第七周作业

书中习题1:说说下列程序的执行过程和运算结果

#include<iostream>
#include<cmath>
using namespace std;

double squ(double x);  //函数原形
int main()             //主函数
{
	double x;          //定义一个double型变量
	cout<<"please input x:"<<endl;
	cin>>x;
	cout<<"The square root of "<<x<<"is"<<squ(x)<<endl; //调用函数squ输出
	return 0;
	
}
double squ(double x)            //这个函数的作用是求x的开方数
{
	double s1,s2;               //求x开方的过程
	s1=0.5*(1.0+x);
	do
	{
		s2=s1;
		s1=(s2+x/s2)*0.5;
	}while(fabs(s2-s1)>1.0e-6);    //精确到0.00001
	return s1;

}


书2,不用库函数,求整数次幂


#include<iostream>
using namespace std;

long int power(int base,int exponent);

int main()
{   
	int base,exponent;
	cout<<"请输入幂和指数(用空格键隔开):"<<endl;
	cin>>base>>exponent;
	power(base,exponent);
	cout<<base<<"的"<<exponent<<"次方为"<<power(base,exponent)<<endl;
	return 0;
}

long int power(int base,int exponent)
{

	for(int i=1,int s=1;i<=exponent;i++)
		s=s*base;
	return s;


}



3 判断一个数是否素数

#include<iostream>
using namespace std;

char *fac(int);

int main()
{   
	int a;
	cout<<"请输入一个正整数:"<<endl;
	cin>>a;
	cout<<fac(a)<<endl;
}

char *fac(int x)
{
	if(x==1)
		return "这个数既不是素数也不是合数";
	if(x==2)
		return "这个数是素数";
	for(int i=2;i<x;i++)
		if(x%i==0)
			return "这个数是合数";
		else return "这个数是素数";


}



4.编写函数,返回十进制正整数数字顺序相反的整数

#include<iostream>
#include<math.h>
using namespace std;

int func(int);

int main()
{   
	int a;
	cout<<"请输入一数字字符串:"<<endl;
	cin>>a;
	cout<<"新字符串为:"<<func(a)<<endl;
}

int func(int x)

{
	int a[50];
	int i,n=0,s,sum,m;
	while (x!=0)
	{
		i=x%10,
		x=x/10,
		a[n]=i,
		n++;
	}
	m=n-1;
	for(i=0,sum=0;i<n;i++)
		sum+=a[i]*pow(10,m),m--;
	return sum;

}


5.按所给的分数,返回等级字符

#include<iostream>
using namespace std;
char *func (int x);
int main()
{
	int x;
	cout<<"请输入一个百分制分数:"<<endl;
	cin>>x;
	cout<<func(x)<<endl;
	return 0;	
	
}

char *func(int x)
{
	if((x/10)==10||(x/10)==9)
		return "这个分数优秀";
	else if((x/10)==8)
		return "这个分数良好";
	else if((x/10)==7)
		return "这个分数中等";
	else if((x/10)==6)
		return "这个分数及格";
	else return "这个分数不及格";

}




6.求10个学生成绩平均分

#include<iostream>
using namespace std;
double average(int a,int b,int c,int d,int e,int f,int g,int h,int i,int j);
int main()
{
	int a,b,c,d,e,f,g,h,i,j;
	cout<<"请输入10个学生成绩(用空格号隔开):"<<endl;
	cin>>a>>b>>c>>d>>e>>f>>g>>h>>i>>j;
	cout<<"这10个学生的平均成绩为:"<<average(a,b,c,d,e,f,g,h,i,j)<<endl;
	return 0;	
	
}

double average( int a,int b,int c,int d,int e,int f,int g,int h,int i,int j)
{
	
	double s;
	s=(a+b+c+d+e+f+g+h+i+j)/10;
	return s;
	
	
	
}



7.求最大公约数和最小公倍数

#include<iostream>
using namespace std;
int func1 (int x,int y);
int func2 (int x,int y);
int main()
{
	int x,y;
	cout<<"请输入两个整数(用空格键隔开):"<<endl;
	cin>>x>>y;
	cout<<"这两个整数的最大公约数为:"<<func1(x,y)<<endl;
	cout<<"这两个数的最少公倍数为:"<<func2(x,y)<<endl;
	
	return 0;	
	
}


int func1(int x,int y)
{
	int max,min,z;
	max=x,min=y;
	while((max%min)!=0)
	{
		z=max%min;
		max=min;
		min=z;
	}return min;
	
	

}
int func2 (int x,int y)
{
	int result;
	result=(x*y)/func1(x,y);
	return result;

}









8.打印99乘法表

#include<iostream>
using namespace std;
void display ();
int main()
{
	display();
	
	return 0;
}

void display()
{
	int count=0;
	for(int i=1;i<=9;i++)
		for(int j=1;j<=9;j++)
		{
			cout<<j<<"*"<<i<<"="<<j*i<<"\t";
			count++;
			if(count%9==0)
				cout<<endl;
		
		}
			
}




#include<iostream>
using namespace std;
void display ();
int main()
{
	display();
	
	return 0;
}

void display()
{
	
	for(int i=1;i<=9;i++)
		for(int j=1;j<=i;j++)
		{
			cout<<j<<"*"<<i<<"="<<j*i<<"\t";
			if(i==j)
				cout<<endl;
		
		}
			
}





#include<iostream>
#include<iomanip>
using namespace std;
void second ();
int main()
{
	second();
	
	return 0;
}

	void second()  
{  
    
    for(int i=1;i<=9;i++)  
    {         
        int c=1;
        for(int j=i;j<=9;j++)  
            cout<<i<<"*"<<j<<"="<<i*j<<'\t';  
        cout<<endl;  
      
        while (c<=i)  
        {  
            c++;  
            cout<<'\t';  
        }  
    }  
    cout<<endl;
			
}



9.求三个整数的最大值,最少值,平均值.


#include<iostream>
using namespace std;
int func1 (int x,int y,int z);
void func2 (int &x,int &y,int &z);
double func3(int x,int y,int z);
int main()
{
	int a,b,c;
	cout<<"请输入三个整数(用空格键隔开):"<<endl;
	cin>>a>>b>>c;
	cout<<"这三个数最大为:"<<func1(a,b,c)<<endl;
	func2(a,b,c);
	cout<<"这三个数最小为:"<<a<<endl;
	cout<<"这三个数平均值为:"<<func3(a,b,c)<<endl;
	return 0;	
	
}


int func1 (int x,int y,int z)
{
	int m,n;
	m=x>y?x:y;
	n=m>z?m:z;
	return n;

}
void func2 (int &x,int &y,int &z)
{
	int m;
	if (x>y)
		m=y,y=x,x=m;
	if(x>z)
		m=z,z=x,x=m;

	

}
double func3 (int x,int y,int z)
{
	double result;
	result=(x+y+z)/3.0;
	return result;


}


3. 编程实现输入两个4X5矩阵和5X3矩阵,定义函数并在主函数中调用计算它们的积。


#include<iostream>
using namespace std;
void func();
int main()
{
    func();
	return 0;
}
void func()
{
 
 int a[4][5],b[5][3],c[4][3];
 int i,j,k;
 cout<<"请输入矩阵a[4][5]并按enter换行"<<endl;
 for(i=0;i<4;i++)
     for(j=0;j<5;j++)
   cin>>a[i][j];
cout<<"请输入矩阵b[5][3]并按enter换行"<<endl;
 for(i=0;i<5;i++)
  for(j=0;j<3;j++)
   cin>>b[i][j];

 for(i=0;i<4;i++)
  for(j=0;j<3;j++)
   c[i][j]=0;

 for(i=0;i<4;i++)
     for(k=0;k<3;k++)
   for(j=0;j<5;j++)   
    c[i][k]+=a[i][j]*b[j][k];
  cout<<"ab的积组成的新矩阵为:"<<endl;
    for(i=0;i<4;i++)
 {
  for(j=0;j<3;j++)
   cout<<c[i][j]<<" ";
  cout<<endl;
 }
 
}



4.编程计算S[n]=1!+21+3!+...n!。要求定义两个函数,一个计算n!,一个计算s[n],在后一个函数中调用前一个函数。然后在主程序中输入数n的值,然后调用定义函数输出结果。

#include<iostream>
using namespace std;
int func1(int n);
int func2(int n);
int main()
{
	int n;
	cout<<"请输入一个数n:"<<endl;
	cin>>n;
	cout<<"s["<<n<<"]="<<func2(n)<<endl;

	
	return 0;
}

int func1(int n)
{
	for(int i=1,k=1;i<=n;i++)
		k*=i;

	return k;
	
}
int func2(int n)
{
	for(int i=1,sum=0;i<=n;i++)
		sum+=func1(i);
	return sum;

}





5.编写一个函数,输入一个十六进制数,输出相应的十进制数。



#include<iostream>
#include<iomanip>
using namespace std;
void func();
int main()
{

	func();
	return 0;
}

void func()
{

	int n;
	cout<<"请输入一个16进制的数!"<<endl;
	cin>>hex>>n;
	cout<<"转化为10进制为:"<<endl;
	cout<<dec<<n<<endl;
	
}





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值