任务1:
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:三角形类
* 作 者:zhxv
* 完成日期: 2012 年 3 月 12日
* 版 本 号: 待定
* 对任务及求解方法的描述部分
* 输入描述:略
* 问题描述:略
* 程序输出:见图示
* 程序头部的注释结束
*/
#include <iostream>
#include <cmath>
using namespace std;
class Triangle
{
public:
void Setabc(float x, float y, float z);//置三边的值,注意要能成三角形
void Getabc(float *x, float *y, float *z);//取三边的值
float Perimeter(void);//计算三角形的周长
float Area(void);//计算并返回三角形的面积
private:
float a, b, c; //三边为私有成员数据
};
void main(void)
{
Triangle Tri1; //定义三角形类的一个实例(对象)
Tri1.Setabc (4, 5, 6); //为三边置初值
float x, y, z;
Tri1.Getabc (&x, &y, &z); //将三边的值为 x,y,z赋值
cout << "三条边为:" << x << '\t' << y << '\t' << z << endl;
cout << "三角形的周长为:" << Tri1.Perimeter()<<'\t'<<"面积为:"<< Tri1.Area()<<endl;
system ("pause");
}
//请在下面定义 Triangle 类中的各个成员函数
void Triangle::Setabc(float x, float y, float z)
{
if (!(x + y < z || x + z < y || z + y < x))
{
a = x;
b = y;
c = z;
}
}
void Triangle::Getabc(float *x, float *y, float *z)
{
*x = a;
*y = b;
*z = c;
}
float Triangle::Perimeter(void)
{
return a + b + c;
}
float Triangle::Area(void)
{
float p = (a + b + c) / 2;
return sqrt(p * (p - a)* (p - b) * (p - c));
}
任务2:
任务感想:利用文件组织项目具有实用性O(∩_∩)O。
任务3:
#include <iostream>
#include <string>
using namespace std;
class NaturalNumber
{
private:
int n;
public:
void setValue (int x);//置数据成员 n 的值,要求判断是否是正整数
int getValue(); //返回私有数据成员 n的值
bool isPrime(); //判断数据成员 n 是否为素数,是返回 true,否则返回 false
void printFactor(); //输出数据成员 n的所有因子,包括 1 和n 自身
bool isPerfect(); //判断数据成员 n 是否为完全数。若一个正整数 n 的所有小于 n 的因子之和等于n,
//则称 n 为完全数, 如 6=1+2+3 是完全数。
bool isReverse(int x);//判断形式参数 x是否为数据成员 n 的逆向数(例 321 是 123 的逆向数)。
bool isDaffodil(int x); //判断形式参数 x 是否是水仙花数。水仙花数的各位数字立方和等于该数,
//如 153=1*1*1+5*5*5+3*3*3
void printDaffodils(); //显示所有大于 1,且小于数据成员 n 的水仙花数;
};
int main(void)
{
NaturalNumber nn; //定义类的一个实例(对象)
nn.setValue (6);
cout << nn.getValue() << (nn.isPrime()?"是":"不是") <<"素数" <<endl;
nn.setValue (37);
cout<< nn.getValue() <<(nn.isPrime()?"是":"不是") <<"素数" <<endl;
nn.setValue (84);
cout<< nn.getValue() <<"的因子有:";
nn.printFactor();
cout << endl;
nn.setValue (6);
cout<< nn.getValue() <<(nn.isPerfect()?"是":"不是")<<"完全数" <<endl;
nn.setValue (26);
cout<<nn.getValue()<<" 和"<<62<<" "<<((nn.isReverse(62))?"是":"不是") << "逆向数" <<endl;
nn.setValue (100000);
cout << "所有大于0,且小于数据成员的水仙花数有:";
nn.printDaffodils();
system ("pause");
//随着成员函数的实现,增加代码以完成相关的测试。注意判断类的成员函数需要测试是或否两种情况……
}
//请在下面定义类中的各个成员函数
void NaturalNumber::setValue (int x)
{
if (x > 0)
{
n = x;
}
}
int NaturalNumber::getValue()
{
return n;
}
bool NaturalNumber::isPrime()
{
for (int i = n / 2; i > 1; --i)
{
if (!(n % i))
{
return false;
}
else
{
return true;
}
}
}
void NaturalNumber::printFactor()
{
cout << n << '\t';
for (int i = n / 2; i > 0; --i)
{
if (!(n % i))
{
cout << i << '\t';
}
}
}
bool NaturalNumber::isPerfect()
{
int sum = 0;
for (int i = n / 2; i > 0; --i)
{
if (!(n % i))
{
sum += i;
}
}
if (sum == n)
{
return true;
}
else
{
return false;
}
}
bool NaturalNumber::isReverse(int x)
{
int s = 0;
for (;x != 0;)
{
s = s * 10 + x % 10;
x = x / 10;
}
if (s == n)
{
return true;
}
else
{
return false;
}
}
bool NaturalNumber::isDaffodil(int x)
{
int s = 0, p = x;
int m;
for (;p != 0;)
{
m = p % 10;
s = s + m * m * m;
p = p / 10;
}
if (s == x)
{
return true;
}
else
{
return false;
}
}
void NaturalNumber::printDaffodils()
{
for(int i = 2; i < n; ++i)
{
if(isDaffodil(i))
{
cout << i <<" ";
}
}
cout << endl;
}
任务4:
#include <iostream>
using namespace std;
class Salary
{
public:
void set_salarys( );
void set_number( );
void add_salarys (int x);
void sort_salarys();
void show_salarys( );
private:
double *p;
int number;
};
int main( )
{
Salary s;
s.set_number( );
s.set_salarys( );
s.add_salarys(250);
s.sort_salarys();
s.show_salarys( );
system("pause");
return 0;
}
void Salary::set_number( )
{
int m = 0;
cin >> m;
number = m;
p = new double [m];
}
void Salary::set_salarys( )
{
for (int x, i = number - 1; i >= 0; --i)
{
cin >> x;
*(p + i) = x;
}
}
void Salary::add_salarys(int x)
{
for (int i = 0; i < number; ++i)
{
*(p + i) += x;
}
}
void Salary::sort_salarys()
{
int j;
double t;
for (int i = 0; i < number - 1; ++i)
{
for(int 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;
}
}
}
}
void Salary::show_salarys( )
{
for (int i=0; i < number; ++i)
{
cout << *(p + i) << " ";
}
}