C++第4周项目5 - 数组作数据成员(扩展1动态开辟空间)

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8690895

【项目5 - 数组作数据成员】阅读教材P255例8.4,注意到类中的数据成员可以是数组。设计一个工资类(Salary),其中的数据成员有:double型数组salary[50](实际人数可以少于50,固定取50可能造成空间浪费),整型值number表示的职工人数。在main函数中调用你自己设计好的成员函数完成下面的功能:

(1)输入职工工资,工资保存到salary数组中,实际人数保存到number中(输入-1标志着工资输入结束);
(2)给每个人涨100元工资;
(3)对涨后的工资进行排序;
(4)输出排序后的工资。

【项目5扩展1(选做)】使用salary[50]有限制,实际人数少浪费空间,人数多时无法完成任务。程序执行中先输入职工人数,然后利用教材P217所讲的动态分配内存的运算符new,开辟一个大小正好的连续空间,完成上面的工作。

扩展1参考解答:

#include <iostream>
using namespace std;
class Salary
{
public:
	void set_salarys( );
	void add_salarys(int x);
	void sort_salarys();
	void show_salarys( );
private:
	double *salarys;    //工资,定义为指针,将来指向一个数组
	int number;			//实际人数
};

void Salary::set_salarys( )
{
	int x,i;
	cout<<"请输入职工人数: ";
	cin>>number;
	salarys=new double[number];  //分配大小正好合适的空间存放数据
	cout<<"请输入职工的工资: ";
	for(i=0;i<number;++i)
	{
		cin>>x;
		salarys[i]=x;
	}
}

void Salary::add_salarys(int x)
{
	int i;
	for (i=0;i<number;i++)
		salarys[i]+=x;
}

void Salary::sort_salarys()
{
	int i,j;
	double t;
	for (i=0;i<number-1;i++)
		for(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( )
{
	int i;
	for (i=0;i<number;i++)
		cout<<salarys[i]<<" ";
}

int main( )
{
	Salary s;
	s.set_salarys( );
	s.add_salarys(100);
	s.sort_salarys();
	s.show_salarys( );
	system("PAUSE");
	return 0;
}

补充说明:这个程序看起来很不错,在空间利用上是如此节约。然而,用new动态分配过的空间应该要用delete回收的。在此处先不强调这一点,后面讲析构函数时再探讨存在着怎样的风险,并学习如何避免。

时间: 2024-09-21 02:33:55

C++第4周项目5 - 数组作数据成员(扩展1动态开辟空间)的相关文章

C++第4周项目5 - 数组作数据成员

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8690895 [项目5 - 数组作数据成员]阅读教材P255例8.4,注意到类中的数据成员可以是数组.设计一个工资类(Salary),其中的数据成员有:double型数组salary[50](实际人数可以少于50,固定取50可能造成空间浪费),整型值number

C++第4周项目5 - 数组作数据成员(扩展2、3引入文件)

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565,本周题目链接:http://blog.csdn.net/sxhelijian/article/details/8690895 [项目5 - 数组作数据成员]阅读教材P255例8.4,注意到类中的数据成员可以是数组.设计一个工资类(Salary),其中的数据成员有:double型数组salary[50](实际人数可以少于50,固定取50可能造成空间浪费),整型值number

C++第4周(春)项目4 数组作数据成员

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目4 - 数组作数据成员]阅读教材P255例8.4,注意到类中的数据成员可以是数组.设计一个工资类(Salary),其中的数据成员如下类的声明. class Salary { public: void set_salarys( ); //(1) void add_salarys(int x); //(2) void sort_salarys

C++实践参考:数组作数据成员

[项目 - 数组作数据成员]下面是设计好的一个工资类(Salary): class Salary { public: void set_salarys( );//输入职工工资(输入-1标志着工资输入结束),工资保存到salary数组中,实际人数保存到number中: void add_salarys(int x); //给每个人涨x元工资 void sort_salarys(); //对工资由大到小排序 void show_salarys( ); //显示工资信息 private: double

C++程序设计-第6周 const用法及指针数据成员

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 第一部分 阅读程序 阅读程序,可以在上机时通过单步执行进一步和你在人脑中运行程序的过程进行对照. a.阅读程序,写出程序的运行结果并理解 #include <iostream> using namespace std; class base { private: int m; public: base(){}; base(int a) {m=a; } int get()

C++第14周项目1——数组大折腾

课程首页地址:http://blog.csdn.net/sxhelijian/article/details/7910565 [项目1 - 数组大折腾]创建一个长度为20的整型数组,通过初始化,为数组中的前10个元素赋初值,然后通过键盘输入,使后10个元素获得值,将所有元素值加倍后保存在数组中,最后由前往后输出数组中所有元素的值,再由后往前输出数组中所有元素的值,再输出数组中的所有偶数,以及下标为3的倍数的元素值. 报告模板及部分代码如下: /* * 程序的版权和版本声明部分 * Copyrig

2013级C++第14周项目——一维数组、字符数组

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1 - 数组大折腾] 将所有元素值加倍后保存在数组中,最后由前往后输出数组中所有元素的值,再由后往前输出数组中所有元素的值,再输出数组中的所有大于100的数,以及下标为3的倍数的元素值. (1)创建一个长度为20的整型数组,通过初始化,为数组中的前10个元素赋初值,然后通过键盘输入后10个元素的值,从前往后(从第0个到第19个)输出数组中元素的值,每5个元素换一行.

C++第14周项目1——数组折腾一下就明白了

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目1 - 数组大折腾] 将所有元素值加倍后保存在数组中,最后由前往后输出数组中所有元素的值,再由后往前输出数组中所有元素的值,再输出数组中的所有大于100的数,以及下标为3的倍数的元素值. (1)创建一个长度为20的整型数组,通过初始化,为数组中的前10个元素赋初值,然后通过键盘输入后10个元素的值,从前往后(从第0个到第19个)输出数组中元素的值,每5个元素换一行.

C++第14周项目4——数组的排序

课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759 [项目4 - 数组的排序] 编函数,完成冒泡排序.要求不能改变下面的main函数. 重点体会:(1)排序算法:(2)数组名作形式参数,将能改变作为实际参数的数组的值,实际参数传递给形式参数的是数组的地址值,也是传值:(3)形式参数中不指定数组大小,实际数组的大小也一并作为参数传递. 参考程序段如下: #include <iostream> using namespace