1. c语言中输出printf(“%%%%”)
输出8个字符宽度的空间, 就相当于你在编程的时候按一下“Table”键,使光标以8个字符为基准进行跳跃,跳到下一个TAB位置。
它们在双引号或定界符表示的字符串中有效,在单引号表示的字符串中无效。 表示键盘上的“TAB”键。
,是一种计算机语言,意思是让所有的数据都紧跟在制表符后面。换码符' ',表示水平制表位(horizontal tab),它的作用是将光标移到最接近8的倍数的位置,使得后面的输入从此开始。换句话说,让所有的数据都紧跟在制表符后面输出。
(1)c语言定界符号成对出现扩展阅读:
转义字符作用
1、使用转义字符来表示字符集中定义的字符,比如ASCll里面的控制字符及回车换行等字符,这些字符都没有现成的文字代号。所以只能用转义字符来表示 。
2、某一些特定的字符在编辑语言中被定义为特殊用途的字符。这些字符由于被定义为特殊用途,它们失去了原有的意义。比如说Html中,<被HTML定义为标签的开始,所以当我们转入<时,HTML就会把它当作为开始,而不是当作一个<来看待。
网络-
2. c语言中成对的括号该怎么打
这是习惯问题
一般是先成对的输入匹配的括号,然后再输入正文
其实这是一个良好的习惯,避免由于括号不匹配造成的错误,值得一提的是,虽然这些错误一般是显式的,但是这么做话,可以帮助coder理清代码的层次,逻辑
另外,所谓的输入速度根本不是问题,对于coder来说,打字就是本能;另外一些编辑器会自动的进行括号匹配,也就是说只要打前括号,就会出现后括号,并且将光标退回正文区域的
3. C语言的注释定界符是什么
最早期的C语言注释的起始是/*
结束是*/
后来又增加的行注释, 为//
4. c语言必看常见符号分类,集合贴
C语言常见符号分类,看完你就懂了......
1、关键字
关键字,又称为保留字,他们是C语言中预先规定的具有固定含义的一些单词,例如C语言的第一个程序中的int和return等,用户只能按预先规定的含义来使用他们,不能擅自改变其含义。
2、标识符
标识符分为系统预定义标识符和用户自定义标识符两类。顾名思义,系统预定义标识符就是由系统预先定义好的,例如主函数main和输出函数printf等等。与关键字不同的是,系统预定义标识符是可以由用户重新定义的,但是这样会于原来的定义产生冲突,原来的含义会被替换,所以不建议这样用!
用户自定义标识符是由用户根据需要自行定义的标识符,通常用做变量名,函数名等,标识符的命名有一定的规则。
3、运算符
首先先说明一下,运算符一共有44个,这里没有一一列举。然后,因为运算符的用法广泛,种类繁杂,所以这里只是列举分类,真正的用途想要讲清楚可能要很久所以,先了解有哪些即可,记不住也没关系的,不用紧张的哈!
(1)算氏拆数运算符:+加 、-减、 *乘、 /除、歼没枣%取余。
(2)关系运算符:>大于、>=大于等于、==等于、<小于、<=小于等于、!=不等于。
(3)逻辑运算符: ! 逻辑非、&&逻辑与、|逻辑或。
(4)赋值运算符: = 将等号右边的数据赋值给察颤等号左边。
(5)增一和减一运算符: ++增一、--减一。
4、分隔符
写文章为了不产生歧义,我们会在适当的位置增加标点符号,用来区分。而写C语言程序,就会用分隔符来区分。
例如: 小明校长找你。和小明,校长找你。和小明校长找你。int a=1;inta=1;前一句就是对的,int a=1;就是命名一个整形的变量a等于1。而inta=1;错误的,因为inta如果是一个变量名的话,那它就没有数据类型了int a,b,c; 逗号也是分隔符的一种,表示命名三个变量,分别是a,b,C。
5、其他符号
括号[] - 括号的打开和关闭用于数组元素引用,表示单维和多维下标。括号() - 这些特殊符号用于函数调用和函数参数。大括号{} - 花括号的打开和关闭表示包含多个可执行语句的代码块的开始和结束。
分号(;)- 它被称为语句终止符,指示一个逻辑实体的结束。这就是每个单独的语句必须以分号结尾的原因。预处理器符号(#)- 编译器使用称为宏处理器的预处理器在实际编译开始之前转换您的程序。定界符”/*"和”*”- 程序注释所用的符号。
6、编译、链接
编译分为四个阶段:
(1)预编译:也称预处理,C程序中的预处理命令都在这个阶段完成,预编译完成的是对源程序的“替换”工作。"#就是预处理符号。
(2)编译阶段:对预编译的C程序进行词法和语法分析将错误呈现出来,处理完成后,编译器会将C程序转为汇编语言或其他中间代码。
(3)优化阶段:对程序代码进行优化,调整缩进等等。
(4)汇编阶段:把中间代码翻译成机器代码,也就是二进制代码,保存在目标文件中。
链接:经过编译后的目标文件的机器码之间是相互独立的,因此,需要链接器将它们链接组合在一起,并解析它们之间的交叉引用。
5. 求助,关于c语言的。
C语言基础(01-引言及预备知识): C语言是一门功能强大的编程语言,它也是C++语言的基础。C语言属于中级语言。这里所说的中级是相对于计算机的底层硬件而言的。汇编语言是最低级的语言,它可以直接与硬件打交道。高级语言有Pascal、Basic、Fortran等等。高级语言的一条语句对应低级语言的很多条语句,任何高级语言编写的程序都要经过编译程序的编译、连接才能成为可以运行的程序。编译连接的过程也就是把高级语言翻译成机器语言(二进制机器码)的过程,而汇编语言是基本上与机器语言一 一对应的一种语言。这个翻译过程是由编译程序自动完成的。把C语言定为中级语言是有它的道理的,因为C语言既有汇编语言的存取底层硬件的能力,又具有高级语言的许多特点。熟练掌握了C语言,学习其它的各种编程语言应该是很轻松的了。
C语言的书写格式:
1) 一个C语言编写的源程序,必定有一个主程序(称为main()函数,在C语言中子程序称为“函数”(当然,不要理解成为数学里面的“函数”)。但是决不能有一个以上的main函数(即只能有一个)。
2) 函数语句块用‘{’括号开始, 以‘}’反括号结束。这样的花括号必须成对出现。
3) 表达式写在小括号里面,以‘(’括号开始,以‘)’反括号结束。
4) 函数不能嵌套,即函数里面不能再套函数。(每一个函数是完成一个特定功能的函数模块)
C语言的组成:
C语言是由许多函数组成的。其中只有一个主函数(main()函数)。C程序执行时总是从main函数的‘{’处开始,至main函数的反大括号'}'处结束。当然还有其它一些规则,这将在以后的学习中去熟悉它。
C语言的书写规则:
C语言在书写时有它自身的特点:书写格式比较自由,在一行里可以写多条语句,一个语句也可以分写在多行上。虽然如此,在书写源程序时还是要注意哪些可以自由书写,而哪些必须要按照书写规则来书写。
几条规则写在下面:
1) 一行内可以写几个语句,建议一行不超过两条语句;
2) 一条语句可以写在多行上;
3) C语句不需要写行标号;
4) 每条语句及数据定义的后面要写上分号以表示该语句结束;
5) C语言中注释用 /* */来表示;
6) 建议书写时采用缩进格式;
7) 花括号、小括号都是成对出现的。
一个最简单的C程序的编写:
/* 程序代码*/ /* 注释部分*/
main() /*main是主函数名。紧跟在main后面的括号是放参数的。
括号里面为空说明main函数不需要参数*/
{ /*正写的大花括号表示main函数从这里开始*/
} /*反写的大花括号表示main函数到这里结束*/
说明:由于是一个演示程序,在函数体内并没有任何可以执行的语句,也就是这个程序什么事也不做。
这个程序就是这么简单: 写在一行上就是 main() { }
你在TC的编辑环境下把这段代码输入进去,按F9键编译连接,按CTRL_F5运行,一定很正常。但是什么结果也不会有,因为在main函数里面什么代码也没有。
下面再举一个可以向屏幕上输出一条信息的例子:
main()
{
printf("这就是C语言编写的程序!"); /*这一条语句的作用是向屏幕输出一条信息
”这就是C语言编写的程序!"*/
}
在这个程序中,main函数只有一条语句:printf("这就是C语言编写的程序!");这个语句的作用是向屏幕输出一个字符串。有关这个语句的知识以后再讲。现在要注意的是一个C语言程序的框架是怎样组成的。
C语言程序的几种文件格式:
1、 源程序---在TC集成环境中输入的程序文本称为源程序。源程序是一种文本文件。它是我们看得见并认识的一种文件。其扩展名为.C。例如你把文件保存为TEST,那么在磁盘上应看得到TEST.C这个文件。这样的文件可以用记事本打开。
2、二进制文件---写完了源程序后接着要做的是编译这个文件。在TC集成环境里是按ALT_F9键,编译后生成了一个二进制文件,这个二进制文件名为TEST.OBJ,也就是扩展名为OBJ的目标文件。
3、运行文件---最后一步是make(或Link),在TC集成环境里是按F9键Make之后生成了一个可以在DOS下运行的文件,其扩展名为EXE。如TEST.EXE。这个EXE文件是由第2步中的OBJ文件生成的。OBJ文件虽然是二进制文件,而电脑又是可以运行二进制文件的,为什么还要把OBJ文件Link为EXE文件才能运行?这里的知识就比较多了,这里不能多讲。但是要明白一点,在DOS下仅仅有了一个二进制文件还不能运行,因为操作系统要把这些二进制文件加以规划,把相应的数据、程序代码放到应该放的内存位置,这样的经过严密规划和组织好了的二进制文件才能运行。而这些只有在生成的EXE文件里面才做完了这些工作。
---------------------------------------
作业题:
1、下列程序中格式错在( )处。
A. main() B. int a,b,z;
C. a=2:b=3; D. z=a+b;
分析:A,B,D 没有错误。 C 中在a=2后面应该是分号而不应是":"号
答: C
2、C语言允许将一条语句写在两行上,下列语句不正确的是
A. int a,
B;
B. int a
,b;
C. int
a,b
D. int a,b
;
分析:C语言规定可以在语句中的任何一个分隔符或空格处换行。上面4个选项中D.有问题因为在D.中第一行的最后没有分隔符,而第二行只有一个分号,可以看做一个语句。所以D中的错误为:第一行是一个独立的语句,但是少了一个分号。
答: D
3. C语言的一行写不下时,可以
A. 用逗号换行 B. 用分号换行
C. 在任意一空格处换行 D. 用回车符换行
分析:C语言可以在任何一个分隔符或空格处换行,所以此题的正确答案是 C
答: C
4. 下列程序段中,哪一个是错误的注释方法?
A. #in/*包含*/clude<stdio.h>
void main()
{
}
B. #include<stdio.h>
void main/* */(/*主函数*/)
{
}
C. #include<stdio.h>
void main()
{ int x/*初始化*/=10;
/*打印*/printf("%d",x);
}
D. #include<stdio.h>
void main()
{
int x=10;
printf("%d",x);
/*打印x的值*”*=10*/
}
分析:根据C语言的规定:注释不能插在标识符的中间,在其它有分隔符的地方都可以插入注释,上面四个程序段中只有A是将注释插入在标识符的中间了。所以A是错误的。
答: A
5. C语言程序是由( )组成的?
答:C程序是由函数组成的。
6. C程序运行时,运行的是什么文件?
数据的类型:
在程序中要处理大量的数据,把这些数据按其特点分为几种基本的数据类型,它们分别是:
1 、整型 2 、字符型 3 、实型
还有其它的一些扩展的数据类型,但是开始学习时要先熟悉这三种基本数据类型。
在 C 语言中这几种数据类型用符号表示如下:
整型数据类型 int /* 一般指可以运算的数,如自然数就是整型数据类型 */
字符数据类型 char /* 一般指文字,如英文字母;字符类型的 '1''2''3''4' 等 */
实型 float /* 也称作浮点型,记住 float 类型的数都是有小数位的,如 425.23*/
常量和变量:
常量――程序运行过程中其值不变的量,如一个整数 134, 一个字符 ‘a'
变量――程序运行过程中其值可以变化的量,如 int a; char b; 那么 a 和 b 都是变量。
符号常量 ――用一个“符号”来表示的一个“常量”称为“符号常量”。
符号常量有什么好处 ――在给符号常量命名的时候,按习惯取的名字与实际上的含义相符,可以“见名识意”;另外在需要修改常量的值的时候,只需要修改符号常量的定义部分即可,非常方便。
符号常量的定义方法 ―― #define 符号 常量
例: #define NUMBER 30 /* 定义了一个符号常量,在这里是用符号 NUMBER 表示整数 30 ,以后在程序里就可以
用符号 NUMBER 代替整数 30 进行运算 */
main()
{
int a=20; /* 把常量 20 赋给整型变量 a*/
int c; /* 定义了整型变量 c*/
c=NUMBER+a; /* 变量 c 的值此时为 50 ,符号常量 NUMBER 参与了运算 */
}
变量的定义方法 ――在变量的名字前面加上一个变量的数据类型,以说明已定义的变量可以用来存放什么样类型的数据。
例: int a; /* 定义了一个整型变量,以后这个变量只能存放整型类型的数 */
char b; /* 定义了一个字符型变量,以后这个变量只能存放符字符型数据 */
怎样把常量值赋给已定义了的变量 ――用一个 = 号赋值。
例: int a; /* 定义一个整型娈量 a*/
char b; /* 定义了一个字符型变量 b*/
a=20; /* 用 = 号完成赋值,赋值后变量 a 的值此时为 20*/
b='d' /* 把常量字符 'd' 赋给变量 b ,此时变量 b 的值是字符 'd'*/
变量赋值时一种更灵活的方法 ――可以在一行上给多个相同数据类型的变量赋值,变量之间用逗号分隔。
例: int a,b,c,d; /* 定义了 4 个整型变量 */
char e,f,g; /* 定义了 3 个字符型变量 */
深入理解变量 ―― 1 ) 1 个变量必须有一个变量名。 2 )变量必须有其指定的数据类型
3 )变量一旦被定义,它就在内存中占有一个位置,这个位置称做该 变量的地址 。
4 )每一个变量都有其对应的值。
l 一定要牢记变量的这 4 个特性。
变量使用时的注意事项 ―― 1 )变量在使用之前一定要先定义,使用一个没有定义的变量是错误的。
2 )变量必须在一个函数的开始部分定义。(这个限制在 C++ 中不存在)
例题:写一个 2 个整数相加的程序。
/* 解题思路:求 2 个整数相加,必定要先定义 2 个变量来存放这 2 个数,另外还需要 1 个变量用来存放
相加的和,所以共需要定义 3 个整型变量 */
/* 注意每次在写 C 程序的时候一定要注意书写格式 */
main()
{
int a,b,c;
a=20,b=30; /* 在这里指定变量的值,因为还没有讲输入输出函数,只能这样了。 */
c=a+b;
}
想一想,这样简单的一个题,需要知道的知识面却不少。 用到了上面所讲的哪些知识?
C语言中的库函数――我们编写C语言程序时要写许多代码,这些代码是用基本程序语句如运算符、表达式、几种语句结构来组成。这些语句组成了多个不同的函数,由多个函数组成一个完整的程序。实际上如果程序中的语句都要由自己来写的话,那么工作量是很大的了。并且有一些完成基本任务的函数如输入输出函数是经常需要使用的。这样的一些常用的完成基本任务的函数有许多已经由提供编译程序的公司为我们写好了。这些已经写好的函数放在TC或者BC编译器的文件中。所谓“库函数”,就是存放“函数”的“仓库”。在TC中,函数的“仓库”在哪里呢?在TC的.\LIB目录中。编写程序的时候,如果我们需要使用某个库函数,就要在这个程序开头指明这库函数存放在哪里,以便让编译程序到这个地方去找。这个指明库函数路径的语句称为“包含”语句,写做#include。完整的写法是:
#include <stdio.h>
#include 是包含的意思,<stdio.h> 是指明要使用的库函数在 stdio.h这个文件里面有说明。尖括号<>是必须要写的。而实际上,编译程序在stdio.h之个文件里根据库函数名可以在.\LIB目录下的LIB文件里找到相关的代码,写进程序里面去。使用不同的库函数时要用不同的包含,关于怎样使用#include,可以查看库函数的帮助。
有了众多的库函数,给编写程序带来了很大的方便。就象做房子要用砖和瓦一样。如果没有砖和瓦,做房子自己要挖土烧砖,可想而知,那样做房子的难度有多大。写程序也是这样,有了库函数,在需要完成某些任务时,找到相应的库函数调用一下就可以了,不需要自己一点一点的写代码。在学习编程的同时要多多了解一些库函数的特点及用法,对编写程序是有很大的好处的。
(在Windows下编写程序,需要了解的“库函数”就更多了,可以说不了解库函数就不会编程。VC中用的是MFC,Win32中用的是API,它们都是函数库)
先了解二个库函数――1、scanf函数 /*格式化控制台输入函数*/
函数原型:int scanf(control_string....); /*看上去很复杂。没关系,以后自然会明白的*/
使用例:
void main()
{
int a,b,c; /*定义了三个整型变量*/
scanf("%d%d",&a,&b); /*从键盘输入二个整数到娈量a和b中*/
c=a+b; /*把变量a与b相加的和送给变量c*/
}
下面仔细讲一下scanf函数各参数的用法:
可以看到在小括号里有二个%d,后面有二个变量a和b。二个%d的写法为"%d%d",注意凡是这样的符号都要写在双引号里面,而变量则写在双引号的外面并用逗号分隔。这个%d我们称为格式化说明符,第一个%d用于说明第一个变量a,第二个%d用于说明第二个变量b,这样的顺序是一一对应的。%d格式符说明了后面输入的变量值是整型数。
另外注意的是二个%d是靠在一起的 %d%d,凡是这样的写法,在输入数时,对于二个数之间的分隔是用“空隔键”来实现的。如输入30和50这二个数形式为 30 50 如果二个%d写成%d,%d中间有一个逗号,那么在输入数据时也一定要在输入的数之间加上逗号,如 30,50。
再来看一下变量的写法,可以看到在每一个变量名的前面都有一个&号,这个&号是取变量地址的意思,那么&a写在一起就是变量a的地址,&b写在一起就是变量b的地址。
上面的scanf函数的作用就是把从键盘上输入的二个整数分别送到变量a和变量b的地址里面去。这个&号是非常重要,不要写漏了。
scanf函数的格式说明符(格式说明符说明了下一步将读的是什么类型的数据)
格式码 含义
%c 读一单字符
%d 读一整数
%i 读一个浮点数
%e 读一个浮点数
%f 读一个浮点数
%g 读一个浮点数
%o 读一个八进制数
%s 读一字符串
%x 读一十六进制数
%p 读一指针
%n 读一个指针收一个等于到目前为止输入的字符数止的整数
%u 读一无符号整数
%[] 扫描一字符集
例:从键盘输入二个字符,一个大写,一个小写,然后把这个小写字符转换成大写,大写字符转换成小写。
#include<stdio.h> /*因为在程序里用到了库函数scanf,所以要使用包含#include<stdio.h>*/
void main()
{
char ch,chh; /*定义了二个字符型变量*/
scanf("%c%c",&ch,&chh); /*从键盘输入二个字符,一个大写,另一个小写*/
ch=ch+32; /*大写转成小写*/
chh=chh-32; /*小写转成大写*/
}
2、printf函数 /*格式化输出函数*/
函数原型:int printf(const char *control_string....);
说明:printf把变量的值或常量字符串输出到控制台(一般是显示屏)
使用例:
#include<stdio.h>
void main()
{
int a,b,c;
scanf("%d%d",&a,&b);
c=a+b;
printf("输出二个整数相加的和"); /*输出字符串常量,这里没有用到格式化说明符*/
printf("%d",c); /*把变量c的值用整型格式输出,这里%d是整型格式说明符*/
}
如果有几个变量的值要输出,用这样的形式:printf("%d %d %d",a,b,c);
从这个printf输出的格式中看出,每一个格式符对应一个变量,其对应顺序也是一一对应的,第一个%d对应第一个变量a,以此类推。注意在printf函数中,变量前面就不要加&符号了。
注意printf函数中几个%d之间留了一些空格,这里的用法与scanf相比有一点不同。在printf函数中格式符之间留多少空隔,输出的时候每一个输出的值之间就有多少空隔。如printf("%d %d %d",a,b,c);输出则为:20 30 50 (这里的数是假设的)。如果写为printf("%d,%d,%d",a,b,c);则输出形式为 20,30,50
printf函数的格式符:
格式码 格式
%c 单个字符
%d 十进制数
%i 十进制数
%e 科学法表示
%E 科学法表示
%f 十进制浮点数
%g 用%e或%f中较短的的一个(如果是%e,用小写e)
%G 用%e或%f中较短的的一个(如果是%E,用大写E)
%o 以八进制形式输出
%s 字符串
%u 无符号十进制数
%x 十六进制数(小写)
%X 十六进制数(大写)
%p 显示一个指针
%n 相关变量是整型指针,它所指处存放至今要写入字符的总数
%% 打印一个%号
printf函数使用例:
1)char ss="abcdefghijk"; printf("%s",ss); /*输出一个字符串,屏幕上显示"abcdefghijk"*/
2)unsigned int a=65535; printf("%u",a); /*以十六进制形式输出一个无符号数,显示为ffff*/
3)int a=123,b=456,c=687; printf("%d\t%d\n%d",a,b,c);
输出形式为:
123 456 /*'\t'是一个制表符,所以要移动一个制表位这么多空格数*/
687 /*'\n'是换行转义符,在前面字符常量里讲过。所以要换一行再输出687*/
C语言基础(05-运算符和表达式):运算符(也叫操作符)--运算符是一个表示特定的数学或逻辑操作的符号。如'+'号,表示了一个相加运算;'&&'号表示了一个逻辑‘与’的运算。由运算符把需要进行运算的各个量(常量或变量)连接起来组成一个表达式。
下面要讲的是标准的运算符,在C++中还有另外的一些运算符。运算符 进行的运算 所属类别 备注
[ ] 间隔符 标点符号
( ) 间隔符 标点符号
· 直接分量选择 双目操作符
-> 间接分量选择 双目操作符
++ 前增量、后增量 单目操作符
-- 前减量、后减量 单目操作符
+ 加 双目操作符、单目操作符
- 减 双目操作符、单目操作符
* 1)乘 2)间接引用 双目操作符、单目操作符
/ 除 双目操作符
% 求余 双目操作符
& 1)位‘与’2)取地址 双目操作符、单目操作符
! 逻辑‘非’ 单目操作符
&& 逻辑‘与’ 双目操作符
|| 逻辑‘或’ 双目操作符
<< 左移位 双目操作符
>> 右移位 双目操作符
< 小于 双目操作符
> 大于 双目操作符
== 等于 双目操作符
!= 不等于 双目操作符
^ 位‘异或’ 双目操作符
+= 和赋值 双目操作符
-= 差赋值 双目操作符
*= 乘赋值 双目操作符
/= 商赋值 双目操作符
<<= 左移赋值 双目操作符
>>= 右移赋值 双目操作符
&= 按位‘与’赋值 双目操作符
^= 按位异或赋值 双目操作符
|= 按位或赋值 双目操作符
%= 模赋值 双目操作符
= 赋值 双目操作符
?: 按条件取值 双目操作符
, 间隔符 标点符号
# 预处理符号 标点符号
## 预处理符号 标点符号
sizeof 求字节数
~ 按位求反
| 位‘或’
: 间隔符
; 间隔符
... 间隔符
要把表中的运算符仔细的分类是不容易的,因为同一个运算符,在不同的地方其含义是不同的。如*运算符,当作为乘运算时是双目操作符(所谓双目操作符,即运算时需要二个操作数),如3*6,那么3与6总共是二个操作数。当作为取值运算时就是单目操作符(所谓单目操作符是只需要一个操作数)如对一个数求反:!a,这里只有一个操作数a。
要记住运算符的二个特点,一个是运算符的操作对象,另一个就是运算符的优先级别。其中运算符的优先级别是最不容易搞清楚和最容易出错的地方。
在讲运算符之前讲一下“表达式”的概念:所谓表达式,就是用运算符把各个操作数连接成符合C语法规则的进行运算的式子。这里说的“符合C语法的规则”也很重要。如 a+b+5就是一个用算术运算符连接起来的表达式。
1、算术运算符:+、-、*、/、%
1)+、-、*、/ 分别是相加、相减、相乘、相除
2)% 求二个数运算的模。所谓求模就是求二个数相除后的余数。例:25/3的余数是1,可以说25%3的模是1。要注意的是求模运算时二个操作数必须是整数。如果求25.3/3.1这样是不能运算的。
下面写一个例子:
#include<stdio.h> /*程序中要用到输入输出库函数,所以包含了stdio.h*/
void main()
{
int a=10,b=20,c=30; /*定义了3个整型变量,并同时进行了初始化赋值*/
a=a*b+c; /*a*b+c组成了一个算术表达式,运算后的结果为230并把值*/
/*赋给变量a*/
printf("%d",a); /*以整型格式输出变量a的值。这里输出230*/
a=a%b; /*进行求模运算。因为没有余数,最后的模为0*/
printf("%d",a); /*输出变量a的值。这里输出0*/
}
下面是一个要考虑运算符优先级的例子:
#include<stdio.h>
void main()
{
int a=10,b=20,c=30;
a=c-a*b; /*这里就要考虑运算符优先级,*运算符的优先级比-运算符*/
/*的高,所以先进行乘运算。这里最后结果为-170*/
}
由上面这个例子看到,在一个有多个运算符连接起来的表达式中需要考虑运算符的优先级,这个例子很简单。关于运算符优先级的概念其实在小学生的算术运算中就有这样的概念了,只不过这里的运算符多了一些,要考虑的情况也就复杂了。
如果这个式子改写一下,写成:a=(c-a)*b;在运算时就以括号中的运算优先。
几个简化的运算表达式:
在C语言的程序中,经常看到这样的运算,如:i++;或者k--;这是运算符号的简化写法。
1、加1运算的简写
当一个变量进行加1运算时,如a=a+1;这是变量自身加1,简写为a++;
2、减1运算的简写
当一个变量进行减1运算时,如a=a-1;这是变量自身减1,简写为a--;
3、加1个常量运算的简写
当一个变量与一个常量相加时,如a=a+5;这是变量自身加5,简写为a+=5;
4、减一个常量运算的简写
当一个变量与一个常量相减时,如a=a-5;这是变量自身减5,简写为a-=5;
5、乘一个常量运算的简写
当一个变量与一个常量相乘时,如a=a*5,这是变量自身乘5,简写为a*=5;
6、除一个常量运算的简写
当一个变量与一个常量相除时,如a=a/5;这是变量自身除5,简写为a/=5;
运算符的结合性(或称作关联性)
在一个复杂的表达式中,常常有许多运算符和变量,这时就要判断优先级和结合性这二个因素。
例:-5+7; 这样的一个表达式用结合性来判断,因为运算符'-'和'+'相对于运算的数来说是‘左’结合的,所以就有'-5'和'+7'所以运算的结果为 2。
通过这个例子要知道什么是“左结合性”和“右结合性”
左结合性--变量(或常量)与左边的运算符结合
右结合性--变量(或常量)与右边的运算符结合
运算符的优先级和结合性表
优先级 运算符(高 ------→低) 结合率 运算符类型
高 ( ) [ ] -> . 从左至右 双目运算符
! ~ ++ -- (类型) sizeof + - * & 从右至左 单目运算符
* / % 从左至右 双目运算符
+ - 从左至右 双目运算符
<< >> 从左至右 双目运算符
< <= > >= 从左至右 双目运算符
== != 从左至右 双目运算符
& 从左至右 双目运算符
^ 从左至右 双目运算符
| 从左至右 双目运算符
&& 从左至右 双目运算符
|| 从左至右 双目运算符
?: 从右至左 三目运算符
低 = += -= *= /= %= &= ^= |= <<= >>= 从左至右 双目运算符
高 -------------→ 低
从表中可以看出一个规律,凡是单目运算符都是“右结合”的,凡是双目运算符都是“左结合”的。其中有一个?:运算符是三目运算符是右结合的,记住了这个规律,运算符的结合性也就掌握了。
如果代码行中的运算符比较多,用括号确定表达式的操作顺序,避免使用默认的优先级。
由于将表熟记是比较困难的,为了防止产生歧义并提高可读性,应当用括号确定表达式的操作顺序。例如:
d = (high << 8) | low /*用括号把需要先运算的括起来*/
if ((a | b) && (a & c)) /*用括号把需要先运算的括起来*/
例:
下列程序输出的结果是
#include<stdio.h>
void main()
{
int a=2;
a%=4-1;
printf("%d",a);
a+=a*=a-=a*=3;
printf("\n%d",a);
}
A. 2,0 B. 1,0
C. -1,12 D. 2,12
分析:由于%=运算符的优先级别低于-运算,a%=4-1即是a%=3,等价于a=a%3即a=2%3=2,所以选项B和C是错误的。表达式a+=a*=a-=a*=3,计算时注意赋值类表达式的值和变量的值随时被更新,计算表达式的值,开始时a=2,表达式赋值是从左至右进行的,表达a*=3使得a=6,此表达式的值也为6,于是表达式a-=a*=3相当于a-=6=6-6=0,a的值为0,后面的计算就不用做了,所以a的值最终为0。
答:A
下列语句中错误的是
A.x=sizeof int;
B.x=sizeof 3.14
C.printf("%d",a=a+1,b--,c+1);
D.printf("%d",++x,x++);
分析:此题的选项A的作用是测试int类型所占内存的字节数,因为类型符要用括号括起来,这时缺少括号是错误的。
选项B是正确的。
选项C从表面上看似乎复杂一些,但其中的a=a+1,b--,c+1是一个逗号表达式,C语言允许使用这种表达式所以D也是正确的。
答案:A
下面的语句中,符合C语言语法的赋值语句是
A.a=7+b+c=a+7; B.a=7+b++=a+7;
C.a=7+b,b++,a+7; D.a=7+b;c=a+7;
分析:一般情况下,表达式不能放在赋值号的左边,所
6. c源程序的基本单位是函数,在定义函数时,函数体必须使用一对什么作为定界符
必须使用一对花括号{ }作为定界符
请采纳,谢谢。
7. C语言中的一句话“表达式为真”,这个“真”是什么意思
因为形式逻辑并不研究“判断的绝对之真”,而C语言是基于形式逻辑理论而编写的计算机编程语言,所以“表达式为真”指的是“命题的相对之真”。
真和假的哲学定义
真/假是对事物体感知程度的判断。是成对出现的,必须一起定义。
真和假构成一对抽象范畴概念,用范畴式定义就是:体感{假/真}。可知假涵盖了真。
真/假分为绝对和相对两种。
一、绝对(判断)真假:有界为真,没界为假。绝对真/假表达了对所有事物的共同性质:本体(连/限)的直接感知程度。就是说只有在有界的情况下,一件事物才能够被感知为是一件被确认的事物;如果没界就没法感知到真有这件事物。这就是绝对真假的含义。分开来定义就是:
绝对的“真”:在连续的混沌中界出了有确定边界的东西。
绝对的“假”:在连续的混沌中没界出有确定边界的东西。
通常所说的:看真些。其实就是说要把对象的边界确认清楚。所谓真假难分,就是说事物总是难以“确界”的。这里有两层意思,1、某一个人对某物难以确界,2、每个人的确界难以相同。其中1涵盖了2。
如表所示,绝对真假是对事物体直接感知程度的判断,共有四级:假的有三级,真的只有一级。我们常说:1、听得不是很真(失真)。指的是听到的与以前不一样;2、没听到什么啊。指的是听不到声音,就是听不到有什么可以作为限制的东西;3、静静的。指的是一片“连”着的空白,这与2反着说但意思相同;4、听到明显的声音。指的是听到“界限”了。
二、相对(命题)真假:把有界传作没界或把没界传作有界都是传递之假(失真);把此界传作他界也是传递之假(误传);把此界传作此界或把没界传作没界则是传递之真(真传)。可见传递的真假是相对于命题的。相对真假问题是指判断的真假在命题和推理过程中的正确传递与否的问题。形式逻辑中的《基本命题真值表》表达的正是绝对真假的相对传递规律,至于如何保证原始判断的绝对真假问题,形式逻辑并不研究。