第三周——基于对象的程序设计——工资类(2)动态数组

问题及代码:

/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:  图书馆的书 .cpp
*作    者:莉莉
*完成日期:2015年3月19日
*版 本 号:v1.0
*问题描述:用salary[50]有限制,实际人数少时,会浪费空间,人数多了,无法完成任务。在main()中先输入职工人数,作为参数传递给输入职工工资的成员函数,然后利用动态分配内存的机制,开辟一个大小正好的连续空间,完成上面的工作。
*/
#include <iostream>
using namespace std;
class Salarys
{
public:
    void set_salarys();
    void add_salarys(int x);
    void sort_salarys();
    void show_salarys();
private:
    double *salarys;
    int number;
};
void Salarys::set_salarys()
{
    int i=0;
    double money;
    cout<<"请输入职员人数:"<<endl;
    cin>>number;
    salarys=new double[number];
    cout<<"请录入员工工资:"<<endl;
    for(i=0; i<number; i++)
    {
        cin>>money;
        salarys[i]=money;
    }
}
void Salarys::add_salarys(int x)
{
    int i=0;
    for(i=0; i<number; i++)
    {
        salarys[i]+=x;
    }
}
void Salarys::sort_salarys()
{
    int i=0,j=0;
    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 Salarys::show_salarys()
{
    int i=0;
    for(i=0; i<number; i++)
    {
        cout<<salarys[i]<<" ";
    }
    cout<<endl;
}
int main()
{
    int a;
    Salarys s;
    s.set_salarys();
    s.show_salarys();
    cout<<"请输入要涨的金额:"<<endl;
    cin>>a;
    s.add_salarys(a);
    cout<<"增加后的工资为:"<<endl;
    s.show_salarys();
    cout<<"按工资由高到低排序后:"<<endl;
    s.sort_salarys();
    s.show_salarys();
    return 0;
}


运行结果:

第三周——基于对象的程序设计——工资类(2)动态数组_第1张图片

心得体会:

在处理上还是有些问题,就是动态数组的开辟问题,出现了生疏,参考的贺老师的,回头要补习一下这方面的问题了

你可能感兴趣的:(第三周——基于对象的程序设计——工资类(2)动态数组)