(结构化实例7.ppt

  1. 1、本文档共36页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(结构化实例7

第7章 模块化程序设计和软件工程 软件模块 数据对象及其相关处理算法 程序模块:数据结构及其相关函数 例 6-10 中的模块 主控模块:main函数负责单词统计算法 其他模块:wdRead、wdLook和wdPrint等函数 分别负责单词读取、单词记录、单词打印 信息隐蔽 模块的使用者无须了解实现细节 模块划分 按照功能:一个函数负责一个子功能 按照数据:处理某种数据的若干函数 例7-1:简易学生管理系统 任务: 分别输入学生的户籍信息和学籍信息,打印出学生基本信息表(假设学生人数 250人) 户籍信息:姓名、身份证号码、出生年月日、住址; 学籍信息:学号、身份证号码、所属学院、专业、班级 学生基本信息表:学号、姓名、年龄、所属学院、班级; 数据对象 学生户籍数据、学生学籍数据 学生基本信息表可以直接输出(不保存) 算法设计 输入户籍数据 (每行输入一个学生的数据,空格分割各个项目) 输入学籍数据 (每行输入一个学生的数据,空格分割各个项目) 构造并输出学生基本信息表 (提取户籍和学籍数据,构造并输出学生信息表) 算法的逐步求精 1、2 步 仅涉及输入输出,忽略算法描述 3 构造学生基本信息表 3.1 依次从户籍数据中取出一个学生的信息 3.2 根据其身份证号码,找出该生的学籍信息 3.3 综合该生的户籍信息和学籍信息,构造基本信息记录,填入学生基本信息表 3.4 重复 3.1-3.3 的处理,直至处理完所有学生的数据 程序结构设计 数据对象 户籍数据、学籍数据、学生基本信息表 尽可能符合信息的原始结构、采用struct 采用结构数组来保存数据 模块与函数的设计 围绕户籍数据,提供输入、依次提取的函数 围绕学籍数据,提供输入、查找的函数 为学生基本信息,提供构造并输出的函数 形成 3 个程序模块 程序结构 户籍处理模块的设计 #include #include typedef struct /* 户籍数据结构 */ char name[ 16 ]; /* 姓名 */ long no; /* 身份证号 */ struct int year, mon, day; /* 作为分量的结构 */ birthday; /* 生日 */ char addr[ 128 ]; /* 地址 */ InfoAddr; int InputAddr InfoAddr info[ ] ; /* 输入数据到数组info, 返回学生数量 */ 学籍处理模块的设计 typedef struct /* 学籍数据结构 */ char student[ 20 ]; /* 学号 */ long no; /* 身份证号 */ char college[ 32 ]; /* 学院 */ char class[ 10 ]; /* 班级 */ InfoStudent; int InputStudent InfoStudent info[ ] ; /* 输入数据到数组info, 返回学生数量 */ InfoStudent *GetStudent long no, InfoStudent info[ ], int n ; /* 获得身份证为no的学生的学籍数据, n是学生数量 */ 主控模块的设计 void Output int n, InfoAddr addr[ ], InfoStudent info[ ] ; /* 构造学生基本信息,按表格输出(n是学生人数) */ main static InfoAddr addr[ 256 ]; static InfoStudent stu[ 256 ]; int num; /* 人数 */ num InputAddr addr ; /* 输入户籍数据 */ if num ! InputStudent stu /* 输入学籍数据 */ return; Output num, addr, stu ; /* 输出基本信息表 */ 设计说明 函数原型设计 考虑函数内部功能的实现中,需要用到的所有输入输出信息; 将输入信息作为参数;输出结果作为返回值,或通过参数返回; 确保信息处理的局部化 实现技术细节 对于复杂结构,利用结构,结构分量的结构 对于大的数据对象(结构数组),采用静态变量 学生基本信息表的构造和输出 void Output int n, InfoAddr addr[ ], InfoStudent info[ ] int i, age; InfoAddr *q; /* 结构指针 */ InfoStudent

文档评论(0)

ozprb1 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档