第1章 C语言概述 1
1.1 C语言的起源 1
1.2 C语言是中级语言 1
1.3 C语言是结构化语言 2
1.4 C语言是面向程序员的语言 3
1.5 编译和解释 4
1.6 C语言程序结构 5
1.6.1 库和链接 6
1.6.2 分别编译 7
1.6.3 编译C程序 7
1.6.4 C语言的内存映像 7
1.7 术语 7
1.8 上机指导 8
1.8.1 QC的支撑环境 8
1.8.2 QC的启动和退出 8
1.8.3 QC的窗口和菜单 8
1.8.4 QC的编辑键 11
1.8.5 QC的鼠标支持 12
1.8.6 QC程序的输入和运行 12
习题 13
第2章 基本数据类型 14
2.1 类型 14
2.2 保留字、标识符 15
2.2.1 单词 15
2.2.2 标识符 15
2.2.3 保留字 15
2.2.4 选择合适的标识符 16
2.2.5 常量与变量 16
2.3 基本数据类型 17
2.3.1 数据的内部表示 18
2.3.2 字符类型 19
2.3.3 整数类型 21
2.3.4 浮点类型和双精度类型 22
2.3.5 字符串常量 23
2.3.6 符号常量 24
2.4 运算符与表达式 25
2.4.1 表达式 25
2.4.2 算术运算符及算术表达式 25
2.4.3 关系运算符及关系运算表达式 27
2.4.4 逻辑运算符及逻辑表达式 27
2.4.5 赋值表达式 28
2.4.6 逗号表达式 28
2.4.7 表达式的运算顺序 28
2.4.8 条件运算 29
2.4.9 sizeof运算 29
2.4.10 运算符优先级与结合性质 30
2.5 类型之间的关系 31
2.5.1 隐式类型转换 31
2.5.2 强制类型转换 32
2.6 位运算 32
2.7 数组和指针 35
2.7.1 数组 35
2.7.2 指针 37
2.7.3 指针和数组的简单用法 39
2.8 一个简单的应用程序 41
本章小结 43
习题 43
第3章 结构化程序设计 45
3.1 顺序结构程序设计 45
3.1.1 赋值语句 45
3.1.2 数据输入 47
3.1.3 数据输出 50
3.2 选择结构程序设计 57
3.2.1 条件语句(if) 57
3.2.2 开关选择语句 62
3.2.3 goto语句 66
3.3 循环结构程序设计 67
3.3.1 三种循环结构的算法表示及执行过程 67
3.3.2 循环的嵌套结构 71
3.3.3 循环程序举例 72
3.3.4 循环辅助控制 80
本章小结 83
习题 83
第4章 函数 85
4.1 概述 85
4.2 C语言程序的结构 85
4.3 函数的定义和调用 86
4.3.1 函数的定义 86
4.3.2 函数的调用 87
4.4 变量的存储类别和变量的使用范围 89
4.4.1 变量的存储类别 89
4.4.2 变量的使用范围 91
4.4.3 小结 92
4.5 函数间的传值 93
4.6 函数的嵌套调用 96
4.7 函数的递归调用 97
4.7.1 递归函数及其执行特点 97
4.7.2 实现递归调用的两种结构 98
4.7.3 递归结构的函数用法举例 99
4.8 函数的应用举例 101
本章小结 104
习题 104
第5章 编译预处理 106
5.1 宏定义 106
5.1.1 不带参数的宏定义 106
5.1.2 带参数的宏定义 108
5.2 文件包含 109
5.3 条件编译 112
本章小结 114
习题 114
第6章 复合数据类型 115
6.1 指针类型 115
6.1.1 指针的声明 115
6.1.2 指针的引用 116
6.1.3 指针的运算 116
6.2 数组类型 118
6.2.1 一维数组的声明 118
6.2.2 一维数组元素的引用与初始化 119
6.2.3 数组作为函数的参数 120
6.2.4 二维数组的声明与使用 122
6.2.5 二维数组元素的引用与初始化 123
6.2.6 指针与数组 125
6.2.7 指针数组与数组指针 126
6.3 字符串 129
6.3.1 字符串常量与变量 129
6.3.2 字符串数组 131
6.3.3 有关字符串操作的系统库函数 133
6.3.4 字符串的用法举例 135
6.4 结构类型 137
6.4.1 结构类型 138
6.4.2 访问结构成员 140
6.4.3 结构指针和结构数组 141
6.4.4 结构指针作为函数的参数 147
6.4.5 结构类型及结构指针的应用举例 147
6.5 关于指针的另外几种用法 158
6.5.1 指向函数的指针 158
6.5.2 指针类型的函数 161
6.5.3 指向指针的指针(二级指针) 163
6.5.4 main函数的参数 164
6.6 位域、联合、枚举和类型别名 167
6.6.1 位域 167
6.6.2 联合类型 170
6.6.3 枚举类型 173
6.5.4 类型别名 174
本章小结 175
习题 175
第7章 文件及应用 179
7.1 C语言文件的概念 179
7.1.1 ANSI C的I/O和UNIX C的I/O 179
7.1.2 流和文件 179
7.1.3 C语言文件 182
7.2 文件系统的基础 182
7.2.1 定义文件结构类型的指针 183
7.2.2 用于文件操作的函数 184
7.3 建立文件的基本步骤 199
7.4 读取文件的基本步骤 201
7.5 非缓冲文件系统 202
7.5.1 open( ) 203
7.5.2 close( ) 203
7.5.3 creat( ) 204
7.5.4 read( )和write( ) 205
7.5.5 unlink( ) 206
7.5.6 lseek( ) 206
7.5.7 缓冲文件系统和非缓冲文件系统的区别 207
本章小结 207
习题 208
第8章 基本应用综合举例 209
8.1 数组元素的查找和排序 209
8.1.1 排序及应用 209
8.1.2 查找 214
8.2 数值积分 217
8.2.1 矩形法 218
8.2.2 梯形法 219
8.2.3 辛普生法 220
8.3 非线性方程的求根 222
8.3.1 牛顿迭代法 222
8.3.2 二分法 224
8.3.3 弦截法 225
8.4 C语言动态数据结构及其用法 226
8.4.1 动态存储分配 226
8.4.2 线性动态数据结构及链表的应用 227
8.4.3 非线性动态数据结构及二叉树的应用 238
8.5 文件的应用 237
8.5.1 用户数据文件的应用 237
8.5.2 用户文本文件的应用 238
参考文献 246