您的位置:首页 > 其它

第三周上机实践项目5-工资类(2.动态扩容无浪费)

2015-03-27 18:49 176 查看
/*
*Copyright(c)2014,烟台大学计算机学院
*All rights reserved.
*文件名称:test.cpp
*作者:满星辰
*完成日期:2015年 3月 27日
*版本号:v1.0
*问题描述:设计一个工资类(Salary),其中类的数据成员如下:
*输入描述:
*程序输出:
*/
class Salary
{
private:
double salarys[50]; //多人的工资
int number;  //实际人数
};
要设计的成员函数有:

void set_salarys( ):输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中;

void add_salarys(int x):给每个人涨x元工资

void sort_salarys():对工资排序

void show_salarys( ):显示工资信息

(2)用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配内存的机制,开辟一个大小正好的连续空间,完成上面的工作。

#include <iostream>
using namespace std;
class Salary
{
private:
double *salarys; //多人的工资
int number;  //实际人数
public:
void set_salarys( );//输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中;
void add_salarys(int x);//给每个人涨x元工资
void sort_salarys();//对工资排序
void show_salarys( );//显示工资信息
};
int main()
{
Salary s1;
s1.set_salarys();
s1.add_salarys(500);
s1.sort_salarys();
s1.show_salarys();
return 0;
}
void Salary::set_salarys( )
{
cout<<"Please input people's number:";
cin>>number;
salarys=new double[number];
cout<<"Please input people's salarys:"<<endl;
for(int i=0;i<number;++i)
{
cin>>salarys[i];
}
}
void Salary::add_salarys(int x)//给每个人涨x元工资
{
for(int i=0; i<number; i++)
{
salarys[i]+=x;
}
}
void Salary::sort_salarys()//对工资排序
{
double t;
for(int i=0; i<number; ++i)
for(int j=0; j<number-1; ++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<<salarys[i]<<endl;
}
}
心得:

关于动态数组扩容的,我能说我只记得个名字么? 又看以前的博文。。。

不过是真的不太记得了。用new 来开辟一个大小合适的新空间。。。抽空再看看吧

图片

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