(一)改错题
1.输出带框文字:在屏幕上输出以下3行信息。
错误信息1:
错误原因:i和d位置错误
改正方法:i和d位置互换
错误信息2:
错误原因:\n后缺了一个"
改正方法:\n后加一个"
错误信息3:
错误原因:第二个printf(" Welcome\n")后缺了一个;
改正方法:printf(" Welcome\n")后加一个;
错误信息4:
错误原因:int mian()写错
改正方法:int mian()改成int main()
进行编译,无错误,符合期望,运行结果如下:
2.计算某个数x的平方赋给y:分别以“y = xx” 和 “xx = y” 的形式输出x和y的值。注意不要删除源程序中的任何注释。输入输出示例(假设x的值为3)
错误信息1:
错误原因:stdio后边缺了.h
改正方法:stdio后边加上.h
错误信息2:
错误原因:1⃣三个%d分别对应y,x,x;2⃣/*的结束注释没有打出来
改正方法:1⃣在x前面加y,x,;2⃣在输出后面加*/
错误信息3:
错误原因:1⃣第一个d前面没有%;2⃣三个%d分没有对应的字母
改正方法:1⃣第一个d前面加%;2⃣三个%d分别对应字母x,x,y
错误信息4:
错误原因:没有给x赋值
改正方法:int x=3
错误信息5:
错误原因:第7行""中的最后没有加\n换行
改正方法:在第7行""中的最后添加\n换行
进行编译,无错误,符合期望,运行结果如下:
(二)学习总结
1.获取不同的数据类型所占的字节数
(1).int类型数据所占的字节大小
源程序
#include <stdio.h>
int main()
{
printf("int: %d字节\n",sizeof(int));
return 0;
}
运行结果:
(2).long类型数据所占的字节大小
源程序
#include <stdio.h>
int main()
{
printf("long: %d字节\n",sizeof(long));
return 0;
}
运行结果:
(3).float类型数据所占的字节大小
源程序
#include <stdio.h>
int main()
{
printf("float: %d字节\n",sizeof(float));
return 0;
}
运行结果:
(4).double类型数据所占的字节大小
源程序
#include <stdio.h>
int main()
{
printf("double: %d字节\n",sizeof(double));
return 0;
}
运行结果:
2.在C语言中,在头文件limits.h中,有关于各种基本数据类型的最大以及最小值的宏定义
(1).int型的最大值为INT_MAX,最小值为INT_MIN。运行下列程序,看一下结果是什么?
结果:
(2).修改程序,输出i+1,结果是什么?为什么?
结果:
原因:因为int类型最大值为2147483647,i+1后整数的值超过它的最大值,当达到最大值时,它将溢出到起始点(即最小值)。
(3).修改程序输出j-1,结果是什么?为什么?
结果:
原因:因为int类型最小值为-2147483648,j-1后整数的值小于它的最小值,当达到最小值时,它将溢出变成最大值。
3.运行下面的程序,输入100 144 64,看看运行结果是什么?为什么?
结果:
原因:%o--表示八进制整数的格式化形式;%d--表示十进制整数的格式化形式;%x--表示十六进制整数的格式化形式。所以输入的100是十进制数,输出的也是十进制数,所以是100;输入的144是八进制数,而输出的是十进制数,所以是100;输入的64是十六进制数,而输出的是十进制数,所以是100。
4.对本章其他你认为需要进行总结的内容进行总结。
总结:
(1).我们需要理解的是变量名与变量值,变量的声明、赋值和初始化,整型常量和整型变量,实型常量和实型变量,算术运算符和赋值运算符,数据类型的转换,宏常量和const常量定义幻数。
(2).我们在编程时需要注意的是:1⃣scanf("%d")后的赋值一定加取地址符&;2⃣我们需要添加注释的习惯,可以更好的帮助我们清晰思路;3⃣我们需要有调试并且多次试用不同情况来检验我们打出的程序是否完善;4⃣区别字母o和数字0的;5⃣当调试程序出错时一定要改一处错误编译一次,因为以后的错误可能是由前一个错误引起的。
(三)实验总结
1.求整数均值
(1)题目
本题要求编写程序,计算4个整数的和与平均值。题目保证输入与输出均在整型范围。
(2)流程图
(3)源代码
#include <stdio.h>
int main()
{
int a,b,c,d,sum;
double average;
scanf("%d%d%d%d",&a,&b,&c ,&d);
sum=a+b+c+d;
average=sum/4.0;
printf("Sum = %d; Average = %.1f",sum,average);
return 0;
}
(4)测试数据及运行结果
运行结果1:
运行结果2:
(5)实验分析
问题1:
原因:
average=sum/4.0,第一次做写成了average=sum/4,导致输出的Average是整数且保留了一位小数
解决办法:
将average=sum/4改成average=sum/4.0
2.是不是太胖了
(1)题目
据说一个人的标准体重应该是其身高(单位:厘米)减去100、再乘以0.9所得到的公斤数。已知市斤是公斤的两倍。现给定某人身高,请你计算其标准体重应该是多少?(顺便也悄悄给自己算一下吧……)
(2)流程图
(3)源代码
#include <stdio.h>
int main()
{
int H;
scanf("%d",&H);
float t,y;
t=(H-100.0)*0.9;
y=2*t;
printf("%.1f",y);
return 0;
}
(4)测试数据及运行结果
运行结果1:
运行结果2:
(5)实验分析
问题1:
原因:
scanf("%d",&H);中的取地址符&忘记写了
解决办法:
在H前面添加&
3.计算物体*下落的距离
(1)题目
一个物体从100米的高空*落下。编写程序,求它在前3秒内下落的垂直距离。设重力加速度为10米/秒2。
(2)流程图
(3)源代码
#include <stdio.h>
int main()
{
int g,t,x;
g=10;
t=3;
x=g*t*t;
float height;
height=1.00/2*x;
printf("height = %.2f",height);
return 0;
}
(4)测试数据及运行结果
运行结果:
(5)实验分析
问题1:
原因:
height=1.00/2*x中的1.00/2写成了1/2导致1/2=0,最后直接影响height的输出值
解决方法:
将height=1.00/2*x改成height=1.00/2*x
4.逆序的三位数
(1)题目
程序每次读入一个正3位数,然后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入700,输出应该是7。
(2)流程图
(3)源代码
#include <stdio.h>
int main()
{
int a,b,c,x,y;
scanf("%d",&x);
a=x/100;
b=x/10%10;
c=x%(a*100+b*10);
y=c*100+b*10+a;
printf("%d",y);
return 0;
}
(4)测试数据及运行结果
运行结果1:
运行结果2:
(5)实验分析
问题1:
刚开始并没有思路,不知从何下手,以至于想单个输入3个值,最后发现根本不对
原因:
没有想到中间应该是数学运算,而不是简单的数值调换
解决方法:
采用数学运算,采用求余、取整等方法从而使达到题目要求。思路正确后在编写过程中没有遇到问题