第3周專案5-陣列作資料成員(1)

不被看好的青春叫成長發表於2015-03-21
*  
 * Copyright (c) 2015, 煙臺大學計算機學院  
 * All rights reserved.  
 * 檔名稱:test.cpp  
 * 作    者:劉暢   
 * 完成日期:2015年 3 月 21 日  
 * 版 本 號:v1.0  
 * 
 * 問題描述: 閱讀教材P255例8.4,注意到類中的資料成員可以是陣列。設計一個工資類(Salary),其中類的資料成員如下:
     class Salary
     {
     private:
         double salarys[50]; //多人的工資
         int number;  //實際人數
     };
     要設計的成員函式有:
     void set_salarys( ):輸入職工工資(輸入-1標誌著工資輸入結束),工資儲存到salary陣列中,實際人數儲存到number中;
     void add_salarys(int x):給每個人漲x元工資
     void sort_salarys():對工資排序
     void show_salarys( ):顯示工資資訊
    (1)在main函式定義Salary類的物件,輸入工資,再給每個人漲500元工資,排序後工資資料,然後輸出結果。
 * 輸入描述:NULL;
 * 程式輸出:按要求輸出。

 

程式碼如下:

#include <iostream>
using namespace std;
class Salary
{
public:
    void set_salarys( );             //輸入職員工資(輸入-1標準著工資輸入結束),工資儲存到salary陣列中,實際人數儲存到number中。
    void add_salarys(int x);         //給每個人漲x元工資
    void sort_salarys( );            //對工資排序
    void show_salarys( );            //顯示工資資訊
private:
    double salarys[50];              //多人的工資
    int number;                      //實際人數
};
int main()
{
    Salary s;
    s.set_salarys( );
    s.show_salarys( );
    s.add_salarys(500);
    s.sort_salarys( );
    s.show_salarys( );
    return 0;
}

void Salary::set_salarys()
{
    int money,i=0;
    while (cin>>money&&money>=0)
    {
        salarys[i]=money;
        i++;
    }
    number=i;
}

void Salary::add_salarys(int x)
{
    int i;
    for (i=0;i<number;i++)
        salarys[i]+=x;
}

void Salary::sort_salarys()
{
    int i,j;
    double t;
    for (i=0;i<number-1;i++)
        for(j=0;j<number-i-1;j++)
            if (salarys[j]<salarys[j+1])      //  從高到低的排列
            {
                t=salarys[j];
                salarys[j]=salarys[j+1];
                salarys[j+1]=t;
            }
}

void Salary::show_salarys( )
{
    int i;
    for (i=0;i<number;i++)
        cout<<salarys[i]<<endl;
}


執行結果:

相關文章