第4周实验报告

 任务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) << " ";
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值