问题及代码:
运行结果:
动态数组。
/*
*Copyright (c)2015,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:score.cpp
*作 者:单昕昕
*完成日期:2015年3月20日
*版 本 号:v1.0
*
*问题描述:用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配内存的机制,开辟一个大小正好的连续空间,完成上面的工作。
*程序输入:工资,涨的工资。
*程序输出:降序排序后工资数据。
*/
#include <fstream> //操作文件必写
#include<iostream>
#include<cstdlib>
using namespace std;
class Salary
{
private:
int number;
double *salarys; //多人的工资
public:
void set_salarys();//输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中;
void add_salarys(int x);//给每个人涨x元工资
void sort_salarys();//对工资排序
void show_salarys();//显示工资信息
};
void Salary::set_salarys( )
{
int i;
cout<<"请输入职工的人数: ";
cin>>number;
salarys=new double[number]; //分配大小正好合适的空间存放数据
cout<<"请输入职工的工资: ";
for(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()//对工资排序
{
int j,i,t; //冒泡升序排列所有工人的工资
for(j=0; j<number-1; j++)
for(i=0; i<number-1-j; i++)
if(salarys[i]>salarys[i+1])
{
t=salarys[i];
salarys[i]=salarys[i+1];
salarys[i+1]=t;
}
}
void Salary::show_salarys()//显示工资信息
{
int i;
for(i=0; i<number; i++)
cout<<salarys[i]<<endl;
}
int main()
{
int x;
Salary salary;
salary.set_salarys();
cout<<"请输入涨的工资数:";
cin>>x;
salary.add_salarys(x);
salary.show_salarys();
return 0;
}
运行结果:
动态数组。
学习心得:
说实话我一开始真的忘了怎么开辟新的空间,忘了动态数组到底怎么解决了。。看来知识点就是得多用才能记住啊~~~