第四周任务四之工资类的拓展

源程序:

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* 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 ;
}


实验结果:


上机感言:

虽然能运行出来,但不知道这个对不对,还是得请老师帮忙看一下啊...


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值