
#include <stdio.h>
#include <math.h>
unsigned int i,l1,l2,k,l,num1,num2,num,result,t1,t2,t,co,power
unsigned int a[100]int b[100]int c[100]
char s1[100]char s2[100]char s[100]char r[100]
char op[2]
void initial()
void origco()
void judge_sub()
void judge_dif()
void output()
int main(void)
{ initial()
origco()
if (op[0] == '+')
judge_sub()
else if (op[0] == '-')
judge_dif()
output()
system("pause")
}
void initial()
{
scanf("%s",s1)
scanf("%s",op)
scanf("%s",s2)
l1=strlen(s1)
l2=strlen(s2)
num1=num2=0
t1=t2=0
}
void origco()
{
if (s1[0]=='-')
{
t1=1
s1[0]='0'
}
if (s2[0]=='-')
{
t2=1
s2[0]='0'
} //negtive numbers
for (i=0i<l1i++)
num1=num1*10+s1[i]-'0'
for (i=0i<l2i++)
num2=num2*10+s2[i]-'0'
printf("%d %c %d\n",num1,op[0],num2) //得到两个数
i=1
num=num1
while (num1>0)
{
a[i]=num1%2
num1=num1/2
i=i+1
}
num1=num
l1=i
i=1
num=num2
while (num2>0)
{
b[i]=num2%2
num2=num2/2
i=i+1
}
l2=i
num2=num
if (l1>l2) l=l1
else l=l2
b[l]=t2
a[l]=t1 //得到10进制原码
for (i=l1i<li++)
a[i]=0
for (i=l2i<li++)
b[i]=0
for (i=li>0i--)
printf("%d",a[i])
printf("\n")
for (i=li>0i--)
printf("%d",b[i])
printf("\n")//2进制原码
}
void output ()
{
if (co>0)
printf("%d",co)
for (i=l-1i>0i--)
printf("%d",c[i])
printf("\n")
// if (t==1) printf("-")
// printf("%d\n",result)
k=0
while (result>0)
{
k=k+1
r[k]=result%10+'0'
result=result/10
}
// printf("%d",result)
for (i=1i<=ki++)
s[i]=r[k-i+1]
s[k+1]='\0'
if (t==1) s[0]='-'
else s[0]='+'
printf("%s",s)
}
void judge_sub()
{
co=0
if (t1==t2)
{
for (i=1i<li++)
{
c[i]=a[i]+b[i]+co
if (c[i]>=2)
{
c[i]=c[i]-2
co=1
}
else co=0
}
t=t1
//if (co==1) printf("overflow")
}
else
if (num1>num2)
{
for (i=1i<li++)
{
c[i]=a[i]-b[i]-co
if (c[i]<0)
{
c[i]=c[i]+2
co=1
}
else co=0
}
t=t1
//if (co==1) printf("overflow")
}
else
{
for (i=1i<li++)
{
c[i]=-a[i]+b[i]-co
if (c[i]<0)
{
c[i]=c[i]+2
co=1
}
else co=0
}
//if (co==1) printf("overflow")
t=t2
}
c[l]=t
result=0
power=1
for (i=1i<li++)
{
result=result+c[i]*power
power=power*2
}
if (co>0) result=result+co*power
if (co>0)
printf("overflow\n")
printf("%d",t)
}
void judge_dif()
{
co=0
if (t1==t2)
{
if (num1>=num2)
{
for (i=1i<li++)
{
c[i]=a[i]-b[i]-co
if (c[i]<0)
{
c[i]=c[i]+2
co=1
}
else co=0
}
t=t1 //if (co==1) printf("overflow")
}
else if(num1 <num2)
{
for (i=1i<li++)
{
c[i]=-a[i]+b[i]-co
if (c[i]<0)
{
c[i]=c[i]+2
co=1
}
else co=0
}
//if (co==1) printf("overflow")
t = !t1
}
}
else
{
for (i=1i<li++)
{
c[i]=a[i]+b[i]+co
if (c[i]>=2)
{
c[i]=c[i]-2
co=1
}
else co=0
}
t=t1
//if (co==1) printf("overflow")
}
c[l]=t
result=0
power=1
for (i=1i<li++)
{
result=result+c[i]*power
power=power*2
}
if (co>0) result=result+co*power
if (co>0)
printf("overflow\n")
printf("%d",t)
}
1.打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个“水仙花数”,因为153=1^3+5^3+3^3。
#include
#include
int main()
{
int bai_wei,shi_wei,ge_wei,i,sum=0
for(i=100i<1000i++)
{
bai_wei=i/100
shi_wei=(i%100)/10
ge_wei=i%10
if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))
{
printf("%d ",i)
sum++
if(sum%5==0)
printf(" ")
}
}
printf(" ")
return 0
}
2.请输入任意两个整数x和y,求其最大公约数和最小公倍数。
#include
int main()
{
int x,y,min,max,i
printf("请输入任意两个整数:")
scanf("%d%d",&x,&y)
min=x>y?y:x
max=x>y?x:y
for(i=mini>0i--)
if(x%i==0&&y%i==0)
{
printf("这两个整数的最大公约数为:%d ",i)
break
}
for(i=maxi<=x*yi++)
if(i%x==0&&i%y==0)
{
printf("这两个整数的最小公倍数为:%d ",i)
break
}
return 0
}
3.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
#include
#include
#define N 50
int main()
{
int sum1=0,sum2=0,sum3=0,sum4,i=0
char str[N]
printf("请输入一串字符串:")
scanf("%s",str)
for(i=0i<strlen(str)i++) p=""></strlen(str)i++)>
{
if((str[i]>='a'&&str[i]='A'&&str[i]<='Z'))
sum1++
if(str[i]==' ')
sum2++
if(str[i]>='0'&&str[i]<='9')
sum3++
}
sum4=strlen(str)-sum1-sum2-sum3
printf("英文字母的个数:%d ",sum1)
printf("空格的个数:%d ",sum2)
printf("数字的个数:%d ",sum3)
printf("其他符号的个数:%d ",sum4)
return 0
}
4.求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。
#include
#include
int main()
{
int a,n,s=0,i,x=0,y=0
printf("请输入整数a的值:")
scanf("%d",&a)
printf("请输入相加的个数n:")
scanf("%d",&n)
for(i=0i<ni++) p=""></ni++)>
{
x=y+2*pow(10,i)
y=x
s=s+x
}
printf("s=%d ",s)
return 0
}
5.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。
#include
int main()
{
int sum=0,i,j
printf("在1000以内的完数有:")
for(i=2i<=1000i++)
{
for(j=1j<ij++) p=""></ij++)>
if(i%j==0)
sum=sum+j
if(sum==i)
printf("%d ",i)
sum=0
}
printf(" ")
return 0
}
6.输入一个不多于5位的正整数,要求:1、求它是几位数;2、逆序打印出个位数字。
#include
int pows(int a,int n)
{
int sum=1,i
for(i=0i<ni++) p=""></ni++)>
sum=sum*a
return sum
}
int main()
{
int n,i,k,x
printf("n=")
scanf("%d",&n)
for(i=1i<6i++)
if(n/pows(10,i)==0)
{
printf("%d ",i)
k=i
break
}
for(i=0i<ki++) p=""></ki++)>
{
x=n/pows(10,i)%10
printf("%d",x)
}
printf(" ")
return 0
}
7.输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。
#include
int main()
{
int n,a[5],i=0
printf("请输入一个5位数:")
scanf("%d",&n)
while(n!=0)
{
a[i]=n%10
n=n/10
i++
}
if(a[0]==a[4]&&a[1]==a[3])
printf("这个数是回文数 ")
else
printf("这个数不是回文数 ")
return 0
}
8.利用递归算法,将所输入的5个字符,以相反顺序打印出来。
#include
void digui(char a[],int n)
{
if(n==1)
printf("%c",a[0])
else
{
printf("%c",a[n-1])
digui(a,n-1)
}
}
int main()
{
char str[5]
printf("请输入5个字符:")
scanf("%s",str)
digui(str,5)
printf(" ")
return 0
}
9.有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…球出这个序列的前20项之和。
#include
int main()
{
int i,a=1,b=1
float sum=0.0
for(i=1i<=20i++)
{
sum=sum+(float)(a+i)/b
b=a+i
a=i
}
printf("sum=%f ",sum)
return 0
}
10.利用递归算法求5!。
#include
int digui(int n)
{
if(n==1)
return 1
else
return n*digui(n-1)
}
int main()
{
int n,sum
printf("n:")
scanf("%d",&n)
sum=digui(n)
printf("sum=%d ",sum)
return 0
}
答案voidmain(){intsele=1,tfloatxsystem("cls")printf("欢迎使用简易菜单!本菜单在VC++平台编译通过\n")printf("有何建议请联系本人!\n")printf("成绩管理菜单\n")printf("\n")printf(">>1.输入成绩2.计算总分>3.求平均值4.输出总分与平均>5.清理屏幕6.高低排列>7.上平均分人数0.退出>8.全部情况:总分平均分第一名及格人数>>")scanf("%d",&sele)puts("")if(sele>=0&&sele>1.输入成绩2.计算总分>3.求平均值4.输出总分与平均>5.清理屏幕6.高低排列>7.上平均分人数0.退出>8.全部情况:总分平均分第一名及格人数>><<\n")breakcase6:gaodi(a)breakcase7:super(a)breakcase8:full(t,x)break}elseprintf("你的输入有误,请重新:")}欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)