4-5(扩展1)动态分配内存

来源:互联网 发布:什么是网络协议和算法 编辑:程序博客网 时间:2024/05/18 01:34
/*  * Copyright (c) 2013, 烟台大学计算机学院 * All rights reserved. * 作    者:孙红蕾  * 完成日期:2013 年 3 月 25 日 * 版 本 号:v1.0 * * 输入描述:职工人数 * 问题描述:在程序执行中输入职工人数,利用动态分配内存的运算符new,开辟一个大小正好的连续空间* 程序输出:排序后的工资* 算法设计:略 */ #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;//实际人数  };//主函数int main( ){Salary s;  s.set_salarys( );    s.add_salarys(100);    s.sort_salarys();s.show_salarys( );  system("PAUSE");return 0;}//输入职工人数和工资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]<<" ";}
运行图片:

原创粉丝点击