- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(面向对象程序设计课程设计报告)如何购买到最多巧克力
购买到最多的巧克力
一 目的
利用所学知识,编写出可以解决从自动售货机出购买巧克力时,已知1美元可以购得一块巧克力。如果我们有n美元,且设置m张优惠券可以兑换一块巧克力,那么最多能够得到多少块巧克力,其中包括优惠券换到的巧克力,以及还有多少张富余的优惠券这一问题,最后将从键盘上键入的内容和输出数据保存到outfile.txt文件夹中。通过这次课程设计,加深对《C语言程序设计》课程所学知识的理解,熟练掌握和巩固C语言的基本知识和语法规范,学会编制结构清晰、编程风格良好、数据结构适当的C语言程序,从而具备利用计算机编程分析解决综合性实际问题的初步能力。
二 需求分析
1、输入数据
(1)输入您所拥有的美元金额n;
(2)能够兑换一块巧克力的的优惠券张数m。
2、输出数据
(1)输出最后得到的巧克力块数
(2)富余优惠券的数量
3、程序所达到的功能
从自动售货机处购买巧克力时,已知1美元可以购得一块巧克力。如果我们有n美元,且设置m张优惠券可以兑换一块巧克力,那么一共能够吃到多少块巧克力,包括优惠券兑换到的巧克力,以及还有多少张富余的优惠券,并且将输出数据保存到outfile.txt文件中。
三 概要设计
1、程序核心所解决的问题
(1)兑换后富余优惠券数=兑换巧克力剩余的优惠券数+兑换得到巧克力所带来的优惠券
(2)最多拥有的巧克力数=美元购买的巧克力数+优惠券兑换到巧克力的总数
2、各成员函数的功能、各数据成员的含义
(1)main函数;
void main()
{
int m,n,a[2];
char c=0;
ofstream outfile;
outfile.open(myfile.txt);
while(c!=#){cout请输入金额:;
cinn;
cout请输入可以用多少优惠券兑换一块巧克力:;
cinm;
a[0]=0;
a[1]=n;
(定义兑换之后剩余的优惠券数a[0],最多拥有的巧克力数a[1])用于最终输出程序结果
(2)Fun函数;
int fun(int m,int n,int a[],int s) {
if(nm) {
a[0]=n;
}
else
{
a[1]+=n/m;
n=n/m+n%m;
return fun(m,n,a,2);
}
}
(定义整型美元金额n,能够兑换一块巧克力的的优惠券张数m,定义数组a[],定义形参s)用于判断拥有的美元金额数n是否小于所设定的m张优惠券兑换一块巧克力的数目:如果小于则输出兑换后剩余的优惠券数为n,最多拥有的巧克力数为n;如果拥有的美元金额数n大于所设定的m张优惠券兑换一块巧克力的数目,则所拥有的巧克力数=a[1]+n/m,n=n/m+n%m,#include fstream 文件流类;
ofstream outfile;
outfile.open(myfile.txt)
outfile兑换之后剩余的优惠券数为a[0]endl最多拥有的巧克力数为a[1]endl;
outfile.close();
将从键盘上入的内容和输出数据保存到myfie.txt文件中。
四 详细设计
1、伪代码
int fun(int m,int n,int a[],int s) //定义函数fun,定义整型美元金额n,能够兑换一块巧克力的的优惠券张数m,定义数组a[],定义形参s
{
if(nm) //如果拥有的美元金额n数小于所设定的m张优惠券兑换一块巧克力的数目
{
则输出兑换后剩余的优惠券数为n
}
else //如果拥有的美元金额数n大于所设定的m张优惠券兑换一块巧克力的数目
{
a[1]+=n/m; //则所拥有的巧克力数=a[1]+n/m
n=n/m+n%m;
return fun(m,n,a,2); //返回函数fun
}
}
void main()
{
int m,n,a[2]; //定义兑换之后剩余的优惠券数a[0],最多拥有的巧克力数a[1]
char c=0;
ofstream outfile;
outfile.open(myfile.txt); //输出到文件myfile.txt
while(c!=#){cout请输入金额:;
输入拥有的美元金额n
输入可以用多少优惠券兑换一块巧克力:;
输入所设定的几张优惠券能够兑换巧克力的数目m
a[0]=0;
a[1]=n;
fun(m,n,a,2);
输出兑换之后剩余的优惠券数为a[0]endl最多拥有的巧克力数为a[1]endl;
outfile兑换之后剩余的优惠券数为a[0]endl最多拥有的巧克力数为a[1]endl
您可能关注的文档
最近下载
- QB_T 4563-2013金砂糖.pdf
- 大坝安全监测系统运检导则(试行) QGDW 46 10022.24-2020.docx VIP
- 第五单元 一方水土养一方人 达标训练(含答案) 浙江省人教版七年级人文地理下册.docx
- 奋进新征程建功新时代PPT模板.ppt VIP
- 规范《GB712-88-船体用结构钢》.pdf
- 二年级上册语文教学设计21《狐假虎威》一等奖 刘芳 部编版.docx VIP
- Q_GDW 46 10022.25-2020 通风空调系统运检导则.docx
- 12如何帮助学生学会正确地与异性同学交往?.docx VIP
- 专题1.2 数轴与动点经典题型(四大题型)(原卷版).docx VIP
- 拉森钢板桩专项施工方案.doc
文档评论(0)