c语言基础

来源:互联网 发布:js null undefined 编辑:程序博客网 时间:2024/06/05 16:06

总体上必须清楚的:

1)计算机的数据在电脑中保存是以 二进制的形式数据存放的位置就是 他的地址

 2)bit是位 是指为或者1。 byte 是指字节一个字节 八个位.

第一章 C语言的基础知识:

第一节、对C语言的基础认识

1C语言编写的程序称为源程序,又称为编译单位。

2C语言书写格式是自由的,每行可以写多个语句,可以写多行。

3、一个C语言程序有且只有一个main函数,是程序运行的起点。

注意:

1、编译预处理不是C语言的一部分,不占运行时间,不要加分号。C语言编译的程序称为源程序,它以ASCII数值存放在文本文件中。

2、在函数中不可以再定义函数。

第三节、标识符:

1、标识符:

合法的要求是由字母,数字,下划线组成。有其它元素就错了。

并且第一个必须为字母或则是下划线。第一个为数字就错了

2、标识符分为关键字、预定义标识符、用户标识符。

关键字:不可以作为用户标识符号。main  define  scanf  printf 都不是关键字。迷惑你的地方If是可以做为用户标识符。因为If中的第一个字母大写了,所以不是关键字。

预定义标识符:背诵define  scanf  printf  include。记住预定义标识符可以做为用户标识符。

第五节:整数与实数

1C语言只有八、十、十六进制,没有二进制。但是运行时候,所有的进制都要转换成二进制来进行处理。

    aC语言中的八进制规定要以0开头。018的数值是非法的,八进制是没有8的,逢81。  

    bC语言中的十六进制规定要以0x开头。

2)小数的合法写法:C语言小数点两边有一个是零的话,可以不用写。

1.0C语言中可写成1.

0.1C语言中可以写成.1

3)实型数据的合法形式:

a2.333e-1 就是合法的,且数据是2.333×10-1。

4) 整型一般是4个字节字符型是1个字节,双精度一般是8个字节:

  long int x; 表示x是长整型。

    unsigned int x; 表示x是无符号整型。

第六、七节:算术表达式和赋值表达式

核心:表达式一定有数值!

1、算术表达式:+-*/

   注意:“/” 两边都是整型的话,结果就是一个整型。 3/2的结果就是1. 

         “/” 如果有一边是小数,那么结果就是小数。 3/2.0的结果就是0.5

          “%”符号请一定要注意是余数, %符号两边要求是整数。不是整数就错了。

2、赋值表达式:表达式数值是最左边的数值,a=b=5;该表达式为5,常量不可以赋值。

1int x=y=10: 错啦,定义时,不可以连续赋值。

2int x,y;

x=y=10;   对滴,定义完成后,可以连续赋值。

3、赋值的左边只能是一个变量。

4int x=7.7;对滴,x就是7

5float y=7;对滴,x就是7.0

3、复合的赋值表达式:

   int a=2

   a*=2+3;运行完成后,a的值是10

一定要注意,首先要在2+3的上面打上括号。变成(2+3)再运算。

4、自加表达式:

自加、自减表达式:假设a=5++a(是为6), a++(为5);

运行的机理:++a 是先把变量的数值加上1,然后把得到的数值放到变量a中,然后再用这个++a表达式的数值为6,而a++先用该表达式的数值为5,然后再把a的数值加上16

再放到变量a中。 进行了++aa++后 在下面的程序中再用到a的话都是变量a中的6了。

  口诀:++在前先加后用,++在后先用后加。

5、逗号表达式:

优先级别最低。表达式的数值是逗号最右边的那个表达式的数值。

234)的表达式的数值就是4

 z=234(整个是赋值表达式这个时候z的值为4。(有点难度哦!)

  z=  234 (整个是逗号表达式)这个时候z的值为2。 

补充:

1、空语句不可以随意执行,会导致逻辑错误。

2、注释不是C语言,不占运行时间,没有分号。不可以嵌套!

3、强制类型转换:

  一定是 (int不是  inta),注意类型上一定有括号的。

   注意(int)(a+b) 和(inta+b 的区别。 前是把a+b转型,后是把a转型再加b

4、三种取整丢小数的情况:

       1、int a =1.6

              2、(int)a;  

                3、1/2; 3/2

第八节、字符

1)字符数据的合法形式:

   '1' 是字符占一个字节,"1"是字符串占两个字节(含有一个结束符号)

  '0' ASCII数值表示为48'a' ASCII数值是97'A'ASCII数值是65

表示单个字符错误的形式:'65'    "1"

字符是可以进行算术运算的,记住: '0'-0=48

大写字母和小写字母转换的方法: 'A'+32='a'  相互之间一般是相差32

2)转义字符:

转义字符分为一般转义字符、八进制转义字符、十六进制转义字符。

一般转义字符:背诵\0、 \n、 \’、 \”、 \\

八进制转义字符:  ‘\141’ 是合法的, 前导的0是不能写的。

十六进制转义字符:’\x6d’ 才是合法的,前导的0不能写,并且x是小写。

3字符型和整数是近亲:两个具有很大的相似之处

          char a = 65 ;

            printf(%c, a);  得到的输出结果:a

printf(%d, a); 得到的输出结果:65                

第二章

第一节:数据输出(一)(二)

1、使用printfscanf函数时,要在最前面加上#includestdio.h

2printf可以只有一个参数,也可以有两个参数。

3printf(“ 第一部分 ”,第二部分  );把第二部分的变量、表达式、常量以第一部分的形式展现出来!

4printf(“a=%db=%d”,12, 34

一定要记住是将1234以第一部分的形式现在在终端也就是黑色的屏幕上 

  printf(“a=%d\n b=%d”,12, 34)那么输出的结果就是:a=12

b=34

   5int x=017;   一定要弄清楚为什么是这个结果!过程很重要

      printf(“%d”, x); 15

printf(“%o”, x); 17 

printf(“%#o”,x); 017

printf(“%x”, x); 11  

printf(“%#x”,x); 0x11 

   6int x=12y=34;  注意这种题型

      char z=a’;     

      printf(“%d ”,xy); 一个格式说明,两个输出变量,后面的y不输出

      printf(“%c”,z);       结果为:12a

   7 

格式说明

表示内容

格式说明

表示内容

%d

整型   int

%c

字符  char

%ld

长整型 long int

%s

字符串

%f

浮点型 float

%o

八进制

%lf

double

%#o

带前导的八进制

%%

输出一个百分号

%x

十六进制

%5d

 

%#x

带前导的十六进制

举例说明:

printf(“%2d”,123 );  第二部分有三位,大于指定的两位,原样输出123

printf(“%5d”,123 );  第二部分有三位,小于指定的五位,左边补两个空格  123

printf(“%10f”,1.25 ); 小数要求补足6位的,没有六位的补0,。结果为1.250000 

printf(“%5.3f”,125 ); 小数三位,整个五位,结果为1.250(小数点算一位)

printf(“%3.1f”,1.25 );小数一位,整个三位,结果为1.3(要进行四舍五入)

第三节 数据输入

1scanf(“a=%db=%d”,&a&b) 

一定要记住是以第一部分的格式在终端输入数据。

在黑色屏幕上面输入的为  a=12b=34才可以把1234正确给a。有一点不同也不行。         

2scanf(“%d%d”,xy);这种写法绝对错误,scanf的第二个部分一定要是地址!

scanf(“%d%d”,&x&y);注意写成这样才可以!

3、指定输入的长度 

终端输入:1234567 

scanf(“%2d%4d%d”,&x&y&z);x12y3456z7

终端输入:1 234567     由于12中间有空格,所以只有1位给x

scanf(“%2d%4d%d”,&x&y&z);x1y2345z67

4、字符和整型是近亲:

int x=97

printf(“%d”,x);   结果为97

printf(“%c”,x);   结果为 a

5、输入时候字符和整数的区别

scanf(“%d”,&x);这个时候输入1,特别注意表示的是整数1

scanf(“%c”,&x);这个时候输入1,特别注意表示的是字符‘1ASCII为整数48

补充说明:

1scanf函数格式:

   注意该函数的第二个部分是&a 这样的地址,不是a;  

   scanf(“%d%d%*d%d”,&a,&b,&c); 跳过输入的第三个数据。

2putchar ,getchar 函数:

   char  a = getchar() 是没有参数的,从键盘得到你输入的一个字符给变量a。 

   putchar(‘y’)把字符y输出到屏幕中。

3)如何实现两个变量y中数值的互换

   不可以把 x=y ,y=x; 要用中间变量 t=xx=yy=t

4)如何实现保留三位小数,第四位四舍五入的程序 

       y=int)(x*100+0.5/100.0   这个保留两位,对第三位四舍五入

       y=int)(x*1000+0.5/1000.0 这个保留三位,对第四位四舍五入

y=int)(x*10000+0.5/10000.0 这个保留四位,对第五位四舍五入

   这个有推广的意义,注意 x = int这样是把小数部分去掉。

 

1 0
原创粉丝点击