#include <stdio.h> int main() { int a=5, b=7, c=100, d, e, f; d = a/b*c; e = a*c/b; f = c/b*a; printf("d=%d, e=%d, f=%d\n",d,e,f); return 0; }
line6 5/7*100=0*100=0
line7 5*100/7=500/7=71
line8 100/7*5=14*5=70
结果原因是因为 /是取整数省去小数部分
#include <stdio.h> int main() { int x=1234; float f=123.456; double m=123.456; char ch='a'; char a[]="Hello, world!"; int y=3, z=4; printf("%d %d\n", y, z); printf("y=%d, z=%d\n", y,z); printf("%8d,%2d\n", x,x); printf("%f, %8f, %8.1f, %0.2f, %.2e\n",f,f,f,f,f); printf("%lf\n",m); printf("%3c\n", ch); printf("%s\n%15s\n%10.5s\n%2.5s\n%.3s\n",a,a,a,a,a); return 0; }
%d 整数输出 %8d 一共占8个位 %2 占两位因为原数4位 按原位
%f 浮点型输出 %8f 浮点型占8位 %8.1 保留一位小数 %0.2保留两位小数
%.2e 保留两位小数,以e指数形式输出 %lf双精度型 %3c 按字符型输出
%s 字符串输出 %15s 占15位 %.3s 取字符串前三个
#include <stdio.h> int main() { double x,y; char c1,c2,c3; int a1,a2,a3; scanf("%d%d%d",&a1,&a2,&a3); printf("%d,%d,%d\n",a1,a2,a3); scanf("%c%c%c",&c1,&c2,&c3); printf("%c%c%c\n",c1,c2,c3); scanf("%lf,%lf",&x,&y); printf("%lf,%lf\n",x,y); return 0; }
#include <stdio.h> int main() { char x; x = getchar(); if(x>='0'&&x<='9') printf("%c是数字字符\n", x); else if(x>='A'&&x<='z') printf("%c是英文字母\n", x); else printf("%c是其它字符\n", x); return 0; }
#include <stdio.h> int main() { char ans1, ans2; printf("复习了没? (输入y或Y表示复习了,输入n或N表示没复习) : "); ans1 = getchar(); getchar(); printf("\n动手敲代码了没? (输入y或Y表示敲了,输入n或N表示木有敲) : "); ans2 = getchar(); if(ans1=='Y'||ans1=='y'&&ans2=='y'||ans2=='Y') printf("\n罗马不是一天建成的:)\n"); else printf("\n罗马不是一天毁灭的。。。\n"); return 0; }
#include <stdio.h> #include <math.h> int main(){ int s,m,n; scanf("%d",&n); int a,q; a=1,q=2; m=pow(q,n); s=a*1*(1-m)/(1-q); printf("n = %d 时,sum = %d",n,s); return 0; }
不知道如何限制n在1-10之间 函数的n次方公式 是百度的