/*
* Copyright (c) 2015, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:姜甜甜
* 完成日期:2015年 3 月 21日
* 版 本 号:v1.0
*
* 问题描述: (2)用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。在main()中先输入职工人数,
作为参数传递给输入职工工资的成员函数,然后利用动态分配内存的机制,开辟一个大小正好的连续空间,完成上面的工作。
* 程序输出:
*/
#include <iostream>
using namespace std;
class Salary
{
private:
double *salarys; //
int number; //实际人数
public:
void set_salarys();
void add_salarys(int x);
void sort_salarys();
void show_salarys();
};
void Salary::set_salarys()
{
cin>>number;
salarys=new double[number] ;
int i=0;
while(i<number)
{
cin>>salarys[i];
i++;
}
}
void Salary::add_salarys(int x)
{
for(int 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-1-i; j++)
{
if(salarys[j]<salarys[j+1])
{
t=salarys[j];
salarys[j]=salarys[j+1];
salarys[j+1]=t;
}
}
}
void Salary::show_salarys()
{
for(int i=0;i<number;i++)
{
cout<<i<<"的工资是:"<<salarys[i]<<" ";
if((i+1)%5==0)
cout<<endl;
}
}
int main()
{
Salary t;
cout<<"输入员工的工资。"<<endl;
t.set_salarys();
cout<<"员工工资信息为:"<<endl;
t.show_salarys();
int a;
cin>>a;
t.add_salarys(a);
t.sort_salarys();
cout<<"排序后,员工工资信息为:"<<endl;
t.show_salarys();
return 0;
}