(003)(课程设计报告)如何购买到最多的巧克力选读.doc

(003)(课程设计报告)如何购买到最多的巧克力选读.doc

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

1亿VIP精品文档

相关文档