c语言基础知识题库?c语言题目及答案
大家好,今天给各位分享c语言基础知识题库的一些知识,其中也会对c语言题目及答案进行解释,文章篇幅可能偏长,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在就马上开始吧!
C语言题库,求发一份
单选题
1.以下叙述中正确的是(1)。
A.若e1、e2为变量,e为表达式,则
e1=e2=e使得e1、e2都具有表达式e的值。
B.程序中不能定义与库函数名同名的变量。
C.一个C源程序可放在多个文件中,但
一个函数不能跨放在两个不同的文件中。
D.C语言编译系统以函数为单位编译源程序。
2.若a,b,c都是实型变量,则下列语句中除(2)之外,都可能得不到正确的计算结果。
A.if(b*b-4*a*c==0) x1=x2=-b/(2*a);
else x1=(-b+sqrt(b*b-4*a*c))/(2*a), x2=(-b-sqrt(b*b-4*a*c))/(2*a);
B.b=2.0e38+1.0-2.0e38;
C.a=456*768/2;
D.double define=1.0;
3.以下正确的常量是(3)。
A.‘077’ B.‘\0x89’ C.3.14u D.‘\012’
4.若已有声明“float x=-1234.5678; int m,n=4;”则执行“m=printf(“\n%8.3f\n”,x)/n;”语句后,
变量m的值是(4)。
A. 2 B. 3 C. 4 D. 5
5.若已有声明“int x1; float x2; long x3; char x4;”,且以下选项均出现在switch语句中,其中正确
的是(5)。
A. case 1.1: scanf("%d",&x1);break;
B. case 1+2: scanf("%f",&x2); break;
C. case'x':
case'y'-1: scanf("%ld",&x3); break;
D. case x4: scanf("%c",&x4); break;
6. 33.以下表达式中,能够作为“if(e)语句”中判断条件表达式e的是(6)。
A. x==++(x+1) B. x+=++x||x++ C. x+1=z D. x%2.0!=0
7.以下局部变量声明中,正确的是(7)。
A.int x=0, void=1; B.int x=1,y=2x;
C.int x=2,y=sqrt(x); D.int x=sqrt(y),y=4;
8.在以下语句中,正确的是(8)。
A.if(a>b)m=a;n=b;else m=b;n=a;
B.if(a>b){m=a;n=b;else m=b;n=a;}
C.if(a>b)m=a,n=b;else m=b,n=a;
D.if(a>b){m=a;n=b;}else(a<=b){m=b;n=a;}
9.24.已知有声明:“char c=‘1’; int x=300; float t=35000; double d=3.1234567e10;”,则以下表达式
求值时除(9)外,其结果都可能是不准确的。
A.x=t/c B.t=d/x C.t=d/1e5f D. t=x+c
10.若有声明“int i,k=1; unsigned j;”,则下列语句执行时会出现无限循环的语句
是(10)。
A.for(j=15;j>0;j-=2) k++;
B.for(j=0;j<15;j+=2) k++;
C.for(i=0;i<15;i+=2) k++;
D.for(i=15;i>0;i-=2) k++;
11.已有声明“int x=2,y=1,z=0;”,以下表达式的值不为0的是(11)。
A. x==(x=0,y=1,z=2)
B. z>y>x
C. x>y==1
D. x>(y=2)
12.若e1、e2和e3是表达式,以下选项中与语句while(e1){e2,e3;}功能等价的语句是(12)。
A. for(;e1;e3)e2; B. for(;e1;e2)e3; C. for(e1;e2;e3); D. for(e1; e2, e3;);
13.已有声明“int x=3;”,以下选项中与“x+=x=x+1”功能不等价的表达式是(13)。
A.x=x+(x=xx+1) B.x=x+(x=x(x+1)) C.x=x+(x=xx1) D.x=x(x+1), x=x+x
14.若已有声明“int a=2;”,则执行语句“printf("%d", a, a+1);”后的输出结果是(14)。
A.语法错 B. 2,3 C. 2 D. 3
15.语句“if(!n) n++;”中的“!n”等价于如下(15)条件的判定。
A.n==0 B.n!=0 C.n>0 D.n<0
16.若已有声明“int a=1;”,则以下表达式中错误的是(16)。
A.-a++ B.+a-- C.--a D.++-a
17.下列(17) C语言表达式能正确表达数学计算式1÷× 2xy。
A. 1/sqrt(2*3.14)*2*pow(x,y) B.1.0/sqrt(2)*2*x**y
C. 1.0/sqrt(6.28)*2x^y D.1/6.28^0.5*2*pow(x,y)
18.已有声明“int a=3,b=3,c=2;”,以下表达式中值为0的是(18)。
A.!a&&!b&&c B.!a||!b|| c C. a==b&&b>=c D. a>=b&&b>c
19.
36.若有: int w=1, x=2, y=3, z=4;则表达式 w>x?x--:y<z?y--:++z的值为(19)。
A. 4 B. 3 C. 2 D. 1
20.已知某程序中有以下片断:
#define p 2.5
main()
{ float x=p;
}
则main函数中标识符p代表一个(20)。
A. float型变量 B. double型变量 C. float型常量D.double型常量
20.
填空题
1.21.设有如下程序段:
int a=2, b, c=5;
scanf(“%d”,&b);
b= c--|| scanf(“%d”,&c)&& a++;
执行该程序段时,若从键盘上输入的数据是 4ƀ3(ƀ代表空格键),则变量c的值为(21)。
2. signed和unsigned只能用于声明int型变量和(22)型变量。
3.代数式“||”的C语言表达式是(23)。
4.已有声明“int a=-13,n=7;”,表达式“a%=n%=4”求值后变量a的值为(24)。
5.已有声明“unsigned int a=30;”,那么–a的值为___(25)____。
6.
如下程序执行后的输出是____(26)____。
#include<stdio.h>
main()
{
int i=1,m=0;
switch( i)
{
case 1:
case 2: m++;
case 3: m++;
}
printf(“%d”,m);
}
7.C语言的三个逻辑运算符(!、&&、||)中,优先级高于算术运算符的是
(27)。
8.已知sizeof(int)的值为2,执行如下程序后输出结果为(28)。
main()
{ int a,b;
a=65536;
b=32767+1;
printf("%d%d\n",a,b);
}
9.若有声明“int a=3,b=0,c=5;”,则表达式!a+b+c-1&&b+c/2的值是(29)。
10.若有声明“int x=1,y=2;”,则表达式++x, x+y++的值是(30)。
三、阅读程序题
1.在PC机的TC中执行以下程序后的输出是:(31)。
main()
{
unsigned x=0x7f39;
int y;
char c;
c=x;
x+=0307;
y=x;
printf(“%d,%x,%c”,x,y,c);
}
2.以下程序运行后的输出结果是(32)。
#include<stdio.h>
main()
{ int x=30, y=45;
while(x!=y)
if(x>y)x-=y;
else y-=x;
printf("%d", x);
}
3.
以下程序运行后输出结果的第一行是(33),第二行是(34)。
#include<stdio.h>
#include<math.h>
void main()
{ int a=0x65,b,c,count=0;
b=a;
while(b>0)
{ b=b/8;
count++;
}
printf("%d\n",count);
while(count>0)
{ c=pow(8,count-1);
printf("%d",a/c);
a=a%c;
count--;
}
}
4.以下程序运行时输出结果是(35)。
#include<stdio.h>
main()
{
int i,x=3,y=5;
for(i=0;i<3;i++)
switch(y%x)
{
case 0: printf("%d",y);
case 1: printf("%d",y--);break;
case 2: printf("%d",--y);break;
}
}
5.以下程序执行后,输出结果的第一行是(36),第二行是 _(37)______。
#define N 100
main()
{ int i=0,sum=0;
do
{ if(i==(i/2)*2)
continue;
sum++;
if(sum>3)
break;
}while(++i<N);
printf("%d\n%d", sum,i);
}
四、完善程序题
1.下列程序的功能是按从键盘上输入的整数m,判断2m-1是否为素数,若为素数再求2m-1的反序数。例如:m为17,217–1(131071)是素数,其反序数是170131。
#include<stdio.h>
(38)
main()
{
int m,j;
long q,k1,k2=0,k3;
scanf("%d",&m);
k3=k1=pow(2,m)-1;
q=sqrt(k1);
for(j=2;j<=q;j++)
if((39)) break;
if(j>q)
{ while(k3>0)
{ k2=k2*10+(40);
k3/=10;
}
printf("m=%d\npow(2,m)-1=%ld is a prime.\nreverse order%ld\n",m,k1,k2);
}
else
printf("m=%d isn't a prime.\n",m);
}
2.以下程序找到并输出所有满足给定条件的四位十进制表示的正整数:该数是某个数的平方、该数的后二位是25、组成该整数的各位数字中有两位是2。例如:1225是满足所给条件的四位正整数(352=1225)。
#include<stdio.h>
#include<math.h>
main()
{ long i,j,s,d=0;
for(i=1000;i<10000;i++)
{(41);
j=(42);
if(i==j*j&& i%100==25)
{ s=i;
while(s>0)
{ if((43))d++;
s=s/10;
}
if(d==2) printf("\n%d",i);
}
}
}
3..下列程序计算下列数学函数展开式的近似值,累加运算在最后一项的绝对值小于10-6时停止。
程序运行时从键盘上分别三个实数-1.0、0.5、1.0,作为x的值。
#include<stdio.h>
#include<math.h>
#define EPS 1.0e-6
main()
{ double x,n,tn,ft,sn,xn;
int i;
for(i=0;i<3;i++)
{(44);
ft=1.0;
scanf("%lf",&x);
sn=xn=x;
do{
xn=xn*x*x;
ft=ft*(2*n-3)/(2*n-2);
tn=ft*xn/(45);
sn=sn+tn;
n=n+1;
}while((46));
printf("f(%lf)=%0.6lf\n",x,sn);
}
}
《C语言程序设计》试卷答题纸
(本试卷满分100分)
系科_____________学号_____________姓名_____________成绩____________
单项选择题得分填空题得分阅读程序题得分完善程序题得分总分
一、单项选择题
(1)(2)(3)(4)(5)
(6)(7)(8)(9)(10)
(11)(12)(13)(14)(15)
(16)(17)(18)(19)(20)
二、填空题
(21)(22)
(23)(24)
(25)(26)
(27)(28)
(29)(30)
三、阅读程序题
(31)(32)
(33)(34)
(35)(36)
(37
四、完善程序题
(38)(39)
(40)(41)
(42)(43)
(44)(45)
(46)
《C语言程序设计》试卷参考答案
(本试卷满分100分)
一、单项选择题
(1)C(2)D(3)D(4)A(5) B
(6)B(7)C(8)C(9)D(10)A
(11)C(12)A(13)A(14)C(15)A
(16)D(17)A(18)A(19)B(20)D
二、填空题
(21) 4(22) char
(23) fabs(exp(sqrt(1+sin(x))))(24)-1
(25) 65506(26) 2
(27)!(28) 0-32768
(29) 1(30) 4
三、阅读程序题
(31)-32768, 8000, 9(32) 15
(33) 3(34) 145
(35) 4433(36) 4
(37) 7
四、完善程序题
(38)#include<math.h>(39) k1%j==0
(40) k3%10(41) d=0
(42) sqrt(i)(43) s%10==2
(44) n=2.0(45)(2*n-1)
(46) fabs(tn)>EPS
谁帮我整理一些C语言的基础知识,谢谢!!
C语言基础知识
1.1 C语言简介
C语言于1972年由美国的Dennis Ritchie发明,并首次在配备了UNIX操作系统的DEC PDP-11计算机上实现。它由早期的编程语言BCPL(Basic Combind Programming Language)发展演变而来。1970年,AT&T贝尔实验室的Ken Thompson根据BCPL语言设计出了较先进并取名为B的语言,通过不断修改、完善,更先进的C语言问世了。
C语言是一种功能强大、应用广泛、具有发展前途的计算机语言。它既可用于系统软件的设计,也可用于应用软件的开发。许多著名的系统软件都是由C语言编写的。C语言具有下列特点:
(1)C语言既具有低级语言直接操纵硬件的特点,又具有高级语言与自然语言和人的思维逻辑相似的特点,C语言程序易编写、易查错,而且实用性很强。
(2)C语言具有丰富的数据类型和运算符,语法结构简单。
(3)C语言是一种结构化程序设计语言,提供了完整的程序控制语句。
(4)C语言是一种模块化程序设计语言,适合大型软件的开发和研制。
(5)C语言还有一个突出的优点就是适合于多种操作系统,如DOS、UNIX,也适用于多种机型,其程序移植性好。
1.2 C语言的数据类型
数据是程序处理的对象,数据类型是数据的内在表现形式。例如,学生的年龄和成绩具有一般数值的特点,在C语言中称为数值型,其中年龄是整数,称为整型;成绩可以为小数,称为实型。而学生的姓名和性别是文字,在C语言中称为字符型数据。
C语言具有丰富的数据类型,其中基本的数据类型有整型、实型、字符型。
1.2.1变量
变量是在程序执行过程中其值可以被改变的量。
1.变量命名规则
和人的取名一样,变量的命名也有一定的规则。
(1)由字母、数字和下划线组成;
(2)必须以字母或下划线打头;
(3)字母区分大小写(在系统默认状态下);
(4)前32个字符有效(在系统默认状态下)。
例如:a,Book,book,_Make_Cipher都是合法的变量名,且Book与book是不同的变量名,而123A,x+y都不是变量名。
2.变量的数据类型
变量可以是任意的一种数据类型,如整型变量、字符型变量、指针变量等。C语言中的基本数据类型及其特性如表1-1所示。
表1-1 C语言的基本数据类型
数据类型名数据类型描述数据类型的长度(字节)数据取值范围
char字符型 1 0~255
int有符号整型 2–32 768~32 767
unsigned int无符号整型 2 0~65 535
short短整型 2–32 768~32 767
long长整型 4–2 147 483 648~2 147 483 647
unsigned long无符号长整型 4 0~4 294 967 295
float单精度实数 4|3.4×10–38|~|3.4×1038|
double双精度实数 8|1.7×10–308|~|1.7×10308|
long double长双精度实数 10|3.4×10–4932|~|3.4×104932|
3.变量的定义
每个变量在使用前都必须先定义其数据类型,定义变量数据类型的语法格式如下:
数据类型符变量名1,变量名2,…;
例如:
int age,score;/*定义年龄和成绩为整型*/
char name[20];/*定义姓名为至多含20个字符的字符数组*/
4.变量的存储类型
当定义某个变量时,C语言的编译系统就要给该变量分配若干个存储单元用来存放该变量的值。而在计算机中寄存器和内存都可以存放数据,内存又可分为临时占用和长期占用。变量的存储类型是指变量在计算机中的存放位置及时间。
定义变量存储类型的语法格式如下:
存储类型符数据类型符变量名1,变量名2,…;
变量的存储类型有自动型(auto)、寄存器型(register)、静态型(static)和外部型(extern),具体特点和使用方法在后面的章节中详细介绍。
在变量定义时,如未说明存储类型,则系统默认为自动型(auto)。
5.变量的初始化
变量的初始化是给变量赋初值的一种方法,是指在变量定义时就给变量赋予初始值。变量初始化的方法很简单,在变量定义的语句中,在变量名后加一个等号和初值即可。
例如:
int x, age=20, score=100;
在上面的定义中,变量x未赋初值,而变量age和score的初值分别为20和100。
在程序中,变量未赋值之前不允许使用,即要遵循“先赋值后使用”的规则。
1.2.2常量
常量是在程序运行过程中值不发生改变的数据。例如,圆周率3.1415926就是一个常量。常量也有数据类型,它们是整型常量、实型常量、字符常量、字符串常量及符号常量,整型常量及实型常量的数据长度及取值范围与变量的规定相同。
1.整型常量
整型常量用来表示整数,整型数据可以以不同数制形式来表示,不同的进位制有其不同的表示方式,其表示方式如表1-2所示。
表1-2整型常量的表示方式
数制表示方式示例
十进制一般整数的写法 0,–22,55
八进制在八进制整数前加数字0 00,–072,+0331
十六进制在十六进制整数前加数字0和字母x 0x0,0x1B5,–0xb3
另外,对于长整型常量,应当在其后加后缀L或l,例如30L。30L和30数值一样,但占用内存的大小不一样。30占用2个字节的存储空间,而30L占用4个字节的存储空间。
2.实型常量
实型常量只有十进制数表示方式,它没有单精度和双精度之分。其表示方式有定点数表示和浮点数表示两种。具体表示方式如表1-3所示。
表1-3实型常量的书写方法
类别表示方式示例
定点数整数部分.小数部分 0.0,1.34,–34.0
浮点数尾数E(或e)指数 3.57E10,–5.6e–9
说明:
(1)浮点数表示方式相当于数学中的科学计数法,其换算公式如下:
尾数E(或e)指数=尾数×10指数
(2)浮点数中的指数部分只能是整型数,尾数可以大于或等于10。
3.字符常量
字符常量是用两个单引号引住单个字符来表示的。例如:'A'、'*'、'!'等。使用字符常量时应注意以下几点:
(1)空格也是字符,表示为'a'。
(2)单引号中必须恰好有一个字符,不能空缺。如''是错误的字符常量。
在C语言中有一类特殊的字符常量,被称为转义字符。它们用来表示特殊符号或键盘上的控制代码,常见的转义字符如表1-4所示。
表1-4常用转义字符表
转义字符意义转义字符意义
\n回车换行符\a响铃
\t水平制表符\"双引号
\v垂直制表符\'单引号
\b左退一格\\反斜杠
\r回车符\ddd 1~3位八进制数ddd对应的字符
\f换页符\xhh 1~2位十六进制数hh对应的字符
4.字符串常量
字符串是用双引号引住的若干个字符。例如,"hello!","485769","a"。
字符串可以不含任何字符,称为空串,表示为""。
字符串中所含的字符个数称为字符串的长度。例如,"abc123","3",""的长度分别为6,1,0。计算字符串长度时应注意以下几点:
(1)对于含有转义字符的字符串,应将转义字符计算为1个字符。例如,"abc\\12\n"的长度为7,而不是9;"abc\\\12\n"及"abc\\\123\n"的长度均为6。
(2)在字符串中,反斜杠表示转义字符的开始,如果其后面没有表1-4中所列出的转义符号,则该反斜杠被忽略,并不参与计算长度。例如,"\A"的长度为1,但"\"是非法的。
5.符号常量
上面所介绍的常量都是具体数据,在程序中也可以用特定符号来表示某个常量,这个符号被称为符号常量。
符号常量的语法格式如下:
#define符号常量名常量
例如:
#define PI 3.1415926
经过上述定义后,可以在程序中使用PI来代替3.1415926。
在程序中使用符号常量有两个好处:一是提高了程序的易读性;二是为修改程序提供了方便。例如,当不需要太高精度时,只需要将符号常量定义修改为
#define PI 3.14
而不需要在程序中去修改每一处的圆周率。
1.3算术运算符与算术表达式
用来表示各种运算的符号称为运算符。C语言中包括以下七大类的基本运算符:算术运算符、逻辑运算符、关系运算符、赋值运算符、逗号运算符、条件运算符和位运算符。本节主要介绍算术运算符,其他的运算符将在后续章节中详细介绍。
1.3.1算术运算符
C语言中的算术运算符和数学中的算术运算相似,是对数据进行算术运算的。算术运算符的运算对象、运算规则及结合性如表1-5所示。
表1-5算术运算符
运算对象个数名称运算符运算规则运算对象
数据类型结合性
单目正+取原值整型或实型自右向左
负–取负值
双目加+加法运算自左向右
减–减法运算
乘*乘法运算
除/除法运算
模%整除取余整型
单目增1(前缀)++先加1,后使用整型、字符型、指针型变量或数组元素、实型自右向左
增1(后缀)++先使用,后加1
减1(前缀)––先减1,后使用
减1(后缀)––先使用,后减1
在C语言中,参加运算的对象个数称为运算符的“目”。单目运算符是指参加运算的对象只有一个,如+10,–67,x++。双目运算符是指参加运算的对象有两个,如2+3,7%3。
相同运算符连续出现时,有的运算符是从左至右进行运算,有的运算符是从右至左进行运算,C语言中,将运算符的这种特性称为结合性。
加法(+)、减法(–)、乘法(*)与数学中的算术运算相同。例如:3.5+4.7结果是8.2;3.5– 4.7结果是–0.8;3.5*4.7结果是16.45。
除法运算(/)与数学中的除法不完全相同,它与参加运算的对象的数据类型相关。当参加运算的两个对象均为整型数据时,其运算结果为数学运算结果的整数部分。如7/4结果为1,而不是1.75。若参加运算的两个对象有一个是实型或两个都是实型,那么运算结果为实际运算的值,如7/5.0的运算结果为1.4。
模运算的运算对象必须为整型,结果是相除后的余数,如7%5结果为2。
增1减1运算符都是单目运算符,用来对整型、实型、字符型、指针型变量或数组元素等变量进行加1或减1运算,运算的结果仍是原类型。
1.3.2常用数学函数
C语言系统提供了400多个标准函数(称为库函数),设计程序时可以直接使用它们。库函数主要包括数学函数、字符处理函数、类型转换函数、文件管理函数及内存管理函数等几类。下面介绍常用的数学函数,其他类型的函数将在后面章节中陆续介绍。
1.函数名:abs
原型:int abs(int i);
功能:求整数的绝对值。
例如,设x=abs(5),y=abs(–5),z=abs(0),则x=5,y=5,z=0。
2.函数名:labs
原型:long labs(long n);
功能:求长整型数的绝对值。
例如,设x=labs(40000L),y=labs(–5),z=labs(0),则x=40000,y=5,z=0。
3.函数名:fabs
原型:double fabs(double x);
功能:求实数的绝对值。
例如,设x=fabs(5.3),y=fabs(–5.3),z=fabs(0),则x=5.3,y=5.3,z=0。
4.函数名:floor
原型:double floor(double x);
功能:求不大于x的最大整数,它相当于数学函数[x]。
例如,设x=floor(–5.1),y=floor(5.9),z=floor(5),则x=–6,y=5,z=5。
5.函数名:ceil
原型:double ceil(double x);
功能:求不小于x的最小整数。
例如,设x=ceil(–5.9),y=ceil(5.1),z=ceil(5),则x=–5,y=6,z=5
6.函数名:sqrt
原型:double sqrt(double x);
功能:求x的平方根。
例如,设x=sqrt(4),y=sqrt(16),则x=1.414214,y=4.0
7.函数名:log10
原型:double log10(double x);
功能:求x的常用对数。
8.函数名:log
原型:double log(double x);
功能:求x的自然对数。
9.函数名:exp
原型:double exp(double x);
功能:求欧拉常数e的x次方。
10.函数名:pow10
原型:double pow10(int p);
功能:求10的p次方。
例如,设x=pow10(3),y=pow10(0),则x=1000,y=1
11.函数名:pow
原型:double pow(double x, double y);
功能:求x的y次方。
例如,设x=pow(3,2),y=pow(–3,2),则x=9,y=9
12.函数名:sin
原型:double sin(double x);
功能:正弦函数。
13.函数名:cos
原型:double cos(double x);
功能:余弦函数。
14.函数名:tan
原型:double tan(double x);
功能:正切函数。
1.3.3算术表达式
由算术运算符和运算对象连接形成的式子称为算术表达式。
算术运算符的优先级从高到低规定如下:
++––
*/%
+–
位于同一行的运算符的优先级相同。
1.4数据类型转换规则
对数据进行运算时,要求参与运算的对象的数据类型相同(运算得到的运算结果的类型与运算对象也相同)。因此,在运算过程中常常需要对变量或常量的数据类型进行转换,转换的方法有两种,一种是系统自动转换(又称为隐式转换);另一种是在程序中强制转换(又称为显式转换)。
1.4.1自动转换规则
在不同类型数据的混合运算中,由系统自动实现转换。转换规则如下:
(1)若参与运算的数据的类型不同,则应先转换成同一类型,然后进行运算。
(2)将低类型数据转换成高类型数据后进行运算。如int型和long型运算时,先把int型转换成long型后再进行运算。
类型的高低是根据其所占空间的字节数按从小到大的顺序排列的,顺序如下:
char,int,long,float,double。
(3)所有的浮点运算都是按照双精度进行运算的,即使仅含float型单精度量运算的表达式,也要先转换成double型,再作运算。
(4)char型和short型参与运算时,必须先转换成int型。
例如,设有:
float PI=3.14;
int s,r=7;
s=r*r*PI;
因为PI为单精度型,s和r为整型,在执行s=r*r*PI语句时,r和PI都转换成double型后再进行计算,运算结果也为double型,右边的运算结果为153.86,但由于s为整型,故应将赋值号右边的运算结果转换成整型(舍去小数部分),因此s的值为153。
1.4.2强制类型转换
强制类型转换是通过类型转换运算来实现的,其语法格式如下:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。例如:(float) a把a转换为实型;(int)(x+y)把x+y的结果转换为整型;而(int)x+y则只将x转换为整型。
在使用强制类型转换时应注意以下问题:
(1)类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则只是把x转换成int型之后再与y相加。
(2)对于被转换的单个变量而言,无论是强制转换还是自动转换,都只是为了本次运算的需要而对变量的数据长度进行临时性转换,而不会改变变量定义时所声明的类型。
例如,设有:
float f=–5.75;
int x;
x=(int)f;
将f强制转换成整数–5,因此x=–5,而f本身的类型并未改变且其值仍为–5.75。
1.5程序结构
1.5.1主函数结构
每一个C源程序都是一系列函数的集合。其中,必须有且只能有一个主函数,其函数名为main,其结构如下:
void main(void)
{
…
}
其中,void main(void)称为函数说明部分(又称函数头),而
{
…
}
称为函数体,函数体中的每个语句行末尾都必须用分号结束。
1.5.2文件包含命令
C语言系统提供了400多个库函数,并将这些函数根据其功能分成了若干组,每组都有一个组名。如数学类函数组的组名为math。在C语言系统所安装文件夹的下级文件夹中有一个与其相对应的文件math.h,这些扩展名为.h的文件称为头文件。
include称为文件包含命令,当用户在程序中使用到系统的标准库函数中的函数时,需要在程序中(一般在程序的首部)增加一条预处理语句如#include<stdio.h>,以便告知系统需要使用某个头文件中的函数。
1.5.3 C语言程序基本结构
一个完整的C语言源程序由如下5个部分构成:
(1)预处理命令;
(2)全局变量说明;
(3)函数原型说明;
(4)主函数;
(5)其他子函数。
一个简单的C语言源程序只需要(1)和(4)两个部分,其中“预处理命令”一般是一系列文件包含命令,即include命令。
关于程序结构,应当注意以下几方面的问题:
(1)可由若干个函数构成,其中必须有且只有一个以main命名的主函数,可以没有其他函数。每个函数完成一定的功能,函数与函数之间可以通过参数传递信息。main()函数可以位于原程序文件中任何位置,但程序的执行总是从main函数开始,main函数执行完毕时程序执行结束。
(2)子函数的结构与主函数相同,即分为函数说明部分和函数体两个部分。
(3)函数中的每个语句最后要有一个分号,作为语句结束标记。但某些特殊的语句行末尾不需要分号,有时还不能有分号。
(4)“/*”和“*/”括住的任意一段字符称为“程序注释”,用来对程序作说明,可以插入到程序的任何地方,且可以跨行使用。程序注释不影响程序运行结果。
(5)函数的书写格式很灵活,在一行中可以书写多个语句(每个语句末尾都要有分号),一个语句也可以写在多行中。在程序的任何地方都可以插入空格或回车符。
(6)主函数可以调用任何子函数但不能调用它自己,任何子函数之间也可以相互调用,但是子函数不能调用主函数。
下面是一个简单的C语言源程序:
【例1-1】求圆的面积。
#include<stdio.h>
void main(void)
{
float r,s,p=3.14;
r=10.5;
s=r*r*p;
printf("圆的面积是:%f",s);
}
下面是一个较完整的C语言源程序:
【例1-2】较完整的C语言程序示例。
#include<stdio.h>
#include<conio.h>
int y,z;
void abc(int x);
void main(void)
{
int x;
clrscr();
x=10;
y=20;
z=30;
printf("ok1: x=%d y=%d z=%d\n",x,y,z);
abc(x);
printf("ok2: x=%d y=%d z=%d\n",x,y,z);
getch();
}
void abc(int x)
{
int y;
printf("ok3: x=%d y=%d z=%d\n",x,y,z);
x=100;
y=200;
z=300;
printf("ok4: x=%d y=%d z=%d\n",x,y,z);
}
C语言的知识有什么
C语言重要知识点记得背会
总体上必须清楚的:
1.程序结构是三种:顺序结构、选择结构(分支结构)、循环结构。
2.读程序都要从main()入口,然后从最上面顺序往下读(碰到循环做循环,碰到选择做选择),有且只有一个main函数。3)计算机的数据在电脑中保存是以二进制的形式。数据存放的位置就是他的地址.4)bit是位是指为0或者1。 byte是指字节,一个字节八个位,
概念常考到的:
1、编译预处理不是C语言的一部分,不占运行时间,不要加分号。C语言编译的程序称为源程序,它以ASCII数值存放在文本文件中。
2、define PI 3.1415926;这个写法是错误的,一定不能出现分号。
3、每个C语言程序中main函数是有且只有一个。
4、在函数中不可以再定义函数。
5、算法:可以没有输入,但是一定要有输出。
6、break可用于循环结构和switch语句。
7、逗号运算符的级别最低,赋值的级别倒数第二。
概念常考到的:
1、编译预处理不是C语言的一部分,不占运行时间不要加分号。C语言编译的程序称为源程序,它以ASCII数值存放在文本文件中。
2、define PI 3.1415926;这个写法是错误的,一定不能出现分号。
3、每个C语言程序中main函数是有且只有一个,
4、在函数中不可以再定义函数。
5、算法:可以没有输入,但是一定要有输出。
6、break可用于循环结构和switch语句。
7、逗号运算符的级别最低,赋值的级别倒数第二
第一节、对C语言的基础认识
1、C语言编写的程序称为源程序,又称为编译单位。
2、C语言书写格式是自由的,每行可以写多个语句,可以写多行。
3、一个C语言程序有且只有一个main函数,是程序运行的起点。
第二节、熟悉vc++
1、VC是软件,用来运行写的C语言程序。
2、每个C语言程序写完后,都是先编译,后链接,最后运行。(.c---a.obj---a.exe)这个过程中注意.c和obj文件时无法运行的,只有.exe文件才可以运行。(常考!)
第三节、标识符
1、标识符(必考内容):
合法的要求是由字母,数字,下划线组成。有其它元素就错了。
并且第一个必须为字母或则是下划线。第一个为数字就错了
2、标识符分为关键字、预定义标识符、用户标识符关键字:不可以作为用户标识符号。main definescanf printf都不是关键字。迷惑你的地方If是可以做为用户标识符。因为if中的第一个字母大写了,所以不是关键字。
预定义标识符:背诵define scanf printf include。
记住预定义标识符可以做为用户标识符。
用户标识符:基本上每年都考,详细请见书上习题。
第四节:进制的转换
十进制转换成二进制、八进制、十六进制。
二进制、八进制、十六进制转换成十进制。
第五节:整数与实数
1.C语言只有八、十、十六进制,没有二进制。但是运行时候,所有的进制都要转换成二进制来进行处理。(考过两次)
a、C语言中的八进制规定要以0开头。018的数值是非法的,八进制是没有8的,逢8进1。
b、C语言中的十六进制规定要以Ox开头。
2.小数的合法写法: C语言小数点两边有一个是零的话,可以不用写。
1.0在C语言中可写成1
0.1在C语言中可以写成.1。
3.实型数据的合法形式:a、2.333e-1就是合法的,且数据是2.333x10-1。b、考试口诀: e前e后必有数,e后必为整数。请结合书上的例子。
4.整型一般是4个字节,字符型是1个字节,双精度一般是8个字节:
long int x;表示x是长整型。
unsigned int x;表示x是无符号整型。
第六、七节:算术表达式和赋值表达式
核心:表达式一定有数值!
1、算术表达式:+,-,*,1,%考试一定要注意:“/”两边都是整型的话,结果就是个整型。 3/2的结果就是1.
“/”如果有一边是小数,那么结果就是小数。 312.0的结果就是0.5
“%”符号请一定要注意是余数,考试最容易算成了除号。)%符号两边要求是整数。不是整数就错了。[注意!!!]
2、赋值表达式:表达式数值是最左边的数值,a=b=5:该表达式为5,常量不可以赋值。
1、int x=y=10:错啦,定义时,不可以连续赋值。
2、int x,y;
x=y=10;对滴,定义完成后,可以连续赋值。
3、赋值的左边只能是一个变量。
4、int x=7.7;对滴,x就是7
5、float y=7;对滴,x就是7.0
3、复合的赋值表达式
int a=2;a*=2+3;运行完成后,a的值是12。一定要注意,首先要在2+3的上面打上括号。变成(2+3)再运算。
4、自加表达式:
自加、自减表达式:假设a=5,++a(是为6), a++(为5);
运行的机理:++a是先把变量的数值加上1,然后把得到的数值放到变量a中,然后再用这个++a表达式的数值为6,而a++是先用该表达式的数值为5,然后再把a的数值加上1为6
再放到变量a中。进行了++a和a++后在下面的程序中再用到a的话都是变量a中的6了。考试口诀:++在前先加后用,++在后先用后加。
5、逗号表达式:
优先级别最低。表达式的数值逗号最右边的那个表达式的数值。
(2,3,4)的表达式的数值就是4。z=(2,3,4)(整个是赋值表达式)这个时候z的值为4。(有点难度哦!)z= 2,3,4(整个是逗号表达式)这个时候z的值为20
补充:
1、空语句不可以随意执行,会导致逻辑错误。
2、注释是最近几年考试的重点,注释不是C语言,不占运行时间,没有分号。不可以嵌套!
3、强制类型转换;一定是(int)a不是 int(a),注意类型上一定有括号的。
注意(int)(a+b)和(int)atb的区别。前是把a+b转型,后是把a转型再加b。
关于c语言基础知识题库的内容到此结束,希望对大家有所帮助。