/* * Copyright (c) 2013, 烟台大学计算机学院 * All rights reserved. * 作 者:孙红蕾 * 完成日期:2013 年 3 月 25 日 * 版 本 号:v1.0 * * 输入描述:职工工资 * 问题描述:工资保存到salary数组中,实际人数保存到number中(输入-1结束);给每个人涨100元工资并排序 * 程序输出:排序后的工资 * 算法设计:略 */ #include <iostream> using namespace std; class Salary { public: void set_salarys( ); void add_salarys(int x); void sort_salarys( ); void show_salarys( ); private: double salarys[50]; //工资 int number; //职工人数 }; //主函数 int main( ) { Salary s; s.set_salarys( ); s.add_salarys(100); s.sort_salarys(); s.show_salarys( ); system("PAUSE"); return 0; } //输入工资 void Salary::set_salarys( ) { int x,i=0; //i表示人数 cin>>x; //输入工资 while(x>0) { salarys[i]=x; i++; cin>>x; } number=i; //把i的值赋给数据成员number } //涨工资 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]<<" "; }
运行图片:
4-5 数组做数据成员
最新推荐文章于 2023-04-26 00:26:35 发布