重庆大学本科学生课程设计任务书——长整数运算.docVIP

重庆大学本科学生课程设计任务书——长整数运算.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
重庆大学本科学生课程设计任务书 课程设计题目 长整数运算 学院 软件学院 专业 软件工程 年级 16级 已知参数和设计要求: [问题描述] 设计一个程序实现两个任意长的整数求和运算。 学生应完成的工作: [基本要求] 利用双项循环链表实现长整数的存储,每个结点含一个整型变量。任何整型变量的范围是-(215-1)~(215-1)。输入和输出形式:按中国对于长整数的表示习惯,每四位一组,组间用逗号隔开。 [测试数据] (1) 0;0;应输出“0”。 (2) -2345,6789;-7654,3211;应输出“-1,0000,0000”。 (3) -9999,9999;1,0000,0000,0000;应输出“9999,0000,0001”。 (4) 1,0001,000;-1,0001,0001;应输出“0”。 (5) 1,0001,0001;-1,0001,0000;应输出“1”。 目前资料收集情况(含指定参考资料): 1. Robert L. Kruse编. Data Structures and Program Design in C++. 高等教育出版社,2001. 2. 严蔚敏编. 数据结构. 清华大学出版社,2000. 3. 李春葆编. 数据结构教程. 清华大学出版社,2002. 4. Clifford A.Shaffer著. 张铭,刘晓丹等译. 数据结构与算法分析(第三版).电子工业出版社,2013.10. 课程设计的工作计划: 第1~4天 完成方案设计与程序框图 第4~10天 编写程序代码 第10~15天 程序调试分析和结果 第15~20天 课程设计报告和总结 任务下达日期 2017 年 12 月 15 日 完成日期 2018年 1 月 12 日 指导教师 文俊浩 (签名) 学 生 陈勇 (签名) 说明:1、学院、专业、年级均填全称,如:光电工程学院、测控技术、2003。 2、本表除签名外均可采用计算机打印。本表不够,可另附页,但应在页脚添加页码。 1.方案设计 1.1问题描述 利用双项循环链表实现长整数的存储,每个结点含一个整型变量。任何整型变量的范围是-(215-1)~(215-1)。输入和输出形式:按中国对于长整数的表示习惯,每四位一组,组间用逗号隔开。 1.2需求分析 核心问题:长整形数的进行拆分再加减 数据模型(逻辑结构):类似汇编的带进位加法和带进位减法 存储结构:循环链表,字符数组 核心算法:字符数组提取数字,链表的加减 输入数据:两个长整形数字 输出数据:加减结果 通过以上分析,该程序具有可行性。 1.3运行环境 硬件开发环境:PC机 软件开发环境:VS2015 操作系统环境Window 1.4概要设计 整个设计的流程图 图1.1 2.算法设计 2.1算法设计思想 用两个字符数组储存输入的字符串,再将字符串中的每个4位整数转入成链表的关键节点分别储存到两个链表中,这样就让长整数分割开来,使得储存成为现实,然后再分别把两个链表的节点相加储存到另一个链表中,用flag来判断有无进位与借位,有进位flag置为1,无进位flag置为-1,最后将结果链表按照要求的格式输出即可1111,4444,5555,3334,0000,0001与1,0000,2321,9000,5555,0000相加相加 3.详细设计 3.1设计思想 用字符数组来存储输入的数,用循环链表的储存整数的节点,以及计算的结果。用链表的好处可以节约空间,它可以随着数据的长短来调整大小,同时,双向循环链表也方便了查找和删除。 3.2设计关键算法 节点类: public: E element; // Value for this node Link* next; // Point to next node in list Link*prev; //Pointer to previous node // Constructors Link(const E it, Link* prevp,Link*nextval) { element = it; next = nextval; prev = prevp; } Link(Link*prevp = NULL,Link* nextval = NULL) { next = nextval; prev = prevp; } 双向循环链表类: template typename E class DoubleLList { private: LinkE* head;

文档评论(0)

日度 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档