《C语言程序设计基础及进阶教程》PDF下载

  • 购买积分:12 如何计算积分?
  • 作  者:甘勇,金保华主编
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2010
  • ISBN:9787302237884
  • 页数:331 页
图书介绍:本书共12章,详细介绍了C语言基础知识、计算机程序设计基本方法和优化思路等内容。

上篇 基础篇 3

第1章 C语言概述 3

1.1 C语言的发展及特点 3

1.1.1 程序设计语言 3

1.1.2 C语言的发展 4

1.1.3 C语言的特点 5

1.2 C程序的组成 5

1.3 C语言的基本语法单位 8

1.4 C程序的开发步骤 9

习题 10

第2章 数据类型、运算符和表达式 11

2.1 数据类型 11

2.1.1 C的数据类型 11

2.1.2 数值型数据的表示与存储形式 12

2.1.3 C字符型数据的表示和存储形式 12

2.1.4 基本类型的名字和长度 12

2.2 常量和变量 14

2.2.1 常量的表示 14

2.2.2 符号常量 19

2.2.3 变量说明 20

2.3 运算符和表达式 21

2.3.1 算术运算 22

2.3.2 关系运算 23

2.3.3 逻辑运算 24

2.3.4 自增自减 25

2.3.5 位运算 26

2.3.6 赋值运算 28

2.3.7 条件运算 30

2.3.8 顺序求值运算 31

2.4 数据类型转换 32

2.4.1 类型转换的规则 32

2.4.2 类型转换的方法 33

习题 35

第3章 简单的C程序设计 38

3.1 C语句 38

3.1.1 C语句分类 38

3.1.2 表达式语句 38

3.1.3 C的语句概述 39

3.2 标准的文件输入输出函数 39

3.2.1 字符输入输出函数 39

3.2.2 格式化输出函数 40

3.2.3 格式化输入函数 43

3.3 简单程序设计举例 49

习题 50

第4章 C语言流程控制 52

4.1 复合语句 52

4.2 选择结构 53

4.2.1 if语句的嵌套 56

4.2.2 switch语句 57

4.3 循环结构 59

4.3.1 while语句 59

4.3.2 do…while语句 62

4.3.3 for语句 63

4.3.4 多重循环 65

4.3.5 流程转移语句 67

4.3.6 循环结构程序设计应用 71

习题 75

第5章 数组 77

5.1 一维数组 77

5.1.1 一维数组的定义 77

5.1.2 一维数组元素的引用 78

5.1.3 一维数组的初始化 79

5.1.4 一维数组的运算 79

5.2 二维数组 83

5.2.1 二维数组的说明、引用和存储结构 83

5.2.2 二维数组的初始化 84

5.2.3 二维数组的运算 85

5.3 字符数组与字符串数组 87

5.3.1 字符数组的定义和引用 87

5.3.2 字符数组的初始化 88

5.3.3 常用字符串处理函数 88

5.3.4 字符串数组 91

习题 92

第6章 函数与程序结构 93

6.1 C程序的一般结构 93

6.2 函数定义和函数声明 94

6.2.1 函数定义 94

6.2.2 函数原型声明 96

6.2.3 函数调用 97

6.2.4 参数传递 98

6.2.5 参数数目可变的函数 99

6.3 变量与存储类型 99

6.3.1 局部变量和全局变量 99

6.3.2 变量生命周期 101

6.3.3 存储类型区分符 101

6.4 递归函数 103

6.4.1 递归函数概念 103

6.4.2 递归程序设计 104

6.5 编译预处理 105

6.5.1 宏替换 105

6.5.2 文件包含 107

6.5.3 条件编译 108

习题 110

第7章 指针 112

7.1 指针的概念 112

7.1.1 变量的地址和指针变量 112

7.1.2 指针说明和指针对象的引用 113

7.2 指针参数 117

7.3 数组的指针表示 120

7.3.1 一维数组的指针表示 120

7.3.2 数组作函数参数时的指针表示 123

7.3.3 字符数组的指针表示 126

7.3.4 多维数组的指针表示与指向数组的指针 129

7.4 指针数组 133

7.4.1 指针数组的概念 133

7.4.2 指针变量的指针 135

7.4.3 main函数的参数 136

7.5 函数的指针 138

7.6 指针函数 139

7.7 指针相关运算 141

7.8 程序举例 143

习题 146

第8章 结构体、共用体和枚举类型 148

8.1 结构体 148

8.1.1 结构体的概念 148

8.1.2 结构体变量的定义 149

8.1.3 结构体变量的初始化和引用 152

8.1.4 结构体数组 154

8.1.5 指向结构体数据的指针 158

8.2 链表 161

8.2.1 链表的概念 161

8.2.2 链表与动态存储 162

8.2.3 链表的建立 163

8.2.4 对链表的操作 164

8.3 共用体 167

8.3.1 共用体变量的定义 167

8.3.2 共用体变量的引用 169

8.4 枚举类型和自定义类型 170

8.4.1 枚举类型 170

8.4.2 自定义类型 171

习题 173

第9章 输入输出与低层接口 176

9.1 文件概述 176

9.1.1 文件的概念 176

9.1.2 C文件的分类 177

9.1.3 缓冲文件系统 178

9.1.4 文件类型指针 178

9.1.5 文件的处理过程 179

9.2 文件的打开与关闭 179

9.2.1 文件的打开(fopen函数) 180

9.2.2 以重定向方式打开文件 181

9.2.3 文件的关闭(fclose函数) 181

9.3 文件的读写 182

9.3.1 字符读写函数(fgetc和fputc) 182

9.3.2 字符串读写函数(fgets和fputs) 185

9.3.3 读写数据块函数(fread和fwrite) 188

9.3.4 格式化读写函数(fscanf和fprintf) 191

9.4 文件的定位及随机读写 193

9.4.1 文件的定位 194

9.4.2 文件的随机读写 194

9.5 文件的出错检测 196

习题 198

中篇 常用算法篇 205

第10章 常用程序设计方法 205

10.1 筛选法求素数及素数应用 205

10.1.1 筛选法求素数 205

10.1.2 素数表的应用 207

10.2 模拟 208

10.3 递推 212

10.4 分治与递归 215

10.5 贪心算法 219

习题 223

下篇 综合案例篇 227

第11章 图书管理系统 227

11.1 系统需求分析 227

11.2 系统总体设计 230

11.3 函数设计 231

11.4 参考代码 236

11.5 运行测试 254

11.6 增加功能 257

11.7 关键技术剖析 258

11.8 导师点评 258

11.9 思考题 259

第12章 工资管理系统 260

12.1 系统需求分析 260

12.2 系统总体设计 262

12.3 函数设计 264

12.4 参考代码 271

12.5 运行测试 303

12.6 增加功能 310

12.7 关键技术剖析 311

12.8 导师点评 312

12.9 思考题 312

附录A 常用字符与ASCII码 313

附录B ANSI C关键字 314

附录C ANSI C运算符的优先级与结合性 316

附录D ANSI C中常用的标准库函数 318

附录E 常用的键盘按键的扫描码 323

附录F 常用的DOS和BIOS系统中断调用 327