*
* 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;
}
运行结果:
原文:http://blog.csdn.net/liuchang54/article/details/44521393