/*Copyright(c)2014,烟台大学计算机学院
*Allrights reserved.
*文件名称:MADE2.cpp
*作 者:张生栋
*完成日期:2015年3月28日
*问题描述:用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。
在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配
内存的机制,开辟一个大小正好的连续空间,完成上面的工作。
*输入描述:职工人数,职工工资
*输出描述:排序输出涨工资后得工资
*版 本 号:v1.0
*/
#include <iostream>
#include"salary.h"
using namespace std;
int main()
{
Salary s;
s.set_salarys( );
s.add_salarys(500);
s.sort_salarys();
s.show_salarys( );
return 0;
}
#include <iostream>
#include"salary.h"
using namespace std;
void Salary::set_salarys()
{
int x,i;
cout<<"请输入职工人数:";
cin>>number;
salarys=new double[number];
cout<<"请输入职工的工资: ";
for(i=0;i<number;i++)
{
cin>>x;
salarys[i]=x;
}
}
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]<<" ";
}
#ifndef SALARY_H_INCLUDED
#define SALARY_H_INCLUDED
class Salary
{
private:
double *salarys; //多人的工资
int number; //实际人数
public:
void set_salarys( );
void add_salarys(int x);
void sort_salarys();
void show_salarys( );
};
#endif // SALARY_H_INCLUDED
运行结果: