第1章 C语言程序设计概述 1
1.1 程序和程序设计的基本概念 1
1.2 算法与程序设计 2
1.2.1 算法的基本特征 2
1.2.2 算法的基本要素 3
1.2.3 算法描述的方法 4
1.2.4 程序设计 5
1.3 C语言简介 7
1.3.1 C语言的发展历史 7
1.3.2 C语言的特点 8
1.3.3 C语言程序的基本结构及书写规则 9
1.3.4 C语言的基本标识符 11
习题 12
第2章 数据类型、运算符与表达式 14
2.1 C语言的数据类型 14
2.2 整型常量与变量 14
2.2.1 常量与变量的概念 14
2.2.2 整型常量 15
2.2.3 整型变量 15
2.3 实型常量与变量 17
2.3.1 实型常量 17
2.3.2 实型变量 17
2.4 字符型常量与变量 19
2.4.1 字符常量 19
2.4.2 字符串常量 20
2.4.3 符号常量 21
2.4.4 字符型变量 21
2.5 赋值运算符和赋值表达式 22
2.6 算术运算符和算术表达式 24
2.6.1 C语言运算符简介 24
2.6.2 基本算术运算符和算术表达式 24
2.6.3 复合赋值运算符及表达式 25
2.6.4 各类数值型数据之间的混合运算 26
2.6.5 自增与自减运算符 28
2.7 逗号运算符和逗号表达式 29
2.8 位运算符 30
2.8.1 位运算符和位运算介绍 30
2.8.2 位运算赋值运算符 34
2.9 变量的地址和指针型变量 34
2.9.1 变量的地址和指针型变量的概念 34
2.9.2 指针型变量的定义和指针变量的基类型 35
2.9.3 给指针变量赋值 36
2.9.4 对指针变量的操作 37
习题 39
第3章 顺序结构程序设计 43
3.1 C语句概述 43
3.2 数据的输入/输出 45
3.2.1 字符输入/输出函数 46
3.2.2 格式输入/输出函数 47
3.3 程序举例 55
习题 57
第4章 分支结构程序设计 61
4.1 关系运算符和关系表达式 61
4.1.1 关系运算符 61
4.1.2 关系表达式 62
4.2 逻辑运算符和逻辑表达式 63
4.2.1 逻辑运算符 63
4.2.2 逻辑表达式 64
4.3 if语句以及用if语句构成的分支结构 64
4.3.1 if语句的两种基本形式 65
4.3.2 嵌套的if语句 67
4.3.3 条件表达式构成的分支结构 70
4.4 switch语句 71
4.4.1 switch语句及用switch语句构成的分支结构 71
4.4.2 在switch语句体中使用break语句 73
4.5 程序举例 74
习题 76
第5章 循环结构程序设计 80
5.1 while语句以及用while语句构成的循环结构 80
5.1.1 while循环的一般形式 80
5.1.2 while循环的执行过程 81
5.2 do-while语句以及用do-while语句构成的循环结构 83
5.2.1 do-while语句构成的循环结构 83
5.2.2 do-while循环的执行过程 83
5.3 for语句以及用for语句构成的循环结构 86
5.3.1 for语句构成的循环结构 86
5.3.2 for循环的执行过程 86
5.3.3 有关for语句的说明 87
5.4 break语句和continue语句在循环结构中的应用 90
5.4.1 break语句 90
5.4.2 continue语句 90
5.5 循环的嵌套 91
5.6 三种循环的比较 94
5.7 程序举例 94
习题 97
第6章 数组与指针 103
6.1 一维数组 103
6.1.1 一维数组的定义 103
6.1.2 一维数组元素的引用 104
6.1.3 一维数组的初始化 107
6.1.4 一维数组程序举例 107
6.2 二维数组 111
6.2.1 二维数组的定义 111
6.2.2 二维数组元素的引用 111
6.2.3 二维数组的初始化 113
6.2.4 二维数组程序举例 114
6.3 字符数组和字符串 118
6.3.1 字符数组 118
6.3.2 字符串 118
6.3.3 字符串的输入输出 120
6.3.4 字符串处理函数 121
6.3.5 程序举例 124
6.4 数组和指针 126
6.4.1 一维数组和指针 126
6.4.2 二维数组的地址 130
6.4.3 指向二维数组的指针变量 131
6.4.4 指针数组的定义和应用 133
6.5 字符串和指针 135
6.5.1 单个字符串的处理方法 135
6.5.2 多个字符串的处理方法 137
6.5.3 字符串程序举例 139
6.6 指向指针的指针 142
习题 145
第7章 函数与指针 147
7.1 概述 147
7.2 函数的定义 147
7.3 函数的参数和函数的值 149
7.3.1 形式参数和实际参数 149
7.3.2 函数的返回值 151
7.4 函数的调用 152
7.4.1 函数的简单调用 152
7.4.2 函数的嵌套调用 154
7.4.3 函数的递归调用 155
7.5 函数与指针 160
7.5.1 指针变量作为函数参数 160
7.5.2 数组作为函数参数 160
7.5.3 返回指针值的函数 163
7.5.4 指向函数的指针 164
7.6 有关指针的数据类型和指针运算的小结 166
7.6.1 有关指针的数据类型的小结 166
7.6.2 指针运算的小结 166
7.6.3 void指针类型 167
7.7 变量的作用域 167
7.7.1 局部变量 167
7.7.2 全局变量 168
7.8 变量的存储类别 170
7.8.1 动态存储方式与静态存储方式 170
7.8.2 auto变量 171
7.8.3 用static声明局部变量 171
7.8.4 register变量 172
7.8.5 用extern声明外部变量 173
习题 173
第8章 编译预处理 183
8.1 宏定义 183
8.1.1 无参宏定义 183
8.1.2 带参宏定义 185
8.2 文件包含 188
习题 189
第9章 结构体与共用体 191
9.1 结构体类型的定义 191
9.2 结构体类型变量 193
9.2.1 结构体变量的定义 193
9.2.2 结构体变量的引用 194
9.2.3 结构体变量的初始化 196
9.2.4 结构体变量的输入与输出 196
9.3 结构体类型数组 197
9.3.1 结构体数组的定义 197
9.3.2 结构体数组的初始化 198
9.3.3 结构体数组的引用 198
9.4 结构体类型指针 200
9.4.1 指向结构体变量的指针 200
9.4.2 指向结构体数组的指针 202
9.5 结构体与函数 203
9.5.1 结构体变量作为函数参数 203
9.5.2 指向结构体变量的指针作为函数参数 204
9.5.3 函数的返回值为结构体类型 206
9.6 链表 208
9.6.1 链表概述 208
9.6.2 处理动态链表所需的函数 210
9.6.3 链表的基本操作 211
9.7 共用体 220
9.7.1 共用体类型与共用体变量 220
9.7.2 共用体变量的引用 221
9.7.3 共用体变量的应用 223
9.8 枚举类型 224
9.9 用typedef定义类型 227
习题 228
第10章 文件 231
10.1 文件概述 231
10.1.1 数据文件 231
10.1.2 文件的存取方式 232
10.1.3 文件指针类型 232
10.1.4 文件操作的步骤 232
10.2 文件的打开与关闭 233
10.2.1 文件的打开(fopen函数) 233
10.2.2 文件的关闭(fclose函数) 235
10.3 文件的读写 235
10.3.1 字符读写函数fgetc和fputc 235
10.3.2 字符串读写函数fgets和fputs 237
10.3.3 数据块读写函数fread和fwrite 239
10.3.4 格式化读写函数fscanf和fprintf 240
10.4 文件的随机读写 241
10.4.1 文件定位 241
10.4.2 文件的随机读写函数 242
10.5 文件检测函数 243
习题 243
附录 245
附录Ⅰ 常用字符与ASCⅡ码对照表 245
附录Ⅱ C99标准的新特性 246
附录Ⅲ Turbo C常用标准库函数 247
参考文献 261