上机题1:
任意输入两个整数(-1000<n<10000),将两数分别反转(逆序)后两相加,相加后的结果再反转后输出
我的程序:
#include<stdio.h>
int tt(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\n %d",&a,&b);
if(a<1000&&a>-1000&&b<1000&&b>-1000)
{
c=tt(a)+tt(b);
d=tt(c);
printf("%d\n",d);
}
运行程序截图:
-----------------------分割线-----------------------
上机题2:
求1+2!+3!+...+20!的和
要求:利用递归函数
我的程序:
#include <stdio.h>
int plus(int num)
{
int i=1;
int sum=1;
for(i=1;i<=num;i++)
{ sum*=i; }
return sum;}
int main(int argc, char *argv[])
{
int i=1; int total=0;
int plusNum=20;
for(i=1;i<=plusNum;i++)
{ total+=plus(i); }
printf("1到%d的阶乘和为:%d\n",plusNum,total);
return 0;
}
运行程序截图:
-----------------------分割线-----------------------
上机题3:
编写程序,输入一个正整数N,如果N 是质数则输出Yes,否则输出No。另,由于最小的质数是2,所以先检查它是否小于2,如果是的话,则提示“质数是不能小于2,请重新输入”
要求:利用自定义函数P(N)检查N 是不是质数
我的程序:
#include <stdio.h>
int XXX(int x)
{
int i=2,a=x%i;
for(i=2;a!=0;i++){a=x%i;};
i=i-1;
if(i!=x)
return 0;
if(i==x)
return 1;
}
void main()
{
int a,x;
scanf("%d",&a);
if(a>=2)
{
x=XXX(a);
if(x==0&&a!=2)
{printf("No\n");}
if(x==1||a==2)
{printf("Yes\n");}
}
else
{printf("质数是不能小于2,请重新输入");}
}
运行程序截图: