微信扫码下载

内容简介

  《从问题到程序:程序设计与C语言引论》以c作为工具语言,讨论了基本程序设计的各方面内容,详细解释了与c语言和程序设计有关的问题。在新版中,特别加强了针对近年日益受到业界和学术界广泛重视的问题的讨论,并通过详细地分析和讨论大量符合c99标准的实例,给出了分析和分解问题、找出解决问题的主要步骤、确定函数抽象、找出循环、选择语言结构直至最后做出所需程序的完整过程。
    《从问题到程序:程序设计与C语言引论》适合作为高等院校计算机及相关专业一门程序设计课程的教材,也可供其他学习c程序设计的读者自学使用。

目录

前言
从问题到程序:程序设计与C语言引论(第2版)》中的编程实例和模式

第1章程序设计和c语言
1.1程序和程序语言
1.2c语言简介
1.3一个简单的c程序
1.4程序开发过程
1.5问题与程序设计
本章讨论的重要概念
练习

第2章数据与简单计算程序
2.1基本字符、标识符和关键字
2.2数据、类型和简单程序
2.2.1几个常用类型
2.2.2函数printf和简单文本输出程序
2.3运算符、表达式和计算
2.3.1算术运算符和算术表达式
2.3.2表达式的求值
2.3.3计算和类型
2.4数学函数和简单计算程序
2.4.1函数、函数调用
2.4.2数学函数及其使用
2.4.3函数调用中的类型转换
语言细节和问题
c语言的字符集
基本数据类型的一些问题
数据形式的转换和输出
运算对象的求值顺序
几个常用程序模式
本章讨论的重要概念
练习

第3章变量、函数和流程控制
3.1复合结构和顺序程序
3.2变量的概念和使用
3.2.1变量的定义
3.2.2变量的使用
3.2.3注释和简单顺序程序
3.3定义函数(初步)
3.3.1函数定义
3.3.2函数与程序
3.3.3函数与类型
3.3.4自定义输出函数
3.4关系表达式、条件表达式、逻辑表达式
3.4.1关系表达式和条件表达式
3.4.2逻辑表达式
3.5语句与控制结构
3.5.1条件语句:if语句
3.5.2循环语句:while语句
3.5.3循环语句:for语句
3.6若干c语言结构
3.6.1增量和减量运算符(++、--)
3.6.2逗号运算符
3.6.3实现二元运算符操作的赋值运算符
3.6.4空语句
3.6.5定义枚举常量
3.7输入和输出
3.7.1格式输入函数scanf
3.7.2字符输入和输出函?
语言细节和问题
变量的意义和实现
赋值操作的一些问题
条件表达式和条件语句
表达式和求值
输入和缓冲
几个常用程序模式
本章讨论的重要概念
练习

第4章基本编程技术
4.1循环程序设计
4.1.1基本循环方式
4.1.2求一系列完全平方数
4.1.3判断素数(谓词函数)
4.1.4艰难旅程(浮点误差)
4.1.5求立方根(迭代和逼近)
4.1.6求sin函数值(通项计算)
4.1.7从循环中退出
4.2输入循环
4.2.1输入循环的基本技术
4.2.2字符输入
4.2.3检查输入
4.2.4一个简单计算器
4.3循环与递归
4.3.1阶乘和乘幂(循环,递归)
4.3.2fibonacci序列(计算与时间)
4.3.3为计算过程计时
4.3.4fibonacci序列的迭代计算(程序正确性与循环不变式)
4.3.5最大公约数
4.3.6河内塔(梵塔)问题
4.4程序调试和排错
4.4.1测试
4.4.2白箱测试
4.4.3黑箱测试
4.4.4排除程序里的错误
语言细节和问题
程序的逐步求精和控制结构嵌套
循环中的几种变量
与输入输出有关的几个问题
输入与安全性
几个常用程序模式
本章讨论的重要概念
练习

第5章c程序结构
5.1数值类型
5.1.1字符类型
5.1.2整数类型
5.1.3基本数?类型的选择
5.2几种控制语句
5.2.1do-while循环结构
5.2.2流程控制语句
5.2.3开关语句
5.3一些标准库函数
5.3.1字符分类函数
5.3.2随机数生成函数
5.4程序的函数分解
5.4.1函数分解
5.4.2对函数的两种观点
5.4.3函数定义与调用之间的配合
5.4.4函数原型
5.4.5求函数的根
5.4.6一个简单猜数游戏
5.5c程序结构与变量
5.5.1外部定义的变量
5.5.2作用域、存在期和变量类
5.5.3变量的其他问题
5.6预处理
5.6.1文件包含命令
5.6.2宏定义与宏替换
5.6.3条件编译命令
5.6.4定义常量
5.6.5单词计数问题
5.7字位运算符
本章讨论的重要概念
练习

第6章顺序数据组织:数组
6.1数组的定义和使用
6.1.1数组变量的定义和声明
6.1.2数组的使用
6.1.3数组?初始化
6.1.4数组程序实例
6.1.5定义数组的问题
6.2以数组为参数的函数
6.2.1一个例子
6.2.2修改实参数组的元素
6.3二维和多维数组
6.3.1多维数组的初始化
6.3.2多维数组的使用
6.3.3多维数组作为函数的参数
6.4字符数组与字符串
6.4.1字符数组
6.4.2字符串
6.4.3程序实例
6.4.4标准库字符串处理函数
6.4.5输出文本里的最长行
6.5编程实例
6.5.1成绩直方图
6.5.2一个通用的带检查的整数输入函数
6.5.3“计算”数组变量的大小
6.5.4数组的划分
6.5.5数组的排序
6.5.6统计c程序里的关键字
语言细节和问题
数组的存储实现
越界访问的可能后果
多维数组的实现
函数参数与sizeof运算符
字符串的字典序
几个常用程序模式
本章讨论的重要概念
练习

第7章指针的应用
7.1指针的定义和使用
7.1.1指针的定义
7.1.2指针操作
7.1.3指针作为函数参数
7.1.4有关指针的几个问题
7.2指针与数组
7.2.1指向数组元素的指针
7.2.2基于指针运算的数组程序设计
7.2.3数组参数与指针
7.2.4指针与数组操作的程序实例
7.2.5字符指针与字符数组
7.2.6多维数组作为参数的通用函数
7.3指针数组
7.3.1字符指针数组
7.3.2指针数组与二维数组
7.3.3命令行参数及其处理
7.4动态存储管理
7.4.1c语言的动态存储管理机制
7.4.2两个程序实例
7.4.3函数、指针和动态存储
7.4.4定义类型
7.5指向函数的指针
7.5.1函数指针的定义和使用
7.5.2函数指针作为函数的参数
语言细节和问题
指针运算原理
指针转换
使用动态存储管理的要点和细节
动态调整策略
过时的函数指针形式
复杂类型描述与解读
几个常用程序模式
本章讨论的重要概念
练习

第8章文件和输入输出程序设计
8.1文件的概念
8.1.1流和文件指针
8.1.2缓冲式输入输出
8.2文件的使用
8.2.1文件的打开和关闭
8.2.2输入输出函数
8.2.3程序实例
8.2.4标准错误流
8.2.5直接输入输出函数
8.3标准流输入输出与格式控制
8.3.1行式输入?输出
8.3.2输入格式控制
8.3.3输出格式控制
8.3.4以字符串作为格式化输入输出对象
8.4程序实例
8.4.1求文件中数据的平均值
8.4.2一个背单词程序
8.4.3资金账目系统
几个常用程序模式
本章讨论的重要概念
练习

第9章结构和复杂数据组织
9.1结构
9.1.1结构声明与变量定义
9.1.2结构变量的初始化和使用
9.1.3结构、数组与指针
9.2枚举
9.3结构与函数
9.3.1处理结构的函数
9.3.2程序实例
9.4编程实例
9.4.1数据组的排序
9.4.2复数的表示和处理
9.5链接结构(自引用结构)
9.5.1链接结构
9.5.2自引用结构的定义
9.5.3程序实现
9.5.4数据与查找
语言细节和问题
结构的实现
联合
字段
本章讨论的重要概念
练习

第10章程序开发技术
10.1分别编译和c程序的分块开发
10.1.1分块开发的问题和方法
10.1.2程序实例:学生成绩处理
10.1.3分块重整
10.1.4其他安排和考虑
10.1.5模块化思想和技术
10.1.6单一头文件结构和多个头文件结构
10.2功能模块和程序库
10.2.1复数模块
10.2.2目标文件和库
10.2.3防止重复包含
10.3错误报告和处理
10.3.1建立统一的错误报告机制
10.3.2定义?参数的错误报告函数
10.3.3运行中错误的检查和处理
10.4程序的配置
10.4.1程序的行为参数和启动时配置
10.4.2交互式配置
10.4.3通过命令行参数
10.4.4采用配置文件
10.5程序开发过程
10.5.1自上而下的开发
10.5.2自下而上的开发
10.5.3实际开发过程
本章讨论的重要概念
练习

第11章标准库
11.1标准库结构
11.1.1标准定义([stddef.h])
11.1.2错误信息([errno.h])
11.1.3c99的几个头文件
11.2几个已经介绍过的头文件
11.3字符串函数([string.h])
11.3.1一些字符串函数
11.3.2存储区操作函数
11.4功能函数([stdlib.h])
11.4.1几个整数函数
11.4.2数值转换
11.4.3执行控制
11.4.4与执行环境交互
11.4.5常用函数bsearch和qsort
11.5日期和时间([time.h])
11.6实现特征([limit.h]和[float.h])
11.6.1整数类型特征
11.6.2浮点数类型特征
11.7其他与输入输出有关的函数([stdio.h])
11.7.1符号常量和类型
11.7.2文件操作函数
11.7.3流缓冲区操作函数
11.7.4文件定位及定位函数
11.7.5其他有关函数
11.7.6采用va_list参数的输出函数
11.8定义变长参数表([stdarg.h])
11.9非局部控制转移([setjmp.h])
11.10调试断言和信号处理([assert.h]和[signal.h])
11.11标准库的其他功能
11.11.1本地化
11.11.2多字节字符
本章讨论的重要概念
练习

第12章c99导引
12.1c99扩充
12.1.1语言层扩充
12.2c99数组和结构
12.2.1复合对象的初始化
12.2.2变长数组的定义和声明
12.2.3函数的变长数组参数
12.2.4结构的变长数组成员
12.3几个c99标准库包
12.3.1标准库包[stdint.h]和[inttype.h]
12.3.2标准库包[complex.h]

附录ac语言运算符表
附录bc语言速查
进一步学习的建议
参考文献


其他推荐