问题及代码:
/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:test.cpp
*作者:陈文青
*完成日期:2015年3月23日
*版 本 号:v1.0
*
*问题描述:用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。
在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配内
存的机制,开辟一个大小正好的连续空间,完成上面的工作。
*程序输入:
*程序输出:
*/
#include<iostream>
using namespace std;
class Salary
{
public:
void set_salarys(); //输入职工工资
void add_salarys(int x);//每人涨x元攻资
void sort_salarys(); //对工资排序
void show_salarys(); //显示工资信息
private:
double *salarys; //用来动态数组
int number; //实际人数
};
//输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中;
void Salary::set_salarys()
{
int i,sal;
cout<<"请输入职工人数:";
cin>>number;
salarys=new double[number];
cout<<"请输入职工工资:";
for(i=0;i<number;i++)
{
cin>>sal;
salarys[i]=sal;
}
}
//给每个人涨x元工资
void Salary::add_salarys(int x)
{
for(int i=0; i<number; i++)
salarys[i]+=x;
}
//对工资排序
void Salary::sort_salarys()
{
double t;
for (int i=0; i<number-1; i++)
for(int 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()
{
for (int i=0; i<number; i++)
cout<<salarys[i]<<" ";
cout<<endl;
}
int main()
{
Salary s;
s.set_salarys();
cout<<"每位职工工资增加500元后:";
s.add_salarys(500);
s.show_salarys();
cout<<"职工工资排序后:";
s.sort_salarys();
s.show_salarys();
return 0;
}
运行结果:
知识点总结:
利用动态数组改造职工工资表,节省空间
学习心得:
动态数组又不会用了,所以学过的知识应该经常复习,运用。