源程序:
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:动态链表工资类
* 作 者: 114-3 张宗佳
* 完成日期: 2012 年 3 月 17 日
* 版 本 号: vc.2
* 对任务及求解方法的描述部分
* 输入描述:输入职员的工资
* 问题描述:使用salary[50]有限制,实际人数少浪费空间,人多时无法完成任务。利用
教材p217页所讲的动态分配内存的运算符new开辟一个大小正好的连续空间并完成下面的工作
(1)输入职工工资,工资保存到salary数组中,实际人数保存到number中(输入-1标志着工资输入结束);
(2)给每个人涨100元工资;
(3)对涨后的工资进行排序;
(4)输出排序后的工资。
* 输出描述:输出职员涨工资,排序后的数据
* 程序头部的注释结束
*/
#include<iostream>
using namespace std;
class Salary
{
public:
void input_salary();
void add_salary();
void order_salary();
void show_salary();
private:
double salary[50];
int number;
};
int main()
{
Salary *sal1;
sal1 = new Salary;
sal1->input_salary();
sal1->add_salary();
sal1->order_salary();
cout << "增加工资且排序后的工资是:" << endl;
sal1->show_salary();
delete sal1;
return 0;
}
void Salary::input_salary()
{
int i;
cout << "职员的人数是:" ;
cin >> number;
cout << "请输入职工工资:" << endl;
for(i = 0; i < number; ++i)
{
cin >> salary[i];
}
return ;
}
void Salary::add_salary()
{
for(int i = 0; i < number; ++i)
{
salary[i] = salary[i] + 100;
}
}
void Salary::order_salary()//排序
{
int i, j, t;
double *p = salary;
for(i = 0; i < number; ++i)
{
for(j = 0; j < number - i - 1; ++j)
{
if(*(p + j) < *(p + j + 1))
{
t = *(p + j);
*(p + j) = *(p + j + 1);
*(p + j + 1) = t;
}
}
}
return ;
}
void Salary::show_salary()
{
for(int i = 0; i < number; ++i)
{
cout << salary[i] << endl;
}
return ;
}
实验结果:
上机感言:
虽然能运行出来,但不知道这个对不对,还是得请老师帮忙看一下啊...