实验任务一
#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; }
输出与书面运算有区别的原因是:
进行的是整数运算,多余小数部分舍弃不进位。
运算书面表达式如下:
ac/b;ac/b;ac/b;
实验任务二
#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; }
格式符:
1.%d(int)%f(float)%lf(double)%c(char)%s(string),除此之外还有%x(十六进制输出)%u(unsigned)。
2.形似%md中的m是输出宽度,若m小于实际位数,则按照实际输出,否则左端空格补位。
3.而形似%.mf中的m是小数点后保留多少位。
实验任务三
#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("%.1lf,%.1lf\n",x,y); return 0; }
这里修改了多处:
1.第一个scanf处没有&(取址运算符),&的意义是将输入写入这个地址中(应该是地址传递)
2.x和y的输出输入的第一个格式符应该为%lf(double)而不是%f(float)。
3.在%lf基础上变化为%.1lf,满足保留一位的要求
思考:
其中c1,c2,c3为字符型,输入回车或者空格都会被直接记录进去,而且后面x和y的输入中因为加了,所以只能1.5,2.5的输入,如果直接1.5加\n会直接出结果
实验任务 四
#include<stdio.h>
int main() { char x; x=getchar();
if(x>='0'&&x<='9') // 待补足①,判断x是数字字符表达式 printf("%c是数字字符\n", x); else if(x>='A'&&x<='Z'||x>='a'&&x<='z') // 待补足②,判断x是大写或小写英文字母的表达式 printf("%c是英文字母\n", x); else printf("%c是其它字符\n", x); return 0; }
思考:
修改了一下程序,测试时用了循环来测试。
单个输入字符可以使用x=getchar();
但是如果往下还有字符型的输入,那么就必须加上getchar();来抵消回车的阻碍,或者无空白连续输入。
实验任务 五
#include<stdio.h> int main() { char ans1,ans2; printf("复习了没? (输入y或Y表示复习了,输入n或N表示没复习) : "); ans1=getchar(); getchar(); //这里不要你就输入到ans2啦! 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; }
思考:
首先getchar();的作用就是读取键盘的一个字符,就是输入完的回车,写入进去是\n。
当然,它只是读取,不作任何写入地址。但是你不加它,ans2就读取到了。
实际上这样写,我只要不输入y或Y,都会判断出“罗马不是一天毁灭的”
实验任务 六
/*完成任务时使用了int,使用内存小 ,但非整数公比时,使用double才是正确的选择*/ #include<stdio.h> #include<math.h> int main() { int n;//定义了运算的量 int s;//定义结果的量 scanf("%lf",&n);//输入 int x=pow(2,n);//q的n次方 s=1*(1-x)/(1-2);//公式给出 printf("%lf",s); return 0; }
思考已经放在了注释