C语言专业课程设计方案报告长整数四则运算.doc
《C语言专业课程设计方案报告长整数四则运算.doc》由会员分享,可在线阅读,更多相关《C语言专业课程设计方案报告长整数四则运算.doc(29页珍藏版)》请在咨信网上搜索。
1、C语言课程设计说明书题目: 长整型数四则运算 学 院: 班 级: 学 生: 学 号: 班内序号: 提交日期: 年 月 日 目 录一、需求分析1二、设计思绪1三、具体设计21、关键函数22、函数关键调用关系图3四、调试分析及编程心得体会3五、用户手册3六、测试结果3七、源程序代码41、 main.c 主控文件42、IntFace.h 程序界面模块头文件53、IntFace.c 程序界面处理模块文件64、LongInt.h 长整型数输入输入及运算模块头文件95、LongIO.c 长整型数输入输出处理模块文件96、LongInt.c 长整型数运算处理模块文件117、DuCiLink.h 双向循环链表
2、处理模块头文件168、DuCiLink.c 双向循环链表处理模块代码17一、需求分析1、 设计一个实现任意长整数进行四则运算程序。2、 输入和输出形式是按中国对于长整数表示习惯,每四位一组,组间用逗号隔开,长整数位数没有上限,以分号结束长整型数据输入。3、 程序实施命令包含:1)、输入长整数1;2)、输入长整数2;3)、输入实施运算符;4)、计算并输出结果;5)、结束。4、测试数据:(以加法为例)(1)、0;0;+;应输出“0”。(2)、2345,6789;7654,3211;+;应输出“1,0000,0000”。(3)、9999,9999;1,0000,0000,0000;+;应输出“999
3、9,0000,0001”.(4)、1,0001,0001;1,0001,0001;+;应输出“0”.(5)、1,0001,0001;1,0001,0000;+;应输出“1”。(6)、9999,9999,9999;9999,9999,9999;+;应输出“1,9999,9999,9998”.(7)1,0000,9999,9999;1;+;应输出“1,0001,0000,0000”.二、设计思绪我们首先要考虑是怎样表示长整型数。根据传统习惯要求每4位数形成1组,而一个长整型数可能会有很多组这种4位数,而每节之间是有前后次序,所以我们能够考虑用数组和链表来存放数据。(1)再考虑到每个长整型数长度在输
4、入之间是无法预知,所以使用链表在存放空间分配上更方便部分。(2)在输入数据时总是从高位到低位地存放,而计算时总是从低位向高位运算,(这么话栈也很方便)所以采取双向链表更方便,而为了从头结点方便地转到尾结点能够采取循环链表。总而言之,为了实现上述功效,应以双向循环链表表示长整数,每个结点含一个整型变量,且仅绝对值不超出9999整数,整个链表用十进制数表示。(3)对于每一个长整型数能够设置一个头结点,其中数据域用来表示该长整型数正负号及组数,该值符号则表示该长整型数符号,该数绝对值表示该长整型数包含4位数组数。第一个存放4位数据组结点称为首结点,而最终一个4位数据组结点称为尾结点。为此需要两个结构
5、数据类型:双向循环链表和长整数,两个类型采取相同结构,只是双向循环链表用来存放数据,长整型用表示数据运算。1、 双向循环链表数据结构及操作定义以下:typedef short ElemType; /定义基础数据类型,我们采取short来表示任意4位整数。typedef struct DuCiLinkNode / 双向循环链表结点存放结构ElemType data;struct DuCiLinkNode *prior;/指向上一结点struct DuCiLinkNode *next;/指向下一结点DuCiLinkNode,*DuCiLinkList; /定义双向循环链表结点及链表类型名基础操作:
6、DuCiLinkNode *MakeNode(ElemType e); /以4位整数e结构1个双向循环链表结点Status InitList(DuCiLinkList *L); /初始化1个双向循环链表,分配1个结点作头结点/数据域赋初值0,上下结点指针指向自己void DestroyList(DuCiLinkList *L); /消毁1个双向循环链表,释放它所占用全部内存空间/并让链表*L指向NULLvoid ClearList(DuCiLinkList L); /清除1个双向循环链表,释放数据结点所占用内存空间/保留头结点,并将数据域置为0,上下结点指针指向自己Status InsTail
7、(DuCiLinkList L, ElemType e); /在双向循环链表L尾结点以后加入1个以e为/数据域新结点,并返回OK; 不然返回ERROR。Status InsFirst(DuCiLinkList L, ElemType e);/将数据元素e插入在线性链表L头结点以后,并返回OK; 不然返回ERROR。Status CopyList(DuCiLinkList L, DuCiLinkList C);/将双向循环链表L复制到双向循环链表C中。2、 长整数数据类型和和操作定义为:typedef struct DuCiLinkNode LongIntNode,*LongInt;/采取双向循
8、环链表为实际存放结构void OutputNumber(LongInt a);/输出一个长整型数void InputNumber(LongInt a,int OneOrTwo);/输入一个长整型数void add(LongInt c,LongInt a,LongInt b);/长整型数 c = a + bvoid sub(LongInt c,LongInt a,LongInt b); /长整型数 c = a - bStatus mul(LongInt c,LongInt a,LongInt b);/长整型数 c = a * bvoid div(LongInt c,LongInt a,LongI
9、nt b); /长整型数 c = a / b (整除)void rem(LongInt c,LongInt a,LongInt b); /长整型数 c = a % b (求余)void power(LongInt c,LongInt a,int n);/长整型数 c = a n (乘方)3、 本程序包含四个模块:1) 主程序模块:void main()/main.c初始化;do接收命令;处理命令;while(“命令”=“结束”)2) 程序界面模块/IntFace.c, IntFace.h3) 双向循环链表处理模块/ DuCiLink.c,DuCiLink.h4) 长整型数输入输出模块/Long
10、IO.c, LongInt.h5) 长整数运算模块/LongInt.c LongInt.h各模块之间调用关系以下: 程序界面模块双向循环链表单元模块长整数运算模块长整数输入输出模块主程序模块三、具体设计1、关键函数(1)、主控模块main.cvoid DoCommand()/依据输入命令进行对应处理void Calculate()/实施计算功效void ReSet()/重设系统环境(2)、程序界面模块 IntFace.cvoid InitiInterface();/界面初始化void GoToCmdxy();/将光标定位到命令选项提醒以后void GoToPrompt();/将光标定位到命令选
11、项提醒行首void ShowMainPrompt();/显示命令选项提醒void ClearScreen();/以清除整个屏幕,并设置为黑底白字模式void ClearPromptLine();/清除提醒行显示void ClearWorkSpace();/清除工作区显示 void InputNumberBox(int OneOrTwo);/指定两个输入数输入窗口,假如超出这个范围文字将自动流动void ResultBox(); /指定计算结果显示窗口,假如超出这个范围文字将自动流动(3)、长整型数输入输出模块见二小节2分节(4)、长整型数四则运算处理模块见二小节2分节(5)、长整型数存放模块双
12、向循环链表模块见二小节1分节2、函数关键调用关系图mainInitiInterFaceDoCommandDrawIntFaceCalculateInputNumberInputOperatorResetaddsubmuldivrempowerInitListOutputNumberInsTailClearListInsFirstCopyListDestroyListDestroyListInitList直接调用可能调用四、调试分析及编程心得体会1、刚开始考虑进位问题过于简单,造成测试数据时数次犯错。2、刚开始时在输入方法中花了较大功夫,而且用户界面不够友好,程序容错性较差。3、开始写程序时源程
13、序没有严格按单元模块结构编写,可读性较差。4、因为首次进行系统程序设计,层次结构划分不太合理,应在以后设计中强化此思维,逐步和工程设计接轨。五、用户手册1、本程序运行环境为DOS操作系统,实施文件为LongInt.exe。2、进入演示程序后即显示文本方法用户界面3、输入命令,实施对应功效:1 输入第1个整数o,O 输入运算符r, R 重置系统2 输入第2个整数c,C 实施运算q,Q 退出系统六、测试结果(1)、0和0四则运算:(2)、-2345,6789;-7654,3211;+;应输出“1,0000,0000”。(3)、9999,9999;1,0000,0000,0000;+;应输出“999
14、9,0000,0001”.(4)、1,0001,0001;1,0001,0001;+;应输出“0”.(5)、1,0001,0001;1,0001,0000;+;应输出“1”。(6)、9999,9999,9999;9999,9999,9999;+;应输出“1,9999,9999,9998”.(7)1,0000,9999,9999;1;+;应输出“1,0001,0000,0000”.略七、源程序代码/*1、main.c 主控文件 */#include IntFace.h/*界面模块头文件*/#include LongInt.h/*长整型数处理模块头文件*/char cmd;/* menu comm
15、and */char opt;/* operator */int n;/* power */LongInt a,b,c;/* Long integer numbers */int flag_n1=0,flag_n2=0,flag_opt=0,flag_cal=0,flag_reset=1; /*标志位*/void ReSet()/* Reset system */ClearWorkSpace();/清屏幕工作区flag_n1=0;/重置长整数1是否输入标志flag_n2=0;/重置长整数2是否输入标志flag_opt=0;/重置运算符 是否输入标志flag_cal=0;/重置是否进行了运算标志
16、flag_reset=1;/重置 重置标志void Calculate()/实施计算int overflow = OK;if (flag_n1*flag_n2*flag_opt = 0 ) return; /*Input is not complete! 输入不完整则直接返回*/switch (opt)case +: add(c,a,b); break;/实施加法运算case -: sub(c,a,b); break;/实施减法运算case *: mul(c,a,b); break;/实施乘法运算case /: overflow = div(c,a,b); break;/实施整除运算case
17、%: rem(c,a,b); break;/实施求余运算case : n = b-prior-data;power(c,a,n); break;/临时以长整数b最终一组数据为幂,实施乘方运算;gotoxy(2,10);/定位到输出位置cprintf(overflow=OK ? Result = :DivideBy);/输出结果提醒ResultBox();/控制输出范围,以免搞乱程序界面OutputNumber(c);/输出运算结果ClearList(c);/清空长整数cwindow(1,1,80,25);/重新设置显示窗口为全屏幕void DoCommand()/依据输入命令进行对应处理swi
18、tch(cmd)case 1:InputNumber(a,1);flag_n1=1;break;/输入第1个长整数case 2:InputNumber(b,2);flag_n2=1;break;/输入第2个长整数case O:case o:opt=InputOperator();flag_opt=1;break;/输入运算符case C:case c:Calculate();flag_cal=1;break;/实施运算case R:case r:ReSet();/重设系统方便实施下一次运算void main()InitiInterface();/初始化程序界面InitList(&a); /初始
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 专业课程 设计方案 报告 整数 四则运算
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。