1、编写C程序时应该注意的: 编写程序必须: 一。包含并且仅仅包含一个main() 二。程序体应该在 { 和 }之间书写 三。变量必须 "先定义后使用" 如必须有 int i,j; 才能有 i=10;j=j+1; printf("%5d",j); 这样的语句。 不能写成inti,j; int及其他类型关键字和后面的变量之间要有空格。 四。语句结尾必须有; 但函数首部不能加分号; 如void main() ;错误 五。注意关键字的书写准确 如
2、 printf 不要写成 print 六。学会看编译时的错误提示 如 statement missing ; 表示该高亮提示行没有结尾; 变量定义时注意其类型,需要看该变量的应用之处,确定该变量应该是整型、实型或者字符型 如:如果要执行 i=j%k; 这样运算 则i,j,k 都应该是整型。 若要计算原面积 s=pi*r*r; 则 s,pi,r 都应该是实型。 scanf("%f,%d,%c",&i,&j,&k); 描述向计算机输入三个值按顺序分别给变量i,j,k。 其中i,j,k的类型对应分别是 实型,整型,字符型。即该sc
3、anf语句之前应该有定义: float i; int j; char k; 运行时在黑屏输入界面下输入: 10.53,88,t 其中: 10.53是实型数据 对应%f的格式控制字符要求,将其赋给输入列表的第一个变量i,(注意变量名是i,但用在scanf中必须写成&i). 88是整型数据 对应%d的格式控制字符要求,将其赋给输入列表的第二个变量j 't'是字符型数据(运行输入时不要带 ' ') 对应%c的格式控制字符要求,将其赋给输入列表的第三个变量k 注意输入时用 “,” 分隔 因为在上面 %f,
4、d,%c 中间是指定用 ‘,’分隔的。 如果写成scanf("%f:%d:%c",&i,&j,&k); 则运行时输入 10.53:88:t 如果写成scanf("%f%d%c",&i,&j,&k); 则运行时输入 10.53 88 t 中间用空格分隔。 printf("%7.3f",k);的含义是 : 输出实型变量k的值,并且k的值实际占用7个字符位置,小数位数为三位。 如果k的实际值占不满7个字符宽,则输出时数据前面(左边)系统自动补上相应空格,使其占够7位 如果k的实际值多于7个字符宽,则系统自动扩展宽度,显示全部真实值。
5、 若改为 %-7.3f含义是: 如果k的实际值占不满7个字符宽,则输出时数据后面(右边)系统自动补上相应空格,使其占够7位 如printf("%7.3f,%-7.2f;;;%12.3f,%-12.2f",122.8899,122.8899,122.8899,122.8899); 则输出为: 122.890,122.89_;;;_____122.890,122.89______ _表示空格 _____5个空格 ______6个空格 变量定义时应该注意, <1>.turbo c中定义语句应该放到程序开始
6、的地方,在所有执行语句之前如 int a=0,b=1,c=3; float k; k=a+b-c; 是正确的,而 int a=0,b=1,c=3; a=b-c; float k; k=1; 则是不正确的。 *** 但在vc中两者都是正确的 <2>.定义变量时候注意类型声明的关键字必须和变量之间存在空格。 int k,l,j;是正确的,而 intk,l,j;是错误的。 <3>.变量定义时,还要注意变量的范围。如果想把10!赋值给变量s,不能把s定义为int,
7、 因为10!的结果超过了int的最大值32767。(c++下int范围已经增大为4字节了) 特殊地方 (1)。c语言中乘法运算符*不能省略,即 5/9(f-32)应当写成: 5/9*(f-32) (2)。注意5/9的结果是0而不是0.555556应该写成 5.0/9 5/9.0 5.0/9.0都对;同种数据类型数据之间运算结果仍为该类型,保持不变。 (3)。混合运算时,必须先考虑运算符之间的优先级,优先级高的先运行; 如果优先级一样的情况下,按各运算符的结合性进行。
8、 (4)。i++,i的值先拿出来用,然后再自增。 i=1; j=i++; ------j的值为1; ++i,i的值先自增然后再拿出来用。 i=1; j=++i; ------j的值为2; 有关文件的问题: (1)。c语言的源文件名应该是不多于8个字符组成,并注意以.c(vc中为.cpp)结尾。 (2)。文件名中应该只有一个"."不能有 12.3.c 这样的名字。 (3)。文件名中不应出现汉字字符以及其他特殊字符,如rrr(1).c就会引起问题。 (4)。定义一个文件比如第一
9、章第三题可以采用类似如下的命名方式:1-3.c。 (5)。程序运行时,出现黑屏,可能是在等待用户输入,因为使用了scanf语句。 也可能是死循环,此时同时按下ctrl和break键,强行中断。 (6)。编辑好文件后先保存再调试运行! (7)。每次编好的程序都应该给一个新的文件名,而不能仅仅沿用以前的名字,否则将会把以前编写好的文件覆盖掉。 printf("格式控制" ,输出表列); printf("%d,%8.4f \n %-10.2s--\t--r=%6d", 10 , 888.888 , "suabngu" , k );
10、 (k是整型变量并且前面已经赋值)。 <1>"格式控制"中普通字符 原样照印,如前面的 , 空格 - r= 。 <2>"格式控制"中转义字符按照表示含义输出,如前面的 \n \t 。 <3>"格式控制"中控制字符和后面 输出表列 中数据对象一一对应即从个数、类型、顺序上一致。 如上面 %d 对应 10 %8.4f 对应 888.888 %-10.2s 对应 "suabngu" 表示输出该字符串到屏幕,但仅输
11、出该字 符串的前两个字符即su,并且其右补8个空格。 %6d 对应 k scanf("格式控制",地址表列); scanf("a=%d, f=%10f, k=%c : " ,&i,&j,&k); i,j,k分别是整型,实型,字符型变量 注意变量前面的& <1>"格式控制"中普通字符 程序运行黑屏时原样照输 如前面的语句运行时,黑屏状态下应该输入 a=10, f= (此处可以有0个或者多个空格)90.89, k=$ : 回车符 。 <2>"格式控制"中转义字符按照表
12、示含义输入 。 <3>"格式控制"中控制字符和后面 地址表列 中地址对象一一对应即从个数、类型、顺序上一致。 %d对应 &i %10f对应 &j %c对应 &k 注意都是给变量赋值,即相应屏幕输入值给了变量i,j,k。但形式上必须要前加&,原因以后再说。 <4>地址表列中不能出现常量,比如123,'*',12.333都是不对的。 16,关于赋值语句的说明: <1>.赋值语句形式为 变量名=表达式 ; 注意:赋值号(=)左边只能为 变量名,-----常量、表达式不允许出现在赋值号左边。 赋值号(
13、右边的表达式可以是常量、变量、表达式的形式。 <2>复合的赋值语句 编写C程序时应该注意的问题(选择、循环、数组部分): 1. 选择结构中if和else均只能“管辖”其下的一条语句,当功能实现需要多条语句时必须将这多条语句用 { }括起来,构成复合语句。如: if ( x>y ) x=1; -----当只有一条语句时{ } 可以省略 else x=y+1; -----当只有一条语句时{ } 可以省略 if ( x>y ) { x=1; y++; } -----当有多条语句时,用{ }括起来 els
14、e { x=y+1; --y; } -----当有多条语句时,用{ }括起来 2. 选择结构if (条件) 后面不能加 ; 否则计算机认为其后跟了一条空语句,不能正确表示功能含义。 如: if (x>y) x=y+1; else x-=y; 是正确的语法形式 而 if (x>y) ; x=y+1; else x-=y; 相当于 if (x>y) ; x=y+1; 此处由于 ; 和 x=y+1; 在c语言中是被认为两条语句,应该用{ }括起来,作为一条复合语句(见上
15、面说明1)才正确,否则系统将提示else没有 if 匹配错。(见下面说明3) else x-=y; 3. if 之后可以没有else相匹配,但else不能没有if,即else不能单独使用, 如: if (x>y) x=1; 正确;---无else 而: 。。。 else x--; 错误;---无if进行匹配,else不能单独使用 又如: if(x>y) x++; y--; else --x; ++y; 错误---思考系统提示为何种错误? 4. break 语句只能用于从 switch –case
16、 结构或循环中退出。不能用在其它地方。 5. 判断几个量的大小相互关系时一定不能使用类似如下形式: if (x>y>z) … 必须写成 if (x>y && y>z) … 原因已经讲得很清楚了 6. 在 if (条件) 形式的条件处,条件表达式的形式并非固定为关系表达式或者逻辑表达式,可以是常量、变量、算术表达式等如下均为正确形式: if(6-3)… if(x) …. if(x*x-y*3)… if(x=7) … 系统先计算()内表达式的值,非零认为真即1,0认为假。 特别的对于 if(x=7)…这种形式,系统先把7赋值给变量x,整个赋值表达式的值为7
17、非零==真==1。 7. 对于循环结构来说,同样while之后,do。。。while之间,for之后只能“管辖”一条语句,当功能需要多条语句时,必须通过{}将其括起来构成一条复合语句构成循环体。反之当循环体只有一条语句时{}可以省略。 8. 对于if。。。else构成的选择结构,while,do。。。while,for构成的循环结构,计算机都会认为是一条语句,而和其下面管辖了多少条语句无关。 如: if (x>y) {t=x;x=y;y=t;} 系统会认为这是一条选择语句。因此如下使用就是正确的: k=0; while(k++) if (x>y)
18、{ t=x; x=y; y=t;} 注意:while下面可以不加{ },因为对于系统用来说,现在while下面仅仅“管辖”了一条选择语句。{}可省略。 又如: if(x>3) for(k=0;k<=x;k++) {s=s+k; t=t-k; } 类似的if后面可以不加{},理由同上。 9. 循环如果出现死循环情况可以通过同时按下ctrl和break组合键强行中止循环执行。(针对turbo c中使用) 10. 出现死循环的可能有: <1>循环变量变化方向不是是循环趋于结束(即和循环条件背道而驰) 如 for(k=1;k<=10;k--) 。。。 <2>
19、 号位置不正确 如 x=9; while(x>1) ; {x--; s=s+x;} 此时,系统认为while的循环体是一条空语句。 <3>循环条件书写不正确,(恒为真了) 如 原意为 while(x==5) {y++;s=s+y;。。。} 结果少写一个=号while(x=5) {y++;s=s+y;。。。} 则循环条件恒为真(自己思考为什么,参考前面说明。) 11. 对于知道循环次数的循环搭建模式: <1>有一个循环变量,并且在执行循环之前对其初始化 <2>有判断循环是否结束的循环条件 <3>有使循环趋于结束的循环变量变化。 12. 判断一个实数是否为零不
20、能使用如下形式: float x; … while(x==0) {…} 必须使用形如: … while(x<=1e-6) {…}来进行比较判断。 13. break语句结束本循环,continue语句结束本次循环,开始本循环的下一次循环。 比较:若s=0; for(k=3;k<=10;k++) {if (k%3!=0) break; s=s+k; } //运行后s值为3 for(k=3;k<=10;k++) {if (k%3!=0) continue; s=s+k; } //运行后s值为18 考虑
21、为什么。。。。 14. 环嵌套的使用:外层循环m(定值)次,内层循环n(定值)次,则内层循环中的语句供执行m*n次。若内层循环k(k为外层循环变量,k初值为a,终值为b)次,则内层循环中的语句共执行次a+(a+1)+(a+2)+(a+3)+。。。+(b-1)+b 次。 15. 循环嵌套应注意,外层循环变量变化一次,内层循环变量变化一圈(即内层循环全部执行完),外层变量变化永远比内层变量变化慢。 16. 打印图形的通用公式为: <1>两层循环实现,外层变量控制打印多少行,内层变量控制每行打印多少列 <2>内层循环先考虑前导空格打印 <3>再打印相关图形 如若干星号 <4>再打印回车
22、换行符。 参考所给的程序中打印*组成的三角形的例子。 17. 数组的使用应该注意: 如果有 int a[10]; 此处int称为数组的基类型。 表明:数组名为a,数组长度为10,数组中有10个元素,下标由小到大分别是a[0],a[1],a[2]…a[9],数组中每个元素的类型都是整型。数组名a表示数组的首地址,相当于&a[0],即元素a[0]的地址,是常量,程序里不能有a=1000;这样的赋值。 18. 数组初始化,可以在定义数组的同时赋初值 如:int a[10]={1,2}; 给a[0],a[1]赋值1和2其他元素默认0值,注意这种“一次性赋值”的形式只能在数组定义的同
23、时可以,程序中不能出现a[10]=…的样子。 字符数组赋初值时{}内的值应该带上两侧的单引号如: char k[100]={’a’,’b’,’v’,’5’,’*’}; 注意:int a[ ]; 是错误的。 int a[ ]={1,2,3,4};是正确的,计算机可以根据赋初值的个数,确定数组长度。此时等价于:int a[4]={1,2,3,4}; 二维数组定义同时赋初值方法类似: int a[2][3]={{1,2,3},{4,5}};内层的小括号表明给不同的行赋值。也可以写成 int a[2][3]={1,2,3,4,5};此时计算机会自动根据定义的数组行数、列数分配给数组元素对
24、应的值,效果同上。 对于二维数组来说,长度可以为空,不过需要注意的是,只能用在在定义同时赋初值,且第一维为空,第二维不能为空。 如:int a[][]={1,2,3,4,5}; int a[2][]={1,2,3,4,5}; int a[][]={{1,2},{3,4,5}};都是不对的。 正确的方式为: int a[][3]={1,2,3,4,5};相当于 int a[2][3]={1,2,3,4,5};相当于 int a[][3]={{1,2,3},{4,5}}; 不管是几维数组在内存中都是线性存放,因此不要因为定义了二维数组,则输出数组元素时一定会在屏幕上打印出“行
25、列”的二维样式,输出为一行,一列还是方阵、矩阵、三角形,要根据输出语句来控制,通过循环、空格和换行达到需要的效果,跟是否定义为二维数组无关。 19. 数组在使用的时候特别要注意下标越界问题,尤其是一些“隐式”越界不容易被发现,出现越界计算机将会得不到正确结果。 如:int a[10],k,t; for(k=0;k<10;k++) scanf(“%d”,&a[k]); //注意,从循环中退出时k的值其实已经是10了 for(t=k;t>=0;t--)//第一次循环中a[t]即a[10],没有意义。 printf(“%d”,a[t]); 这段程序运行后将多打印出来一个莫名其
26、妙的数据 20.将字符串倒置,下面的代码有什么问题?? main() { char str[14]="abcedfghijklmn"; char a[14]; int i; for(i=0;i<14;i++) a[i]=str[13-i]; printf("%s",a); } 系统运行将会报error C2117: 'abcedfghijklmn' : array bounds overflow错误。 为何报此错误呢? 注意字符串的长度并非是双引号内的字符个数(此题中为14个)而是字符个数加一, 此题为15个,这是因为系统自动要在字符串的末尾添加字符
27、'\0'造成的。
而题目中存放字符串的字符数组str 和a 定义长度为14,不够存放,所以报错误为下标越界!
可以改为
#include
28、历该列,即确定列下标后,行下标取所有可能。
for(i=0;i 29、
{x[j]=a[0][j]; //---------------注意,此时针对下标为j的每列进行处理,请比较上面另一段代码
for(i=1;i 30、型为void,有返回值的函数其返回值类型必须和函数的类型保持一致。函数只能通过return语句带回一个返回值!
如:
void a ( int x )
{…..}
float b ( int y )
{float c;
……
return c;}
关于函数调用:
1. 函数语句调用: 函数名(实参表); 如: m(3,x);此时函数不一定需要有返回值。
2. 表达式调用: 如z=m(x,y); 此时函数需要有返回值作为表达式运算的一部分。
3. 函数作为其他函数的参数调用 如 z=max(max(x,y),z); 此时函数需要有返回值作为 31、其他函数的参数。
关于函数的原型:
如果被调用函数定义书写在调用函数的前面,则调用函数中不需要对其进行声明(该声明及函数原型的声明)。
反之则必须声明。
如:下例中main函数和m函数都调用了a函数,由于a函数对于此二者的相对位置不同。m函数中需要对其进行原型声明,main中则不用
int m( int x, int y )
{ float a ( int x );----------原型声明
….
c=a( k ) ;
}
float a ( int x)
{….}
main( )
{-----------------无需原型声明
…. 32、
c=a( t ) ;
}
1、求1+2+3+……….+100。(循环)
答案
#include 33、输出他们的最大值。(if)
答案
#include 34、
答案
#include 35、
main()
{int a[10],i=0;
for(i=0;i<=9;i++)
scanf("%f",&a);
printf("\n");
for(i=9;i>=0;i--)
printf("%f",a);
}
6输入两个数,交换他们的值并输出。(元素交换)
答案
#include 36、}
7.输出9*9乘法表。(双层循环)
答案
#include 37、a[n];
int i;
scanf("%s",a);
printf("大写为:");
for(i=0;i<=n;i++)
{
if(a<='z'&&a>='a')
a=a-32;
printf("%c",a);
}
printf("\n小写为:");
for(i=0;i<=3;i++)
{
a=a+32;
printf("%c",a);
}
}
9、 编写一个简单计算器程序,要求能够完成两个数的+,-,*,/四 38、种运算。输出运算式及运算结果。(switch)
6.2
#include"stdio.h"
main()
{char c;int i=0,j=0,k=0,l=0;
while((c=getchar())!=’\n’)
{if(c>=65&&c<=90||c>=97&&c<=122) i++;
else if(c>=48&&c<=57) j++;
else if(c==32) k++;
else l++;}
printf("i=%d,j=%d,k=%d,l=%d\n",i,j,k,l);
}
6.6
#include"math.h"
main()
{int x=10 39、0,a,b,c;
while(x>=100&&x<1000) {a=0.01*x;b=10*(0.01*x-a);c=x-100*a-10*b;
if(x==(pow(a,3)+pow(b,3)+pow(c,3))) printf("%5d",x);x++;}
}
6.7
main()
{int m,i,j,s;
for(m=6;m<10000;m++)
{s=1;
for(i=2;i 40、j==0)
printf("%d ",j);printf("\n");}
}
}
或
main()
{int m,i,j,s;
for(m=6;m<1000;m++)
{s=m-1;
for(i=2;i 41、
scanf("%ld",&n);
while(i<=n) {s=y/x;sum=sum+s;t=y;y=y+x;x=t;i++;}
printf("%f\n",sum);
}
11,P128 例6.10(译码)
#include 42、include 43、x,y);
}
}
5.6
#include 44、 7: grade=’C’;break;
case 6: grade=’D’;break;
case 5:
case 4:
case 3:
case 1:
case 0: grade=’E’;
}
printf("成绩是%5.1f,相应的等级是%c。\n",score,grade);
}
13,P108 例5.5(一元二次方程求根) 例5.6(求闰年)
5.5
#include 45、0)
{
if(year%400==0)
leap=1;
else
leap=0;
}
else
leap=1;
}
else
leap=0;
if(leap)
printf("%d is",year);
else
printf("%d is not",year);
printf("a leap year.\n")
}
5.6
14,P31 例2.17 例2.18
2.17
输出50个学生中成绩高于80分者的学号和成绩
2.18
输出2000——2500年每一年是否闰年
#include 46、)
{
int year;
year=2000;
go: if(((year%4 == 0)&&(year%100 != 0)) || (year%400 == 0))
printf("%d is run nian",year);
if(year<=2500)
year=year++;
if(year>2500)
goto end;
goto go;
end: 47、 getch();
}
scanf....
s=0;
for(i=1;i<=n;i++)
{ y=1;
for(j=1;j<=i;j++)
y=y*j;
s=s+y;
}
printf...
1*(1+2)*(1+2+3)*.....(1+...n)
1!+2!+3!...+n!
s=0;y=1;
for(i=1;i<=n;i++)
{y=y*i; 1!--2!---3!...
s=s+y; 0+1!+2!+3!...
48、 }
//分解质因数
#include 49、g=0;h=0;
printf("请输入数值(3000<=x<=10000):");
scanf("%d",&x);
for(c=1;c<=x-1;c++)
if(x%c==0)
for(i=2;i<=x/2;i++)
b[i]=c;
{if(b[i]<=100)
d++;}
{if(b[i]>100&&b[i]<=300)
e++;}
{if(b[i]>=301&&b[i]<=500)
f++;}
{if(b[i]>=501&&b[i]<=1000)
g++;}
{if(b[i]>=1001&&b[i]<=x/2)
h++;}
printf("%d %d 50、d %d %d",d,e,f,g,h);
}
//p1_1
#include






