跪求!!!!!!!!!!!!!!!!最简单的C语言程序 需要100个语句

跪求!!!!!!!!!!!!!!!!最简单的C语言程序 需要100个语句,第1张

#include <string.h>

#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("你的输入有误,请重新:")}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/11228151.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-14
下一篇2023-05-14

发表评论

登录后才能评论

评论列表(0条)

    保存