《C语言程序设计:问题与求解方法》——3.3节逐步求精的伪代码

3.3 逐步求精的伪代码
表示问题求解的算法有多种方法,其中最常用的是伪代码和流程图。流程图只适合解决规模较小的、比较简单的问题,虽然初学者易于理解和掌握,表达算法也比较清晰,但程序员和真正会编程者并不常使用这种方法—因为它不利于对算法的构思、修改和调整(仅适用于表达比较简单的算法),所以本书不作介绍。
本书将使用逐步求精的伪代码来表示算法。所谓伪代码没有严格的规范(所以也比较灵活),但其中有一些结构要素,可以用一些比较规范的方式来表述对问题的计算和处理流程。
一级算法只是解决问题的一个轮廓。对于某些复杂问题,只根据一级算法难以直接写出(C语言的)源程序。这时可对一级算法进一步细化(称为二级求精),将其中的某些步骤进一步扩展、细化,直到可以很容易写出(C语言)程序的语句时为止。
对于某些人是很显然的算法描述,对于其他人可能并不显而易见。因此,算法求精的过程和步骤是因人而异的。编程经验越丰富,算法求精的步骤就可能越少。不过,算法求精的步骤太少也不一定是好事。因为程序员的一个良好习惯,就是把伪代码表示的一级算法(算法复杂,还可以到二级求精),转变为源程序中的注释。注释太过简洁,会加大自己和别人阅读程序的难度。
逐步求精的伪代码的实质就是模仿人们在做一个大的任务时,首先将其粗分为几个一级任务,然后再分别考虑每个一级任务如何完成。不太明确的一级任务还要再细分为若干个二级任务,依此类推。
学习用伪代码来表达自己的编程思路和算法时,要通过大量阅读代码和练习来模仿、领悟,看的和模仿的算法多了,慢慢就掌握了。
【例题3.1】求三个数的和及平均值。(类型:必修题;趣味性:; 难度:
变量安排: 3个要输入的数用3个变量a1、a2、a3表示;三个数的和用1个变量sum表示;平均值用1个变量average表示;所有变量都用浮点类型定义。
伪代码的一级算法:
1 输入这三个数a1,a2,a3;
2 求这三个数的和sum及平均值average;
3 输出sum,average;
其中第二步由于不能直接转化成语句而需要进一步求精。根据求和及求平均值的以下两个代数式:
sum=a1+a2+a3
average=sum÷3
只需将其转化为赋值语句即可。
第2步的二级求精:

2.1   sum=a1+a2+a3;      /*求这三个数的和
2.2   average=sum/3.0;   /*求这三个数的平均值
转化成C语言程序如下:
/求三个数的和及平均值/
1  #include<stdio.h>
2  int  main(void)
3  {
4    float  a1,a2,a3 ; / 三个已知量,定义为浮点型变量/
5    float  sum,average; / 两个未知量,定义为浮点型变量/
6    /输入这三个数a1,a2,a3/
7    printf("请输入3个数,3个数之间用空格隔开\n");
8    scanf("%f%f%f",&a1,&a2,&a3);
9
10   /求这三个数的和sum及平均值average/
11   sum = a1 + a2 + a3 ;
12   average = sum / 3.0 ;
13
14   /输出sum,average/
15   printf("三数之和=%f ,平均值=%f \n",sum,average);
16   return  0;
17  }

注意:运行此程序时,用键盘输入三个数据给变量a1,a2,a3时,三个数据之间要用空格隔开。输完后,按下回车键,程序才会继续运行。
【练习】输入两个数,求两数的平方和。
提示:将伪代码形式的一级算法(有时还包括二级求精)转变为程序中的注释,可增加程序的可读性。这是一种良好的编程习惯。
【例题3.2】鸡兔同笼问题。已知鸡和兔的总头数和总脚数,求鸡有多少只,兔有多少只。(类型:必修题;趣味性:*;难度:
伪代码的一级算法:
1 输入总头数heads,总脚数feet
2 求鸡的只数chicken和兔的只数rabbit
3 输出变量chicken和rabbit的值
其中只有第2步需要求精。根据二元一次方程组,可知四个变量heads、feet、chicken、rabbit之间的关系为

heads=chicken+rabbit
feet=2×chicken+4×rabbit
解此方程组,可得到以下两个公式:
chicken=(4×heads-feet)/2
rabbit=(feet-2×heads)/2

将此公式转化为赋值语句,考虑到输入的总头数和总脚数不一定能得到整数解,因此将变量chicken(表示鸡的只数)、rabbit(表示兔的只数)定义为float 型变量。
二级求精如下:

2.1  chicken=(4*heads-feet)/2.0
2.2  rabbit=(feet-2*heads)/2.0
转化为C语言程序如下:
1  #include<stdio.h>
2  int main(void)
3   {
4    int  heads,feet;
5    float  chicken,rabbit;
6    /输入总头数heads,总脚数feet/
7
8    printf("请输入总头数和总脚数,两数间用空格隔开\n");
9    scanf("%d%d",&heads,&feet);
10
11   / 求鸡的只数chicken和兔的只数rabbit /
12
13   chicken=(4.0*heads-feet)/2.0;
14   rabbit=(feet-2.0*heads)/2.0;
15   /*输出变量chicken和rabbit的值
16
17  printf("鸡的只数为:%f只,兔的只数为:%f只 \n ",chicken,rabbit);
18  return  0;
19  }
【问题】如果不解方程组,而直接将其转变为赋值语句,也就是用
heads=chicken+rabbit;
feet=2chicken+4rabbit;

取代第13行和第14行,结果会如何?
答:赋值语句右边的表达式中出现的变量,必须是已经初始化了的变量。赋值语句是用赋值号右边的表达式求出的值,存放到赋值号左边的变量表示的存储单元中。所以,这两句是不正确的,但大多数编译程序不会报告出这类错误。程序运行时,会取用内存单元中变量chicken和rabbit中的不确定的值(垃圾数据)参与运算。经过运算得到两个错误数值,去改变变量heads和feet的原来正确值。
换言之,数学中的方程式不能直接转变为赋值语句,只有公式才可以直接转变为赋值语句(所谓公式,是等号左边为一个要求值的变量,等号右边是一个数学代数式,数学代数式中出现的变量的值都是已知的)。

时间: 2024-10-29 08:07:51

《C语言程序设计:问题与求解方法》——3.3节逐步求精的伪代码的相关文章

《C语言程序设计:问题与求解方法》——导读

目 录 第0章 "理想厨房"的工作原理0.1 理想厨房系统0.2 理想厨房系统的一个炒菜实例0.3 "理想厨房"工作的重要特点0.4 理想厨房系统与计算机系统术语对照表本章习题第1章 计算机的基本工作原理1.1 二进制简介1.2 计算机系统1.3 提高部分本章习题第2章 C语言程序结构和基本语法要素2.1 高级程序设计语言和编译程序简介2.2 C语言历史概述2.3 C语言源程序的主要构成成分:函数定义2.4 C语言源程序的次要组成成分:编译预处理命令.注释和声明2.

C++实现二叉树遍历序列的求解方法_C 语言

本文详细讲述了C++实现二叉树遍历序列的求解方法,对于数据结构与算法的学习有着很好的参考借鉴价值.具体分析如下: 一.由遍历序列构造二叉树              如上图所示为一个二叉树,可知它的遍历序列分别为:                       先序遍历:ABDECFG                       中序遍历:DBEAFCG                       后序遍历:DEBFGCA 我们需要知道的是,由二叉树的先序序列和中序序列可以唯一地确定一棵二叉树:由

c语言-请问怎么学好《C语言程序设计教程》

问题描述 请问怎么学好<C语言程序设计教程> 这本书下学期就要学了,可是看着迷迷糊糊,看不懂,有没有什么学习的捷径?什么配套的辅导书比较好?谢谢! 解决方案 简单来说,就是Reading+Coding. 阅读入门可以从谭浩强的<C程序设计>开始,国人所写比较符合我们的思维习惯,但是过于基础,许多细节问题没有讲到,所以看完那本可以接着看看<C语言深度解剖>. 另外还有两本国外的C语言经典著作<C程序设计语言><数据结构与算法分析--C语言描述>,可

C语言学习教程第三章-C语言程序设计初步(1)

C语言程序设计 本课介绍C语言程序设计的基本方法和基本的程序语句.从程序流程的角度来看,程序可以分为三种基本结构, 即顺序结构.分支结构.循环结构. 这三种基本结构可以组成所有的各种复杂程序.C语言提供了多种语句来实现这些程序结构. 本章介绍这些基本语句及其应用,使读者对C程序有一个初步的认识, 为后面各章的学习打下基础. C程序的语句 C程序的执行部分是由语句组成的. 程序的功能也是由执行语句实现的.C语句可分为以下五类:1.表达式语句2.函数调用语句3.控制语句4.复合语句5.空语句 1.表

《C语言程序设计与实践(第2版)》——导读

前言 C语言程序设计是一门理论与工程实践密切相关的专业基础课程,在计算机学科教学中具有十分重要的地位.大力加强该课程的建设,提高该课程的教学质量,有利于教学改革和教育创新,有利于创新人才的培养.通过本课程的学习,学生应培养良好的编程风格,掌握常见的算法思路,真正提高运用C语言编写程序解决实际问题的综合能力,为后续课程的实践环节打好基础. 目前国内关于C语言的教材较多,有些教材语法知识介绍细致,较适合作为非专业的等级考试类教学用书:有些教材起点较高,内容深奥,不适于初学者.为了帮助广大学生更好地掌

《C语言程序设计与实践(第2版)》——1.2 计算机与程序设计

1.2 计算机与程序设计 计算机的功能非常强大,能做非常复杂.人脑难以胜任的许多工作.然而,从电子市场买回CPU.主板.内存.硬盘等硬件并组装好一台计算机后,你却发现这台计算机什么也做不了.究其原因,就是因为该计算机上还没有安装任何计算机程序,即软件.硬件是计算机拥有强大功能的前提条件,但是如果没有"大脑"(也就是计算机程序)去指挥它,它将什么也做不了,所以计算机程序的存在是计算机能够工作.能够按指定要求工作的必要条件.因此,计算机程序(Program,通常简称程序)可以简单理解为人们

《C语言程序设计进阶教程》一导读

前 言 为什么要写这本书 本文讲的是C语言程序设计进阶教程一导读,市面上有成百上千种关于编程的书籍,其中有很多都是关于C语言编程的,那么为什么我还要写这本书呢?为什么建议你花时间读它呢?这本书跟其他书有什么不同呢?跟很多作者一样,我写这本书是因为我觉得有必要,觉得这本书中的方法比其他书中的更好. 我将现在已有的关于编程的书分为两类:入门和进阶.入门类书是给初学者写的,一般都假设读者没有编程基础,所以主要是介绍基本的概念.通常以"Hello World!"程序开始,也就是将"H

c语言-求大侠帮忙:C语言程序设计---编程题(以下所有题目程序应是非递归的)

问题描述 求大侠帮忙:C语言程序设计---编程题(以下所有题目程序应是非递归的) 编写一个函数insert(s1,s2,ch),实现在字符串s1中的指定字符ch位置处插入字符串s2. 学校工会组织活动,要求有8名教师参加,这8名教师将分别从A学院3名教师.B学院5名教师.C学院6名教师中任意抽取,且其中必须有B学院的教师参加,请编程输出所有可能的方案 已知在C盘根目录下存有文本文件"file1.txt",编程统计文件"file1.txt"中每个字母字符和每个数字字符

Go语言中普通函数与方法的区别分析_Golang

本文实例分析了Go语言中普通函数与方法的区别.分享给大家供大家参考.具体分析如下: 1.对于普通函数,接收者为值类型时,不能将指针类型的数据直接传递,反之亦然. 2.对于方法(如struct的方法),接收者为值类型时,可以直接用指针类型的变量调用方法,反过来同样也可以. 以下为简单示例: 复制代码 代码如下: package structTest    //普通函数与方法的区别(在接收者分别为值类型和指针类型的时候)  //Date:2014-4-3 10:00:07    import (