2015-第3周项目5-数组做数据成员(1)

来源:互联网 发布:linux中端口的欺骗 编辑:程序博客网 时间:2024/05/22 06:49

【项目5 - 数组作数据成员】阅读教材P255例8.4,注意到类中的数据成员可以是数组。设计一个工资类(Salary),其中类的数据成员如下:

[cpp] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. class Salary  
  2. {  
  3. private:  
  4.     double salarys[50]; //多人的工资  
  5.     int number;  //实际人数  
  6. };  
要设计的成员函数有:
  • void set_salarys( ):输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中;
  • void add_salarys(int x):给每个人涨x元工资
  • void sort_salarys():对工资排序
  • void show_salarys( ):显示工资信息

(1)在main函数定义Salary类的对象,输入工资,再给每个人涨500元工资,排序后工资数据,然后输出结果。


#include <iostream>using namespace std;class Salary{private:    double salarys[50]; //多人的工资    int number;  //实际人数public:    void set_salarys();    void add_salarys(int x);    void sort_salarys();    void show_salarys();};int main( ){    Salary s;    s.set_salarys();    s.add_salarys(500);    s.sort_salarys();    s.show_salarys();    return 0;}void Salary::set_salarys(){    int i=0,x;    while(cin>>x&&x!=-1)    {        salarys[i]=x;        ++i;    }    number=i;}void Salary::add_salarys(int x){    int i;    for (i=0;i<=number-1;i++)        salarys[i]+=x;}void Salary::sort_salarys(){    int i,j;    double n;    for (i=0;i<=number-2;i++)        for(j=0;j<=number-i-2;j++)            if (salarys[j]<salarys[j+1])            {                n=salarys[j];                salarys[j]=salarys[j+1];                salarys[j+1]=n;            }}void Salary::show_salarys(){    int i;    for (i=0;i<=number-1;i++)        cout<<salarys[i]<<" ";}

运行结果:


0 0
原创粉丝点击