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

不被看好的青春叫成長發表於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( ):顯示工資資訊
(2)用salary[50]有限制,實際人數少時,會浪費空間,人數多了,無法完成任務。在main()中先輸入職工人數,作為引數傳遞給輸入職工工資的成員函式,然後利用動態分配記憶體的機制,開闢一個大小正好的連續空間,完成上面的工作。

 * 輸入描述: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;              //多人的工資
    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 i;
    double money;
    cout<<"請輸入職工人數:";
    cin>>number;
    salarys=new double[number];
    cout<<"請輸入職工的工資:";
    for (i=0;i<number;i++)
    {
        cin>>money;
        salarys[i]=money;
    }

}

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;
}


 

執行結果:

相關文章