C++走向远洋——37(工资类,2)

来源:互联网 发布:淘宝商家不见了怎么办 编辑:程序博客网 时间:2024/04/30 13:12
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:salarly.cpp * 作者:常轩 * 微信公众号:Worldhello * 完成日期:2016年4月20日 * 版本号:V1.4 * 问题描述:对数组内的工资进行一系列的操作 * 程序输入:工资 * 程序输出:见运行结果 */#include <iostream>  #include <fstream>  #include <cstdlib>  using namespace std;  const int N=500;  class Salary  {  public:      void read_data( );      void write_data();      void add_salarys(int x);      void sort_salarys();      void show_salarys( );  private:      double salarys[N]; //工资, 指针更好      int number;        //人数  };  void Salary::read_data( )  {      int i;      ifstream infile("salary.txt",ios::in);   //以输入的方式打开文件      if(!infile)                 //测试是否成功打开      {          cerr<<"open error!"<<endl;          exit(1);      }      i=0;      while(infile>>salarys[i])          i++;      number=i;      infile.close();  }  void Salary::write_data( )  {      int i;      ofstream outfile("salary_ordered.txt",ios::out);   //以输入的方式打开文件      if(!outfile)                 //测试是否成功打开      {          cerr<<"open error!"<<endl;          exit(1);      }      for(i=0; i<number; ++i)      {          outfile<<salarys[i]<<endl;      }      outfile.close();  }  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]<<"\t\t";  }  int main( )  {      Salary s;      s.read_data( );      s.add_salarys(500);      s.sort_salarys();      s.write_data( );      s.show_salarys( );      return 0;  } 


运行结果:

心得:

   无

1 0
原创粉丝点击