实验一
task1-1
源代码:
1 #include <stdio.h> 2 int main () 3 { 4 printf(" O \n"); 5 printf("<H>\n"); 6 printf("I I\n"); 7 printf(" O \n"); 8 printf("<H>\n"); 9 printf("I I\n"); 10 11 return 0 ; 12 }
编译结果:
task1-2
源代码:
1 #include <stdio.h> 2 int main () 3 { 4 printf(" O \t"); 5 printf(" O \n"); 6 printf("<H>\t"); 7 printf("<H>\n"); 8 printf("I I\t"); 9 printf("I I\n"); 10 11 return 0 ; 12 }
编译结果:
task 2
源代码:
1 #include <stdio.h> 2 int main () 3 { 4 double a,b,c; 5 scanf("%lf%lf%lf",&a,&b,&c); 6 7 if (a+b>c && b+c>a && a+c>b) 8 printf("能构成三角形\n"); 9 else 10 printf("不能构成三角形\n"); 11 12 return 0 ; 13 }
编译结果:
task 3
源代码:
1 #include <stdio.h> 2 int main () 3 { 4 char ans1, ans2; 5 6 printf("每次课前认真预习、课后及时预习了没?(输入y或Y表示有,输入n或N表示没有):"); 7 ans1 = getchar(); 8 9 getchar(); 10 11 printf("\n动手敲代码实践了没?(输入y或Y表示敲了,输入n或N表示木有敲):"); 12 ans2 = getchar(); 13 14 if (ans1 == 'y'||ans1 == 'Y' && ans2 == 'n'||ans2 == 'N' ) 15 printf("\n罗马不是一天建成的,继续保持哦:)\n"); 16 else 17 printf("\n罗马不是一天毁灭的,我们来建设吧\n"); 18 19 return 0; 20 }
编译结果:
总结:
1.删去line9时,在第二个问还没有输入回答时就直接输出结果并结束了运行
2.line9即getchar()的主要特点是“阻塞式等待输入”,会一直等待用户按下回车键才开始读取
task 4
源代码:
1 #include<stdio.h> 2 3 int main () 4 { 5 double x,y; 6 char c1,c2,c3; 7 int a1,a2,a3; 8 9 scanf("%d%d%d", &a1, &a2, &a3); 10 printf("a1 = %d,a2 = %d,a3 = %d\n", a1, a2, a3); 11 12 scanf("%c%c%c", &c1, &c2, &c3); 13 printf("c1 = %c,c2 = %c,c3 = %c\n", c1, c2, c3); 14 15 scanf("%lf,%lf",&x,&y); 16 printf("x = %f,y = %lf\n", x, y); 17 18 return 0; 19 }
编译结果:
总结:
1.整数型int占4个字节,所以在运行时输入数字可以用空格隔开
2.字符型char固定占1个字节,所以在运行时不能输入空格
task 5
源代码:
1 #include<stdio.h> 2 3 int main () 4 { 5 int year; 6 double m; 7 m = 1e+9/(60*60*24*365); 8 year = m + 0.5; 9 10 printf("10亿秒约等于%d年\n",year); 11 return 0; 12 }
编译结果:
task 6-1
源代码:
1 #include<stdio.h> 2 #include<math.h> 3 4 int main () 5 { 6 double x, ans; 7 8 scanf("%lf",&x); 9 ans = pow(x,365); 10 printf("%.2f的365次方:%.2f\n",x,ans); 11 12 return 0 ; 13 }
编译结果:
task 6-2
源代码:
1 #include<stdio.h> 2 #include<math.h> 3 4 int main() 5 { 6 double x,ans; 7 8 while(scanf("%lf",&x)!=EOF) 9 { 10 ans = pow(x,365); 11 printf("%.2f的365次方:%.2f\n",x,ans); 12 printf("\n"); 13 } 14 15 return 0; 16 }
编译结果:
task 7
源代码:
1 #include<stdio.h> 2 3 int main() 4 { 5 double c,f; 6 7 while(scanf("%lf",&c)!=EOF) 8 { 9 f = 9.0/5.0*c+32; 10 printf("摄氏度c = %.2lf时,华氏度f = %.2lf",c,f); 11 printf("\n"); 12 } 13 14 15 return 0; 16 }
编译结果:
task 8
源代码:
1 #include<stdio.h> 2 #include<math.h> 3 4 int main() 5 { 6 int a,b,c; 7 double s,area; 8 9 while(scanf("%d%d%d",&a,&b,&c)!=EOF) 10 { 11 s = (a+b+c)/2.0; 12 area = sqrt(s*(s-a)*(s-b)*(s-c)); 13 printf("a = %d,b = %d, c = %d,area = %.3lf",a,b,c,area); 14 printf("\n"); 15 } 16 17 18 return 0; 19 }
编译结果: