课堂练习 书籍促销(贪心算法)

一.题目

书店针对《哈利波特》系列书籍进行促销活动,一共5卷,用编号0、1、2、3、4表示,单独一卷售价8元,具体折扣如下所示:

            本数                  折扣

2                       5%

3                       10%

4                       20%

5                       25%

1 根据购买的卷数以及本数,会对应不同折扣规则情况。单数一本书只会对应一个折扣规则,例如购买了两本卷1,一本卷2,则可以享受5%的折扣,另外一本卷一则不享受优惠。

2 设计算法能够计算出读者购买一批书的最低价格。

3 要求将设计思想、代码实现、实现截图、个人总结以博文的形式发表。

二.设计思想

根据折扣和买书数量可以知道:

1)当购买1,2,3,4,5本时,按卷编号顺序购买最优;

2)当购买5的整数本时,5卷一起买:5,5,5.......最佳;

3)当购买6,7,8,9时,最佳为:6=1+5,7=2+5,8=4+4,9=5+4

4)当买书量大于10本时,将数量进行求余,算出当买6、7、8、9本书时的最小价格,其余的直接用买5套的折扣价即为最优方案。

三.代码实现 

 1 // ConsoleApplication6.cpp : 定义控制台应用程序的入口点。
 2 //
 3 #include "stdafx.h"
 4 int _tmain(int argc, _TCHAR* argv[])
 5 {
 6     return 0;
 7 }
 8 #include<iostream>
 9 using namespace std;
10 float price;
11 void tanxin(int book)
12 {
13     int yushu;
14     yushu = book % 5;
15     switch (yushu)
16     {
17     case 0:
18         price = book * 8 * 0.75;
19         break;
20     case 1:
21         price = (book - yushu) * 8 * 0.75 + 8;
22         break;
23     case 2:
24         price = (book - yushu) * 8 * 0.75 + 2 * 8 * 0.95;
25         break;
26     case 3:
27         price = (book - yushu) * 8 * 0.75 + 4 * 8 * 0.8 * 2 - 5 * 8 * 0.75;
28         if (book<5)
29         {
30             price += 0.4;
31         }
32         break;
33     case 4:
34         price = (book - yushu) * 8 * 0.75 + 4 * 8 * 0.8;
35         break;
36     default:
37         cout << "Error!" << endl;
38
39     }
40 }
41 void main()
42 {
43     int i= 0;
44     while (i== 0)
45     {
46         int book;
47         cout << "购买本数(tip:输入正整数):";
48         cin >> book;
49         tanxin(book);
50         cout << "最低价格:" << price << endl;
51         cout << "还要买吗?(tip:输入0继续,输入任意键退出)";
52         cin >> i;
53     }
54 }

四.结果截图

五.总结

  对于负数本书提示错误,但是对于本书太多如截图输入15亿的情况,结果显示一个带e的数。通过本次试验对自身提高很大。

时间: 2024-08-30 09:13:48

课堂练习 书籍促销(贪心算法)的相关文章

POJ1017 Packets(贪心算法训练)

Time Limit: 1000MS          Memory Limit: 10000K          Total Submissions: 51306          Accepted: 17391 Description A factory produces products packed in square packets of the same height h and of the sizes 1*1, 2*2, 3*3, 4*4, 5*5, 6*6. These pro

贪心算法的简述与示例

贪心算法采用自顶向下,以迭代的方法做出相继的贪心选择,每做一次贪心选择就将所求问题简化为一个规模更小的子问题,通过每一步贪心选择,可得到问题的一个最优解,虽然每一步上都要保证能获得局部最优解,但由此产生的全局解有时不一定是最优的,所以贪婪法不要回溯.能够用贪心算法求解的问题一般具有两个重要特性:贪心选择性质和最优子结构性质. 参考:http://babybandf.blog.163.com/blog/static/61993532010112923767/ [例1]删数问题[B][/B] 试题描

算法导论——lec 13 贪心算法与图上算法

之前我们介绍了用动态规划的方法来解决一些最优化的问题.但对于有些最优化问题来说,用动态规划就是"高射炮打蚊子",采用一些更加简单有效的方法就可以解决.贪心算法就是其中之一.贪心算法是使所做的选择看起来是当前最佳的,期望通过所做的局部最优选择来产生一个全局最优解. 一. 活动选择问题 [问题]对几个互相竞争的活动进行调度:活动集合S = {a1, a2, ..., an},它们都要求以独占的方式使用某一公共资源(如教室),每个活动ai有一个开始时间si和结束时间fi ,且0 ≤ si &

五大常用算法之三贪心算法

贪心算法 贪心算法简介: 贪心算法是指:在每一步求解的步骤中,它要求"贪婪"的选择最佳操作,并希望通过一系列的最优选择,能够产生一个问题的(全局的)最优解. 贪心算法每一步必须满足一下条件: 1.可行的:即它必须满足问题的约束. 2.局部最优:他是当前步骤中所有可行选择中最佳的局部选择. 3.不可取消:即选择一旦做出,在算法的后面步骤就不可改变了. 贪心算法案例: 1.活动选择问题  这是<算法导论>上的例子,也是一个非常经典的问题.有n个需要在同一天使用同一个教室的活动a

零基础学贪心算法

本文在写作过程中参考了大量资料,不能一一列举,还请见谅.贪心算法的定义:贪心算法是指在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以考虑,只做出在某种意义上的局部最优解.贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关.解题的一般步骤是:1.建立数学模型来描述问题:2.把求解的问题分成若干个子问题:3.对每一子问题求解,得到子问题的局部最优解:4.把子问题的局部最优

贪心算法

一,贪心算法的设计思想 ? 从问题的某一个初始解出发逐步逼近给定的目标,每一步都作一个不可回溯的决策,尽可能地求得最好的解.当达到某算法中的某一步不需要再继续前进时,算法停止. 二,贪心算法的基本性质 1)贪心选择性质 所谓贪心选择性质是指所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到.这是贪心算法可行的第一个基本要素,也是贪心法与动态规划法的主要区别. 2) 最优子结构性质 该问题解的整体最优性依赖于其局部子问题解的最优性.这种性质是可以采用贪心算法解决问题的关键特征.例如

算法导论----贪心算法,删除k个数,使剩下的数字最小

先贴问题: 1个n位正整数a,删去其中的k位,得到一个新的正整数b,设计一个贪心算法,对给定的a和k得到最小的b: 一.我的想法:先看例子:a=5476579228:去掉4位,则位数n=10,k=4,要求的最小数字b是n-k=6位的: 1.先找最高位的数,因为是6位数字,所以最高位不可能在后5位上取到(因为数字的相对顺序是不能改变的,假设如果取了后五位中倒数第5位的7,则所求的b就不可能是6位的了,最多也就是4位的79228)理解这点很重要!所以问题变成从第1位到第k+1(n-(n-k-1))取

高级算法——贪心算法(找零问题)

function makeChange(origAmt, coins) {//贪心算法——找零问题 var remainAmt ; if (origAmt % .25 < origAmt) { coins[3] = parseInt(origAmt / .25); remainAmt = origAmt % .25; origAmt = remainAmt; } if (origAmt % .1 < origAmt) { coins[2] = parseInt(origAmt / .1); r

高级算法——贪心算法(背包问题)

贪心算法不能用来解决离散物品问题的原因是我们无法将“ 半台电视” 放入背包. 规则是按照物品价值高低顺序放入背包. function ksack(values, weights, capacity) { var load = 0; var i = 0; var v = 0; while (load < capacity && i < weights.length) { if (weights[i] <= (capacity - load)) { v += values[i