购买到最多的巧克力
一 目的
利用所学知识,编写出可以解决从自动售货机出购买巧克力时,已知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
原创力文档

文档评论(0)