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

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


运行结果:

技术分享

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。