上机题1:任意输入两个大于10的整数,将两数分别反转(逆序)后两相乘,如果最后一位是0去掉0,再反转后输出;
#include<stdio.h>
void main()
{
int nx(int n);
int x,y,z;
printf("请输入两个大于十的数:");
scanf("%d%d",&x,&y);
z=nx(x)*nx(y);
z=nx(z);
printf("%d",z);
}
int nx(int n)
{int a,b=0;
while (n!=0)
{
a=n%10;
n=n/10;
b=b*10+a;
}
return b;
}
运行结果
-----------------------分割线-----------------------
上机题2:假设一个数列K表的前两项是0,1,而之后的每一项为KN= 2 * KN-1+3 KN-2,输入一个正整数N,计算和输出该数列的第Ñ项
要求:利用递归函数
#include<stdio.h>
void main()
{
int Kn(int n);
int n;
printf("输入一个正整数N:");
scanf("%d",&n);
printf("Kn(%d)=%d\n",n,Kn(n));
}
int Kn(int n)
{
int result;
if(n<0)
printf("输入错误!\n");
else
if(n==1||n==2)
result=n-1;
else
result=2*Kn(n-1)+3*Kn(n-2);
return result;
}
运行结果
-----------------------分割线-----------------------
上机题3:编写程序,输入一个正整数n,如果n+1是质数则输出Yes,否则输出No。另,由于最小的质数是2,所以先检查它是否小于2,如果是的话,则提示“质数是不能小于2,请重新输入”
要求:利用自定义函数z(n)检查是不是质数
#include<stdio.h>
void main()
{
int n,a,b;
printf("请输入一个正整数n:");
scanf("%d",&n);
n+=1;
if(n<2)
printf("质数是不能小于2,请重新输入");
else
for(a=2;a<n;a++)
{
b=n%a;
if(b==0)
break;
}
if(n==a)
printf("Yes");
else
printf("No");
}
运行结果