您的位置:首页 > 编程语言 > C语言/C++

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

2016-04-21 09:17 375 查看
*/
* 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
; //工资, 指针更好
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;
}


运行结果:



心得:

   无
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: