问题及代码;
/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:尚 月
* 完成日期:2015年 3 月 21 日
* 版 本 号:v1.0
*
* 问题描述:用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配内存的机制,开辟一个大小正好的连续空间,完成上面的工作。
* 程序输入:员工工资
* 程序输出:员工增加后排序工资
*/
#include <iostream>
using namespace std;
class Salary
{
private:
double *salarys; //多人工资
int number; //实际人数
public :
void set_Salarys(); //输入职工工资
void add_Salarys(int x); //给每个人涨X元工资
void sort_Salarys(); //对工资排序
void show_Salarys(); //显示工资信息
};
void Salary::set_Salarys()
{
int x,i=0;
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 p;
for(i=0; i<number-1; i++)
for(j=0; j<number-i-1; j++)
if(salarys[j]<salarys[j+1])
{
p=salarys[j];
salarys[j]=salarys[j+1];
salarys[j+1]=p;
}
}
void Salary::show_Salarys()
{
int i;
for(i=0; i<number; i++)
cout<<salarys[i]<<" ";
}
int main()
{
Salary s;
s.set_Salarys();
s.add_Salarys(500);
s.sort_Salarys();
s.show_Salarys();
return 0;
}
运行结果:
总结:动态分配内存感觉真的很方便,开辟了大小正好的连续空间,但是要注意一些细节。