第1章 C语言的基本概念 2
1.1 程序设计语言的发展历史 2
1.2 程序设计过程中的几个基本概念 3
1.3 软件工程的概念 5
1.4 C语言的发展与特点 6
1.4.1 C语言的发展和ANSI C标准 6
1.4.2 C语言的特点 7
1.5 C语言程序的基本字符集和标识符 8
1.6 一个简单的实例 9
1.7 C语言程序的编译和执行 10
习题1 11
第2章 C语言程序的基本数据类型及其运算 14
2.1 C语言的数据类型 14
2.1.1 数据类型的一般概念 14
2.1.2 基本数据类型 14
2.2 常量与变量的定义与应用 15
2.2.1 常量 15
2.2.2 变量及变量的定义 18
2.2.3 变量的初始化 19
2.3 数据类型转换 20
2.3.1 隐式类型转换 20
2.3.2 显式类型转换 22
2.4 运算符和表达式 23
2.4.1 运算符和表达式概述 23
2.4.2 赋值运算符和赋值表达式 25
2.4.3 算术运算符及算术表达式 26
2.4.4 关系运算符和关系表达式 27
2.4.5 逻辑运算符和逻辑表达式 28
2.4.6 条件运算符 29
2.4.7 其他运算符 30
2.5 C语言中的基本输入输出函数 31
2.5.1 字符输入输出函数 31
2.5.2 格式化输入输出函数 33
习题2 40
第3章 C语言程序基本控制结构及其应用 46
3.1 结构化程序设计方法 46
3.1.1 结构化程序设计思想 46
3.1.2 结构化程序设计的基本控制结构 46
3.1.3 结构化程序设计的注意事项 47
3.2 顺序结构程序设计 48
3.3 分支结构程序设计 50
3.3.1 if条件判断在程序设计中的应用 50
3.3.2 开关(switch)分支 55
3.4 循环结构程序设计 59
3.4.1 while语句 59
3.4.2 do-while语句 61
3.4.3 for语句 63
3.4.4 多重循环 65
3.4.5 循环和switch分支的中途退出 68
3.4.6 goto语句 70
习题3 71
第4章 数组及其应用 82
4.1 一维数组 82
4.1.1 一维数组的定义与初始化 82
4.1.2 一维数组的引用 84
4.2 多维数组 88
4.2.1 多维数组的定义及其在内存中的存储特点 88
4.2.2 多维数组的引用与初始化 90
4.2.3 多维数组的应用实例 92
4.3 字符型数组与字符串 98
4.3.1 字符型数组的初始化 98
4.3.2 字符型数组的输入输出 99
4.3.3 常用字符串处理函数 101
4.3.4 字符数组的应用实例 102
习题4 106
第5章 函数及其应用 114
5.1 函数的定义与调用 114
5.1.1 C语言程序的结构 114
5.1.2 函数的定义 115
5.1.3 函数的调用 117
5.2 函数间的信息传递方式 120
5.2.1 实参—形参之间的信息传递 120
5.2.2 函数调用结果的返回 123
5.3 函数与数组 126
5.3.1 数组元素作实参 126
5.3.2 一维数组名作实参 127
5.3.3 多维数组名作参数 128
5.3.4 字符数组作函数的参数 130
5.4 递归函数与递归调用 131
5.4.1 递归思想 131
5.4.2 递归函数与调用 131
5.4.3 递归程序设计 133
5.5 静态变量的应用及作用域 136
习题5 138
第6章 指 针 144
6.1 指针的基本概念及定义方式 144
6.1.1 指针的基本概念 144
6.1.2 指针的定义 145
6.1.3 指针的初始化 145
6.1.4 指针运算符 147
6.2 指针的运算 147
6.3 指针与数组 149
6.3.1 指向一维数组的指针 149
6.3.2 指向多维数组的指针 152
6.4 字符指针和字符串 153
6.5 指针数组 156
6.5.1 指针数组的概念 156
6.5.2 指针数组的应用 157
6.5.3 指针数组在带形参的main函数中的应用 158
6.6 指针在函数参数传递中的应用 159
6.7 指针型函数 160
6.7.1 指针型函数的定义和引用 160
6.7.2 指针型函数的应用 161
6.8 指向函数的指针 162
6.8.1 指向函数的指针的概念 162
6.8.2 指向函数的指针的应用 163
6.9 多级指针 167
6.9.1 多级指针的概念及定义 167
6.9.2 多级指针的应用 169
6.10 动态指针 169
6.10.1 动态内存分配的概念 169
6.10.2 动态内存分配的应用 172
习题6 173
第7章 排序与查找算法及其实现 180
7.1 排序概述 180
7.1.1 排序的概念 180
7.1.2 排序的定义 180
7.1.3 排序的方法 180
7.2 冒泡排序法的设计及其实现 181
7.2.1 冒泡排序法的设计思想 181
7.2.2 冒泡排序法的实现 181
7.3 选择排序法的设计及其实现 185
7.3.1 选择排序法的设计思想 185
7.3.2 选择排序法的实现 186
7.4 插入排序法的设计及其实现 187
7.4.1 插入排序法的设计思想 187
7.4.2 插入排序法的实现 188
7.5 SHELL排序法的设计及其实现 190
7.5.1 SHELL排序法的设计思想 190
7.5.2 SHELL排序法的实现 191
7.6 快速排序法的设计及其实现 193
7.6.1 快速排序法的设计思想 193
7.6.2 快速排序法的实现 194
7.6.3 用快速排序法实现字符串的排序 195
7.7 查找及其应用 197
7.7.1 顺序查找及其应用 197
7.7.2 折半查找及其应用 198
习题7 200
第8章 结构体、联合体和枚举 202
8.1 结构体的说明和定义 202
8.1.1 什么叫结构体 202
8.1.2 结构体的说明及结构体变量的定义与初始化 202
8.1.3 结构体成员的引用 206
8.2 结构体数组 208
8.2.1 结构体数组的定义及初始化 208
8.2.2 结构体数组的应用实例 209
8.3 结构体指针 210
8.3.1 结构体指针及其定义 210
8.3.2 通过指针引用结构体成员 211
8.3.3 结构体指针的应用实例 212
8.4 结构体在函数间的传递 213
8.4.1 结构体变量的传递 214
8.4.2 结构体数组在函数间的传递 217
8.5 结构体指针型和结构体型函数 219
8.5.1 结构体指针型函数 219
8.5.2 结构体型函数 221
8.6 结构体嵌套 223
8.6.1 什么是结构体嵌套 223
8.6.2 嵌套结构体类型变量的引用 224
8.6.3 结构体嵌套应用实例 225
8.7 联合体 227
8.7.1 联合体的说明及联合体变量的定义 227
8.7.2 使用联合体变量时应注意的问题 231
8.8 枚举类型 233
8.8.1 枚举类型数据的概念及其定义 233
8.8.2 枚举型变量的使用 234
8.9 自定义类型 237
8.9.1 自定义类型及其表示形式 237
8.9.2 自定义类型的优点 237
习题8 238
第9章 文件操作 244
9.1 文件概述 244
9.1.1 文件的概念 244
9.1.2 流和文件指针 245
9.2 文件的基本操作 246
9.2.1 文件的打开 246
9.2.2 文件的关闭 248
9.2.3 文件的删除 248
9.2.4 文件的重命名 248
9.2.5 临时文件的创建 249
9.3 文件的读写操作 250
9.3.1 文件的非格式化读写 250
9.3.2 文件的格式化写操作 258
9.3.3 文件的格式化读操作 260
9.4 文件的定位 261
9.4.1 ftell函数 262
9.4.2 fseek函数 262
9.4.3 feof函数 263
9.5 错误处理 264
9.5.1 ferror函数 264
9.5.2 perror函数 264
习题9 265
第10章 链表及其应用 272
10.1 线性表的基本概念 272
10.2 链表的基本操作 273
10.2.1 单链表的定义及其基本结构 274
10.2.2 单链表的创建 274
10.2.3 结点的查找 276
10.2.4 结点的插入操作 279
10.2.5 链表中结点的删除 282
10.3 链表的应用 284
习题10 289
附录 ASCII码表 293
参考文献 295