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