第1篇 基础知识 3
第1章 C语言概述 3
1.1 C语言的发展史 4
1.1.1 程序语言简述 4
1.1.2 C语言的历史 4
1.2 C语言的特点 5
1.3 一个简单的C程序 6
1.4 一个完整的C程序 8
1.5 C语言程序的格式 12
1.6 开发环境 13
1.6.1 Turbo C 2.0 13
1.6.2 Visual C++++6.0 17
1.7 小结 22
第2章 算法 23
2.1 算法的基本概念 24
2.1.1 算法的特性 24
2.1.2 算法的优劣 25
2.2 算法的描述 25
2.2.1 自然语言 25
2.2.2 流程图 26
2.2.3 N-S流程图 29
2.3 小结 32
第3章 数据类型 33
3.1 编程规范 34
3.2 关键字 35
3.3 标识符 35
3.4 数据类型 36
3.5 常量 37
3.5.1 整型常量 38
3.5.2 实型常量 40
3.5.3 字符型常量 41
3.5.4 转义字符 43
3.5.5 符号常量 44
3.6 变量 45
3.6.1 整型变量 45
3.6.2 实型变量 47
3.6.3 字符型变量 50
3.7 变量的存储类别 51
3.7.1 动态存储与静态存储 51
3.7.2 auto变量 52
3.7.3 static变量 52
3.7.4 register变量 53
3.7.5 extern变量 54
3.8 混合运算 55
3.9 小结 56
3.10 实践与练习 56
第4章 运算符与表达式 57
4.1 表达式 58
4.2 赋值运算符与赋值表达式 60
4.2.1 变量赋初值 60
4.2.2 自动类型转换 62
4.2.3 强制类型转换 62
4.3 算术运算符与算术表达式 63
4.3.1 算术运算符 63
4.3.2 算术表达式 64
4.3.3 优先级与结合性 65
4.3.4 自增/自减运算符 67
4.4 关系运算符与关系表达式 69
4.4.1 关系运算符 69
4.4.2 关系表达式 69
4.4.3 优先级与结合性 70
4.5 逻辑运算符与逻辑表达式 71
4.5.1 逻辑运算符 72
4.5.2 逻辑表达式 72
4.5.3 优先级与结合性 72
4.6 位逻辑运算符与位逻辑表达式 73
4.6.1 位逻辑运算符 74
4.6.2 位逻辑表达式 74
4.7 逗号运算符与逗号表达式 74
4.8 复合赋值运算符 76
4.9 小结 77
4.10 实践与练习 77
第5章 常用的数据输入/输出函数 79
5.1 语句 80
5.2 字符数据输入/输出 80
5.2.1 字符数据输出 80
5.2.2 字符数据输入 81
5.3 字符串输入/输出 83
5.3.1 字符串输出函数 83
5.3.2 字符串输入函数 85
5.4 格式输出函数 85
5.5 格式输入函数 88
5.6 顺序程序设计应用 92
5.7 小结 93
5.8 实践与练习 94
第6章 选择结构程序设计 95
6.1 if语句 96
6.2 if语句的基本形式 96
6.2.1 if语句形式 96
6.2.2 if...else语句形式 99
6.2.3 else if语句形式 103
6.3 if的嵌套形式 106
6.4 条件运算符 109
6.5 switch语句 110
6.5.1 switch语句的基本形式 111
6.5.2 多路开关模式的switch语句 114
6.6 if...else语句和switch语句的区别 116
6.7 选择结构程序应用 118
6.8 小结 120
6.9 实践与练习 120
第7章 循环控制 121
7.1 循环语句 122
7.2 while语句 122
7.3 do-while语句 125
7.4 for语句 127
7.4.1 for语句使用 127
7.4.2 for循环的变体 130
7.4.3 for语句中的逗号应用 132
7.5 3种循环语句的比较 133
7.6 循环嵌套 134
7.6.1 循环嵌套的结构 134
7.6.2 循环嵌套实例 135
7.7 转移语句 137
7.7.1 goto语句 137
7.7.2 break语句 139
7.7.3 continue语句 140
7.8 小结 141
7.9 实践与练习 141
第2篇 核心技术 145
第8章 数组 145
8.1 一维数组 146
8.1.1 一维数组的定义和引用 146
8.1.2 一维数组初始化 148
8.1.3 一维数组应用 150
8.2 二维数组 151
8.2.1 二维数组的定义和引用 151
8.2.2 二维数组初始化 152
8.2.3 二维数组应用 155
8.3 字符数组 156
8.3.1 字符数组的定义和引用 157
8.3.2 字符数组初始化 157
8.3.3 字符数组的结束标志 159
8.3.4 字符数组的输入和输出 160
8.3.5 字符数组应用 161
8.4 多维数组 162
8.5 数组的排序算法 163
8.5.1 选择法排序 163
8.5.2 冒泡法排序 165
8.5.3 交换法排序 167
8.5.4 插入法排序 169
8.5.5 折半法排序 171
8.5.6 排序算法的比较 174
8.6 字符串处理函数 174
8.6.1 字符串复制 174
8.6.2 字符串连接 176
8.6.3 字符串比较 177
8.6.4 字符串大小写转换 179
8.6.5 获得字符串长度 180
8.7 数组应用 181
8.7.1 反转输出字符串 181
8.7.2 输出系统日期和时间 183
8.7.3 字符串的加密和解密 184
8.8 小结 186
8.9 实践与练习 186
第9章 函数 187
9.1 函数概述 188
9.2 函数的定义 190
9.2.1 函数定义的形式 191
9.2.2 定义与声明 192
9.3 返回语句 194
9.3.1 从函数返回 194
9.3.2 返回值 195
9.4 函数参数 197
9.4.1 形式参数与实际参数 197
9.4.2 数组作函数参数 199
9.4.3 main函数的参数 205
9.5 函数的调用 206
9.5.1 函数的调用方式 206
9.5.2 嵌套调用 209
9.5.3 递归调用 211
9.6 内部函数和外部函数 214
9.6.1 内部函数 214
9.6.2 外部函数 215
9.7 局部变量和全局变量 216
9.7.1 局部变量 217
9.7.2 全局变量 220
9.8 函数应用 221
9.9 小结 227
9.10 实践与练习 228
第10章 指针 229
10.1 指针相关概念 230
10.1.1 地址与指针 230
10.1.2 变量与指针 231
10.1.3 指针变量 231
10.1.4 指针自加自减运算 235
10.2 数组与指针 237
10.2.1 一维数组与指针 237
10.2.2 二维数组与指针 241
10.2.3 字符串与指针 244
10.2.4 字符串数组 246
10.3 指向指针的指针 247
10.4 指针变量作函数参数 250
10.5 返回指针值的函数 258
10.6 指针数组作main函数的参数 260
10.7 小结 262
10.8 实践与练习 262
第3篇 高级应用 265
第11章 结构体和共用体 265
11.1 结构体 266
11.1.1 结构体类型的概念 266
11.1.2 结构体变量的定义 267
11.1.3 结构体变量的引用 269
11.1.4 结构体类型的初始化 271
11.2 结构体数组 273
11.2.1 定义结构体数组 273
11.2.2 初始化结构体数组 275
11.3 结构体指针 277
11.3.1 指向结构体变量的指针 277
11.3.2 指向结构体数组的指针 280
11.3.3 结构体作为函数参数 282
11.4 包含结构的结构 284
11.5 链表 286
11.5.1 链表概述 286
11.5.2 创建动态链表 287
11.5.3 输出链表 290
11.6 链表相关操作 292
11.6.1 链表的插入操作 292
11.6.2 链表的删除操作 294
11.7 共用体 298
11.7.1 共用体的概念 298
11.7.2 共用体变量的引用 299
11.7.3 共用体变量的初始化 300
11.7.4 共用体类型的数据特点 301
11.8 枚举类型 301
11.9 小结 302
11.10 实践与练习 303
第12章 位运算 305
12.1 位与字节 306
12.2 位运算操作符 306
12.2.1 “与”运算符 306
12.2.2 “或”运算符 308
12.2.3 “取反”运算符 309
12.2.4 “异或”运算符 310
12.2.5 “左移”运算符 312
12.2.6 “右移”运算符 313
12.3 循环移位 315
12.4 位段 317
12.4.1 位段的概念与定义 317
12.4.2 位段相关说明 319
12.5 小结 320
12.6 实践与练习 320
第13章 预处理 321
13.1 宏定义 322
13.1.1 不带参数的宏定义 322
13.1.2 带参数的宏定义 323
13.2 #include指令 325
13.3 条件编译 327
13.3.1 #if命令 327
13.3.2 #ifdef及#ifndef命令 329
13.3.3 #undef命令 331
13.3.4 #line命令 331
13.3.5 #pragma命令 332
13.4 小结 333
13.5 实践与练习 333
第14章 文件 335
14.1 文件概述 336
14.2 文件基本操作 336
14.2.1 文件指针 336
14.2.2 文件的打开 337
14.2.3 文件的关闭 338
14.3 文件的读写 338
14.3.1 fputc函数 338
14.3.2 fgetc函数 339
14.3.3 fputs函数 340
14.3.4 fgets函数 341
14.3.5 fprintf函数 342
14.3.6 fscanf函数 343
14.3.7 fread和fwrite函数 344
14.4 文件的定位 346
14.4.1 fseek函数 346
14.4.2 rewind函数 348
14.4.3 ftell函数 349
14.5 小结 352
14.6 实践与练习 352
第15章 存储管理 353
15.1 内存组织方式 354
15.1.1 内存的组织方式 354
15.1.2 堆与栈 354
15.2 动态管理 356
15.2.1 malloc函数 356
15.2.2 calloc函数 357
15.2.3 realloc函数 358
15.2.4 free函数 359
15.3 内存丢失 360
15.4 小结 361
15.5 实践与练习 361
第16章 网络套接字编程 363
16.1 计算机网络基础 364
16.1.1 IP地址 364
16.1.2 OSI七层参考模型 364
16.1.3 地址解析 365
16.1.4 域名系统 366
16.1.5 TCP/IP协议 366
16.1.6 端口 368
16.1.7 套接字的引入 368
16.1.8 网络字节顺序 369
16.2 套接字概述 369
16.2.1 套接字概述 369
16.2.2 TCP的套接字的socket编程 369
16.2.3 UDP的套接字的socket编程 370
16.3 套接字函数 371
16.3.1 套接字函数介绍 371
16.3.2 基于TCP的网络聊天程序 376
16.4 小结 382
16.5 实践与练习 382
第4篇 项目实战 385
第17章 学生成绩管理系统 385
17.1 需求分析 386
17.2 系统设计 386
17.3 功能设计 387
17.3.1 功能选择界面 387
17.3.2 录入学生成绩信息 388
17.3.3 查询学生成绩信息 391
17.3.4 删除学生成绩信息 392
17.3.5 修改学生成绩信息 393
17.3.6 插入学生成绩信息 395
17.3.7 统计学生人数 397
17.4 小结 397
附录A ASCII表 399