上机题1:任意输入两个整数(-1000<n<10000),将两数分别反转(逆序)后两相加,相加后的结果再反转后输出
#include<stdio.h>
int hanshu(int a)
{
int b=0;
while(a!=0)
{
b=b*10+a%10;
a=a/10;
}
return b;
}
void main()
{
int a,b,c,d;
scanf("%d,%d",&a,&b);
if(a<1000&&a>-1000&&b<1000&&b>-1000)
{
c=hanshu(a)+hanshu(b);
d=hanshu(c);
printf("所求的数为%d",d);
}
}
-----------------------分割线-----------------------
上机题2:求1+2!+3!+...+20!的和
要求:利用递归函数
#include<stdio.h>
long hanshu(int a);
void main()
{
int sum=0;
for(int i=1;i<=20;i++)
{
sum+=hanshu(i);
}
printf("1!+2!+3!+...+20!=%d",sum);
}
long hanshu(int a)
{
int b;
if(a==1||a==0)
b=1;
else
b=a*hanshu(a-1);
return(b);
}
---------------------分割线-----------------------
上机题3:编写程序,输入一个正整数N,如果N 是质数则输出Yes,否则输出No。另,由于最小的质数是2,所以先检查它是否小于2,如果是的话,则提示“质数是不能小于2,请重新输入”
要求:利用自定义函数P(N)检查N 是不是质数
#include<stdio.h>
int zhishu(int x)
{
int i=2,a=x%i;
for(i;a!=0;i++){a=x%i;};
i=i-1;
if(i!=x) return 0;
if(i==x) return 1;
}
void main()
{
int N,x;
scanf_s("%d",&N);
if(N>=2){
x=zhishu(N);
if(x==0&&N!=2){printf("N");}
if(x==1||N==2){printf("Y");}
}
else {printf("质数是不能小于2,请重新输入");}
}