第1章 程序设计与C语言 1
1.1 初识C语言 1
1.1.1 最简单的C语言程序 1
1.1.2 简单C语言程序的基本结构 3
1.1.3 C语言程序的书写规范 3
1.2 设计简单的C语言程序 4
1.2.1 程序设计的方法和步骤 4
1.2.2 C语言程序的调试和运行 5
课外阅读 6
1.程序、程序设计、程序设计语言 6
2.程序设计语言的分类 6
3.C语言的特点 7
4.C语言的发展历史 7
5.怎样才能学好C语言 8
习题 9
第2章 算法 12
2.1 算法的概念 12
2.2 简单算法举例 12
2.3 算法的特性 16
2.4 算法的描述 17
课外阅读 20
1.什么是算法 20
2.常用算法的传统流程图和N-S流程图描述 21
习题 23
第3章 简单数据处理 24
3.1 C语言数据类型 24
3.1.1 整型数据 24
3.1.2 实型数据 25
3.1.3 字符数据 26
3.2 运算符和表达式 27
3.2.1 基本的算术运算符 27
3.2.2 自增自减运算符 28
3.2.3 赋值运算符 28
3.2.4 强制类型转换运算符 29
3.3 C语言语句 30
3.4 顺序结构程序设计 31
课外阅读 33
1.C语言数据类型 33
2.常量 34
3.变量 35
4.标识符 37
5.逗号运算符和逗号表达式 38
6.运算符的优先级和结合性 38
7.类型转换 38
8.数据的输入/输出 39
习题 43
第4章 选择结构程序设计 48
4.1 选择结构程序设计简介 48
4.2 if语句选择结构程序设计 48
4.2.1 单分支if语句 48
4.2.2 双分支if语句 49
4.2.3 多分支if语句 51
4.2.4 if语句的嵌套 53
4.3 用switch语句实现多分支选择结构 56
4.4 选择结构程序设计举例 59
课外阅读 64
1.关系运算符 64
2.关系表达式 64
3.逻辑运算符 64
4.逻辑表达式 65
5.条件运算符及条件表达式 66
习题 67
第5章 循环结构程序设计 72
5.1 循环结构程序设计简介 72
5.1.1 循环程序实例 72
5.1.2 循环结构概述 73
5.2 循环语句 74
5.2.1 用for语句实现循环 74
5.2.2 用while语句实现循环 77
5.2.3 用do…while语句实现循环 78
5.2.4 while语句与do…while语句的区别 79
5.3 循环的嵌套 79
5.4 break语句和continue语句 81
5.4.1 break语句 81
5.4.2 continue语句 82
5.5 循环结构程序设计举例 83
5.5.1 找最大值或最小值 84
5.5.2 累加或累乘问题 84
5.5.3 递推法求解问题 86
5.5.4 穷举法求解问题 89
5.5.5 求素数 90
5.5.6 输出特殊图案 91
课外阅读 94
3种循环语句的比较 94
习题 94
第6章 数组 99
6.1 一维数组 99
6.1.1 一维数组的定义 100
6.1.2 一维数组元素的引用 101
6.1.3 一维数组程序举例 103
6.2 二维数组 104
6.2.1 二维数组的定义 104
6.2.2 二维数组的初始化和元素引用 107
6.2.3 二维数组程序举例 108
6.3 字符数组 109
6.4 数组的应用 111
课外阅读 117
1.多维数组 117
2.字符串处理函数 118
习题 120
第7章 函数 125
7.1 函数的定义和调用 125
7.1.1 模块化程序设计基本思想 125
7.1.2 函数的定义 127
7.1.3 函数的调用 129
7.2 函数的参数与返回值 130
7.2.1 函数的参数 130
7.2.2 函数的返回值 132
7.3 函数的嵌套调用与递归调用 133
7.3.1 函数的嵌套调用 133
7.3.2 函数的递归调用 134
7.4 数组作为函数参数 138
7.4.1 数组元素作为函数实参 139
7.4.2 数组名作为函数参数 140
7.4.3 多维数组名作为函数参数 144
7.5 局部变量和全局变量 146
7.5.1 局部变量 146
7.5.2 全局变量 147
课外阅读 150
1.变量的存储方式和生存期 150
2.内部函数和外部函数 158
习题 161
第8章 指针 166
8.1 指针和指针变量 166
8.1.1 指针和指针变量的概念 166
8.1.2 指针变量的使用 167
8.1.3 指针变量作为函数参数 169
8.2 指针与数组 171
8.2.1 一维数组与指针 171
8.2.2 二维数组与指针 176
8.2.3 字符串与指针 180
8.3 指针数组和多级指针 185
8.3.1 指针数组 185
8.3.2 指向指针数据的指针(多级指针) 186
8.3.3 指针数组作为main()函数的形参 188
8.4 指针与函数 189
8.4.1 指针函数(返回指针值的函数) 189
8.4.2 函数指针(指向函数的指针) 190
8.5 指针的应用 192
课外阅读 194
1.零指针与空类型指针 194
2.动态内存分配 195
3.指针变量类型小结 196
习题 196
第9章 自定义数据类型 202
9.1 自定义和使用结构体类型 202
9.1.1 建立结构体类型 202
9.1.2 定义结构体类型变量 204
9.1.3 结构体变量的初始化和引用 205
9.2 使用结构体数组 209
9.2.1 定义结构体数组 209
9.2.2 结构体数组的应用举例 212
9.3 结构体指针 213
9.3.1 指向结构体变量的指针 214
9.3.2 指向结构体数组的指针 215
9.3.3 将结构体变量和结构体变量的指针作为函数参数 217
9.4 用指针处理链表 221
9.4.1 链表的定义 221
9.4.2 建立简单的静态链表 222
9.4.3 建立动态链表 224
9.4.4 输出链表 227
9.5 共用体类型 230
9.5.1 共用体类型的定义 230
9.5.2 引用共用体变量的方式 231
9.5.3 共用体类型数据的特点 231
9.6 使用枚举类型 235
课外阅读 239
用typedef声明类型别名 239
习题 242
第10章 文件 247
10.1 文件概述 247
10.2 文件的打开和关闭 249
10.2.1 文件的打开 249
10.2.2 文件的关闭 251
10.3 文件的顺序读写 252
10.3.1 以字符方式读写文件 252
10.3.2 以字符串方式读写文件 255
10.3.3 以格式化方式读写文件 258
10.3.4 以数据块方式读写文件 259
10.4 文件的随机读写 263
10.4.1 文件位置标记及其定位 263
10.4.2 随机读写 266
10.5 文件读写的出错检测 268
课外阅读 269
1.文件的定义 269
2.文件名 269
3.文件的分类 270
4.文件缓冲区 271
5.文件类型指针 271
习题 272
第11章 项目实战 276
11.1 信息管理系统设计 276
11.1.1 设计目的和要求 276
11.1.2 需求分析 276
11.1.3 系统设计 276
11.1.4 编码实现 277
11.2 项目实战选题 292
附录1 ASCII码表 294
附录2 C语言的关键字 295
附录3 运算符的优先级和结合性 296
附录4 位运算 298
附录5 编译预处理 302
附录6 C语言常用库函数 307
附录7 C语言常见出错信息 312
参考文献 316