/*
* Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 作 者:孙红蕾
* 完成日期:2013 年 3 月 25 日
* 版 本 号:v1.0
*
* 输入描述:职工人数
* 问题描述:在程序执行中输入职工人数,利用动态分配内存的运算符new,开辟一个大小正好的连续空间
* 程序输出:排序后的工资
* 算法设计:略
*/
#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; //工资,定义为指针,将来指向一个数组
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;
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]<<" ";
}
运行图片: