飞道的博客

c语言全部知识大梳理

495人阅读  评论(0)

C语言与C++学习路线

1.入门程序


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. printf( "Hello World!");
  5. return 0;
  6. }

2.数据类型

数据类型:

1.基本数据类型

1.1. 整型:int 4 个字节

1.2. 字符型:char 1 个字节

1.3. 实型(浮点型)

  • 1.3.1.单精度型:float 4 个字节

  • 1.3.2.双精度型:double 8 个字节

2.构造类型

2.1.枚举类型

2.2.数组类型

2.3.结构体类型

2.4.共用体类型

3.指针类型

4.空类型

3.格式化输出语句

  • %d:十进制整数;

  • %c:单个字符;

  • %s:字符串;

  • %f:6位小数;


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int age = 18;
  5. float height = 1.85;
  6. char unit = 'm';
  7. printf( "小明今年%d岁\n", age);
  8. printf( "小明身高%f%c\n", height, unit);
  9. printf( "小明现在在慕课网上学习IT技术\n");
  10. return 0;
  11. }

4.常量

值不发生改变的量成为常量;

定义字符常量(注意后面没有;)


  
  1. #include <stdio.h>
  2. #define POCKETMONEY 10 //定义常量及常量值
  3. int main()
  4. {
  5. printf( "小明今天又得到%d元零花钱\n", POCKETMONEY);
  6. return 0;
  7. }

5.运算符

5.1.算数运算符:+,-,*,/,%,++,--;前++/--,先运算,再取值.后++/--,先取值,再运算;

5.2.赋值运算符:

5.3.关系运算符;

5.4.逻辑运算符;

5.5.三目运算符:

  • 表达式1 ? 表达式2 : 表达式3;

6.水花仙数计算

输出所有三位数的水仙花数字

所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数,如:153就是一个水仙花数,153=111+555+333。


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. //定义三位数num,个位数sd,十位数td,百位数hd
  5. int num, sd, td, hd;
  6. //循环所有三位数
  7. for( num= 100 ; num< 1000 ; num++ )
  8. {
  9. //获取三位数字num百位上的数字
  10. hd = num/ 100 ;
  11. //获取三位数字num十位上的数字
  12. td = num/ 10% 10 ;
  13. //获取三位数字num个位上的数字
  14. sd = num% 10 ;
  15. //水仙花数的条件是什么?
  16. if(num ==hd*hd*hd+td*td*td+sd*sd*sd )
  17. {
  18. printf( "水仙花数字:%d\n", num);
  19. }
  20. }
  21. return 0;
  22. }

7.打印正三角形的*


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int i, j, k;
  5. for(i= 1; i< 5; i++)
  6. {
  7. /* 观察每行的空格数量,补全循环条件 */
  8. for( j=i ; j< 5 ; j++ )
  9. {
  10. printf( " "); //输出空格
  11. }
  12. /* 观察每行*号的数量,补全循环条件 */
  13. for( k= 0 ; k< 2*i -1 ; k++ )
  14. {
  15. printf( "*"); //每行输出的*号
  16. }
  17. printf( "\n"); //每次循环换行
  18. }
  19. return 0;
  20. }

8.臭名远扬的goto语句

很少使用


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int sum = 0;
  5. int i;
  6. for(i= 1; i<= 10; i++)
  7. {
  8. printf( "%d\n", i);
  9. if(i== 3){
  10. goto LOOP; //满足条件就执行goto语句
  11. }
  12. }
  13. //执行goto
  14. LOOP: printf( "结束for循环了...."); //请选择合适位置添加标识符
  15. return 0;
  16. }

9.形参与实参

形参:形参是在定义函数名和函数体的时候使用的参数,目的是用来接收调用该函数时传入的参数;

实参:实参是在调用时传递该函数的参数。

函数的形参和实参具有以下特点:

  1. 形参只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只有在函数内部有效。函数调用结束返回主调函数后则不能再使用该形参变量。

  2. 实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须具有确定的值,以便把这些值传送给形参。因此应预先用赋值等办法使实参获得确定值。

  3. 在参数传递时,实参和形参在数量上,类型上,顺序上应严格一致,否则会发生类型不匹配”的错误。

10.函数返回值注意

注意:void函数中可以有执行代码块,但是不能有返回值,另void函数中如果有return语句,该语句只能起到结束函数运行的功能。其格式为:return;

11.递归


  
  1. #include <stdio.h>
  2. int getPeachNumber(int n) //这里要定义n,要不编译器会报错!
  3. {
  4. int num;
  5. if(n== 10)
  6. {
  7. return 1;
  8. }
  9. else
  10. {
  11. num = (getPeachNumber(n+ 1)+ 1)* 2;
  12. printf( "第%d天所剩桃子%d个\n", n, num);
  13. }
  14. return num;
  15. }
  16. int main()
  17. {
  18. int num = getPeachNumber( 1);
  19. printf( "猴子第一天摘了:%d个桃子。\n", num);
  20. return 0;
  21. }

12.变量存储类别 !

12.1.生存周期划分存储方式

C语言根据变量的生存周期来划分,可以分为静态存储方式和动态存储方式。

静态存储方式:是指在程序运行期间分配固定的存储空间的方式。静态存储区中存放了在整个程序执行过程中都存在的变量,如全局变量。

动态存储方式:是指在程序运行期间根据需要进行动态的分配存储空间的方式。动态存储区中存放的变量是根据程序运行的需要而建立和释放的,通常包括:函数形式参数;自动变量;函数调用时的现场保护和返回地址等。

12.2.存储类型划分

C语言中存储类别又分为四类:自动(auto)、静态(static)、寄存器的(register)和外部的(extern) ;

  1. 用关键字auto定义的变量为自动变量,auto可以省略,auto不写则隐含定为“自动存储类别”,属于动态存储方式。

  2. 用static修饰的为静态变量,如果定义在函数内部的,称之为静态局部变量;如果定义在函数外部,称之为静态外部变量。

注意:静态局部变量属于静态存储类别,在静态存储区内分配存储单元,在程序整个运行期间都不释放;静态局部变量在编译时赋初值,即只赋初值一次;如果在定义局部变量时不赋初值的话,则对静态局部变量来说,编译时自动赋初值0(对数值型变量)或空字符(对字符变量)

  1. 为了提高效率,C语言允许将局部变量的值放在CPU中的寄存器中,这种变量叫“寄存器变量”,用关键字register作声明。

注意:只有局部自动变量和形式参数可以作为寄存器变量;一个计算机系统中的寄存器数目有限,不能定义任意多个寄存器变量;局部静态变量不能定义为寄存器变量。

  1. 用extern声明的的变量是外部变量,外部变量的意义是某函数可以调用在该函数之后定义的变量。


  
  1. #includ <stdio.h>
  2. int main()
  3. {
  4. //定义外部局部变量
  5. extern int x;
  6. return 0;
  7. }
  8. int x= 100;

13.内部函数外部函数 !

在C语言中不能被其他源文件调用的函数称为内部函数 ,内部函数由static关键字来定义,因此又被称为静态函数,形式为:

static [数据类型] 函数名([参数])

这里的static是对函数的作用范围的一个限定,限定该函数只能在其所处的源文件中使用,因此在不同文件中出现相同的函数名称的内部函数是没有问题的。

在C语言中能被其他源文件调用的函数称为外部函数 ,外部函数由extern关键字来定义,形式为:

extern [数据类型] 函数名([参数])

C语言规定,在没有指定函数的作用范围时,系统会默认认为是外部函数,因此当需要定义外部函数时extern也可以省略。 extern可以省略; 14.数组 数组:一块连续的,大小固定并且里面的数据类型一致的内存空间, 数组的声明:数据类型 数组名称[长度n]

  1. 数据类型 数组名称[长度n] = {元素1,元素2,元素3,......};

  2. 数据类型 数组名称[] = {元素1,元素2,元素3,......};

  3. 数类类型 数组名称[长度n]; 数组名称[0] = 元素1;数组名称[1] = 元素2;...... 注意: 1、数组的下标均以0开始; 2、数组在初始化的时候,数组内元素的个数不能大于声明的数组长度; 3、如果采用第一种初始化方式,元素个数小于数组的长度时,多余的数组元素初始化为0; 4、在声明数组后没有进行初始化的时候,静态(static)和外部(extern)类型的数组元素初始化元素为0,自动(auto)类型的数组的元素初始化值不确定。

15.数组遍历


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int arr[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9} ;
  5. int i;
  6. for(i=0;i<10;i++)
  7. {
  8. printf("%d\n", arr[ i] );
  9. }
  10. return 0 ;
  11. }
  1. 数组的冒泡排序

冒泡排序的思想:相邻元素两两比较,将较大的数字放在后面,直到将所有数字全部排序。

  1. 字符串与数组

在C语言中,是没有办法直接定义子字符串数据类型的,需使用数组来定义所要的字符串,形式如下:

  • char 字符串名称[长度] = "字符串内容";

  • char 字符串名称[长度] = {'字符串1','字符串2',....,'字符串n','\0'};

注:

  1. []中的长度可以省略不写;

  2. 采用第二种方式最后一个元素必须是'\0',表示结束;

  3. 第二种方式不能写中文!; 输出字符串时,要使用:printf("%s",字符数组名);或puts(字符数组名);

16.字符串函数

  1. strlen(s):获取字符串s的长度;

  2. strcmp(s1,s2):比较字符串;比较的时候会把字符串转换成ASCII码再进行比较,返回结果为0表示s1和s2的ASCII码值相等,返回结果为1表示s1比s2的ASCII码大,返回结果为-1表示s1比s2的ACSII码小;

  3. strcpy(s1,s2):字符串拷贝;s2会取代s1中的内容;

  4. strcat(s1,s2)将s2拼接到s1后面;注意:s1的length要足够才可以!

  5. atoi(s1)将字符串转为整数!

17.多维数组

数据类型 数组名称[常量表达式1]...[常量表达式n];

多维数组的初始化与一维数组的初始化类似也是分两种:

  1. 数据类型 数组名称[常量表达式1][常量表达式2]...[常量表达式n] = { {值1,..,值n},{值1,..,值n},...,{值1,..,值n}};

  2. 数据类型 数组名称[常量表达式1][常量表达式2]...[常量表达式n]; 数组名称[下标1][下标2]...[下标n] = 值;

多维数组初始化要注意以下事项:

  1. 采用第一种始化时数组声明必须指定列的维数。因为系统会根据数组中元素的总个数来分配空间,当知道元素总个数以及列的维数后,会直接计算出行的维数;

  2. 采用第二种初始化时数组声明必须同时指定行和列的维数。

18.多维度数组的遍历

使用嵌套循环

注意:多维数组的每一维下标均不能越界!

19.结构体

C 数组允许定义可存储相同类型数据项的变量,结构是 C 编程中另一种用户自定义的可用的数据类型,它允许您存储不同类型的数据项。

结构用于表示一条记录,假设您想要跟踪图书馆中书本的动态,您可能需要跟踪每本书的下列属性:

  • Title

  • Author

  • Subject

  • Book ID

定义结构

为了定义结构,您必须使用 struct 语句。struct 语句定义了一个包含多个成员的新的数据类型,struct 语句的格式如下:


  
  1. struct tag {
  2. member- list
  3. member- list
  4. member- list
  5. ...
  6. } variable- list ;

tag 是结构体标签。

member-list 是标准的变量定义,比如 int i; 或者 float f,或者其他有效的变量定义。

variable-list 结构变量,定义在结构的末尾,最后一个分号之前,您可以指定一个或多个结构变量。下面是声明 Book 结构的方式:


  
  1. struct Books
  2. {
  3. char title[ 50];
  4. char author[ 50];
  5. char subject[ 100];
  6. int book_id;
  7. } book;

在一般情况下,tag、member-list、variable-list 这 3 部分至少要出现 2 个。以下为实例:


  
  1. //此声明声明了拥有3个成员的结构体,分别为整型的a,字符型的b和双精度的c
  2. //同时又声明了结构体变量s1
  3. //这个结构体并没有标明其标签
  4. struct
  5. {
  6. int a;
  7. char b;
  8. double c;
  9. } s1;
  10. //此声明声明了拥有3个成员的结构体,分别为整型的a,字符型的b和双精度的c
  11. //结构体的标签被命名为SIMPLE,没有声明变量
  12. struct SIMPLE
  13. {
  14. int a;
  15. char b;
  16. double c;
  17. };
  18. //用SIMPLE标签的结构体,另外声明了变量t1、t2、t3
  19. struct SIMPLE t1, t2[20], *t3;
  20. //也可以用typedef创建新类型
  21. typedef struct
  22. {
  23. int a;
  24. char b;
  25. double c;
  26. } Simple2;
  27. //现在可以用Simple2作为类型声明新的结构体变量
  28. Simple2 u1, u2[ 20], *u3;

访问结构成员

为了访问结构的成员,我们使用成员访问运算符(.)。成员访问运算符是结构变量名称和我们要访问的结构成员之间的一个句号。您可以使用 struct 关键字来定义结构类型的变量。下面的实例演示了结构的用法:


  
  1. #include <stdio.h>
  2. #include <string.h>
  3. struct Books
  4. {
  5. char title[ 50];
  6. char author[ 50];
  7. char subject[ 100];
  8. int book_id;
  9. };
  10. int main( )
  11. {
  12. struct Books Book1; /* 声明 Book1,类型为 Books */
  13. struct Books Book2; /* 声明 Book2,类型为 Books */
  14. /* Book1 详述 */
  15. strcpy( Book1.title, "C Programming");
  16. strcpy( Book1.author, "Nuha Ali");
  17. strcpy( Book1.subject, "C Programming Tutorial");
  18. Book1.book_id = 6495407;
  19. /* Book2 详述 */
  20. strcpy( Book2.title, "Telecom Billing");
  21. strcpy( Book2.author, "Zara Ali");
  22. strcpy( Book2.subject, "Telecom Billing Tutorial");
  23. Book2.book_id = 6495700;
  24. /* 输出 Book1 信息 */
  25. printf( "Book 1 title : %s\n", Book1.title);
  26. printf( "Book 1 author : %s\n", Book1.author);
  27. printf( "Book 1 subject : %s\n", Book1.subject);
  28. printf( "Book 1 book_id : %d\n", Book1.book_id);
  29. /* 输出 Book2 信息 */
  30. printf( "Book 2 title : %s\n", Book2.title);
  31. printf( "Book 2 author : %s\n", Book2.author);
  32. printf( "Book 2 subject : %s\n", Book2.subject);
  33. printf( "Book 2 book_id : %d\n", Book2.book_id);
  34. return 0;
  35. }

20.共用体

共用体是一种特殊的数据类型,允许您在相同的内存位置存储不同的数据类型。您可以定义一个带有多成员的共用体,但是任何时候只能有一个成员带有值。共用体提供了一种使用相同的内存位置的有效方式。


  
  1. #include <stdio.h>
  2. #include <string.h>
  3. union Data
  4. {
  5. int i;
  6. float f;
  7. char str[ 20];
  8. };
  9. int main( )
  10. {
  11. union Data data;
  12. printf( "Memory size occupied by data : %d\n", sizeof(data));
  13. return 0;
  14. }

21.指针


  
  1. #include <stdio.h>
  2. int main ()
  3. {
  4. int var = 20; /* 实际变量的声明 */
  5. int *ip; /* 指针变量的声明 */
  6. ip = &var; /* 在指针变量中存储 var 的地址 */
  7. printf( "Address of var variable: %p\n", &var );
  8. /* 在指针变量中存储的地址 */
  9. printf( "Address stored in ip variable: %p\n", ip );
  10. /* 使用指针访问值 */
  11. printf( "Value of *ip variable: %d\n", *ip );
  12. return 0;
  13. }

22.文件读写

写入文件


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. FILE *fp = NULL;
  5. fp = fopen( "/tmp/test.txt", "w+");
  6. fprintf(fp, "This is testing for fprintf...\n");
  7. fputs( "This is testing for fputs...\n", fp);
  8. fclose(fp);
  9. }

读取文件


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. FILE *fp = NULL;
  5. char buff[ 255];
  6. fp = fopen( "/tmp/test.txt", "r");
  7. fscanf(fp, "%s", buff);
  8. printf( "1: %s\n", buff );
  9. fgets(buff, 255, (FILE*)fp);
  10. printf( "2: %s\n", buff );
  11. fgets(buff, 255, (FILE*)fp);
  12. printf( "3: %s\n", buff );
  13. fclose(fp);
  14. }

23.排序算法

十大经典排序算法(动态演示+代码)

24.查找算法

九种查找算法

25.字符串操作

C语言与C++面试知识总结

26.面试知识

字符串操作的全面总结


转载:https://blog.csdn.net/weixin_41055260/article/details/109250035
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场