第2周项目5-数组做数据成员

本文介绍如何在C++中使用动态内存管理为不同数量的员工分配合适的工资空间,并通过成员函数实现工资输入、修改和排序。重点在于合理利用内存资源,确保程序效率和资源利用最大化。
/*
*copyright (c)2014,烟台大学计算机学院
*All rights reserved
*文件名称:project.cpp
*作者:孙春红
*完成日期:2015年3月24日
*版本号:v1.0
*
*问题描述:用salary[50]有限制,实际人数少时,
会浪费空间,人数多了,无法完成任务。在main()中
先输入职工人数,作为参数传递给输入职工工资的成员函数,
然后利用动态分配内存的机制,开辟一个大小正好的连续空间
,完成上面的工作。
*输入描述:略。
*程序输出:略。
*/

#include <iostream>
using namespace std;
class Salary
{
private:
    double *salarys;
    int number;  //实际人数
public:
    void set_salarys();
    void add_salarys(int x);
    void sort_salarys();
    void show_salarys();
};
int main()
{
    Salary s;
    int x;
    s.set_salarys();
    s.show_salarys();
    cout<<endl;
    cout<<"请输入给每位工人所加工资:  ";
    cin>>x;
    s.add_salarys(x);
    s.sort_salarys();
    s.show_salarys();
    return 0;
}
void Salary::set_salarys()
{
    int i;
    cout<<"请输入职工人数:  ";
    cin>>number;
    salarys=new double [number];//开辟大小正好的职工人数的连续空间
    cout<<"输入工资:"<<endl;
   for(i=0;i<number;i++)
   {
       cin>>salarys[i];
   }
}
void Salary::add_salarys(int x)
{
    int i;
    for (i=0;i<number;i++)
    {
        salarys[i]+=x;
    }
}
void Salary::sort_salarys()
{
    int i,t,j;
    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]<<" ";
    }
}


运行结果:

知识点总结:
在面向对象时,学会开辟新的空间,限制员工的数量。重点就是salarys=new double[number]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值