题目要求:

  题目记得不太清楚,大概的意思是一个商店的打折方案如下:设一个客户买了n个商品,价格分别是p1,p2,...,pn

  (1)第一个商品不打折,即cost=p1;

  (2)第i个商品的折扣d=min{p1,p2,...,pi-1}.如果d>pi也就是说打折的前比他付的钱还多,那么这个商品就不要钱了,相当于d=p1;

  例如:n=4,价格分别为{4,9,2,3},这是题目给的示例  

    p1=4,d1=0,cost=4,because,the first item is never discounted;

    p2=9,d2=4,cost=9-4=5.means that the second item only need to pay 5$

    p3=2,d3=min{4,9}=4<p3, so d3=2,cost=2.means that the third item is free

    p4=3,d4=min{4,9,2}=2,d4=2,cost=3-2=1,.means that the fourth item need to pay 1$

  so, the total prices is 10$

    示例截图附在最后了。

解题思路

  最坏的思路:对于每个价格,求前面的最小值,类似于示例的思路。

  目前最优的思路:仔细思考会发现,对于第i个价格,di=min{min{p1,...,pi-2},pi-1},所以每次求前面价格最小值的时候,可利用之前的计算。

代码如下:

1、第一种:复杂性比较高  

public static void reduceSum(int[] prices){
int sumReduce=prices[0];
for (int i = 1; i < prices.length; i++) {
int minvalue=minValue(prices,i);
//System.out.println(prices);
//System.out.println(minvalue);
if (prices[i]<minvalue) {
minvalue=prices[i];
}
// else{
System.out.println("add:"+(prices[i]-minvalue));
sumReduce+=prices[i]-minvalue;
// }
} System.out.println("qian:"+sumReduce);
}
public static int minValue(int[] prices,int point){
int min=Integer.MAX_VALUE;
for (int i = 0; i < point; i++) {
if (prices[i]<min) {
min=prices[i];
}
}
System.out.println("min:"+min);
return min;
} public class FirstPra {
public static void main(String[] args) {
int[] prices={4,9,2,3};
//minValue(prices, 3);
reduceSum(prices);
}
public static void reduceSum(int[] prices){
int sumReduce=prices[0];
for (int i = 1; i < prices.length; i++) {
int minvalue=minValue(prices,i);
//System.out.println(prices);
//System.out.println(minvalue);
if (prices[i]<minvalue) {
minvalue=prices[i];
}
// else{
System.out.println("add:"+(prices[i]-minvalue));
sumReduce+=prices[i]-minvalue;
// }
} System.out.println("qian:"+sumReduce);
}
public static int minValue(int[] prices,int point){
int min=Integer.MAX_VALUE;
for (int i = 0; i < point; i++) {
if (prices[i]<min) {
min=prices[i];
}
}
System.out.println("min:"+min);
return min;
}
}

2、第二种,目前最优的思路”

     int prices={4,9,2,3};
     int sumReduce=prices[0];
int minValue_last=prices[0];
int minValue_cur=0; for (int i = 1; i < prices.length; i++) {
minValue_cur=minValue_last<prices[i]?minValue_last:prices[i];
sumReduce+=prices[i]-minValue_cur;
minValue_last=minValue_cur;
} System.out.println("qian:"+sumReduce);

  

“凯易迅Calix”实习上机——打折问题的更多相关文章

  1. “凯易迅Calix”实习上机——求元音开头辅音结尾的子串

    题目要求: 对于一个输入的字符串(26个小写字母组成),求出他的所有子串中元音开头,辅音结尾的子串.在这所有的子串中,输出第一个和最后一个. 例如aab,共有子串a,aa,aab,ab,b:但是满足元 ...

  2. python爬虫:爬取易迅网价格信息,并写入Mysql数据库

    本程序涉及以下方面知识: 1.python链接mysql数据库:http://www.cnblogs.com/miranda-tang/p/5523431.html   2.爬取中文网站以及各种乱码处 ...

  3. 牛一网ecshop家电数码模板(仿易迅网)for ecshop 2.7.3

            本模板尤其适用于家电数码行业. 本模板已经开发.测试完毕,并开放演示. 本模板支持全站静态.销售数量后台自定义.首页商品独立图片.品牌独立展示.商品精美团购.宽屏窄屏自动识别并切换.分 ...

  4. Selenium2学习-008-WebUI自动化实战实例-006-易迅登录之 frame 处理

    此文主要讲述用 Java 编写 Selenium 自动化测试脚本编写过程中,在因 frame 标签导致页面定位失败,提示 NoSuchElementException 时的,页面元素定位前的 fram ...

  5. 易观OLAP算法大赛结果揭晓,开源组黑马放大招!

    100+天激烈赛程,40+国内顶级技术豪门对决,历经研发内部测试.正式环境测试和易观数据正式环境跑benchmark三大阶段.10月28日,易观OLAP算法大赛优胜名单出炉! 40+技术门派比武 易观 ...

  6. php大力力 [055节] 大力力阅读文章集锦

    php大力力 [055节] 效率低啊,效率低 啥也不说了,先把网页挨个保存一下,关闭网页窗口 从 2015-09-11 10:58 到 2015-09-11 12:38 共用了100分钟,整理最近几天 ...

  7. 深度解析国内O2O模式

    今日在网上发现这篇文章很棒,详细的分析了当前BAT矩阵下的o2o 的模式.所以转载过来与大家一起分享. 文章来自于:http://www.siilu.com/20151214/158917.shtml ...

  8. ebe2

    Email:kefu007@vip.qq.com 软件每天有更新.请用Ctrl+F键搜索您需要的软件..如果你找不到你需要的软件可以联系客户服务人员帮您找! 海拉之光LucidShape光学设计仿真分 ...

  9. 豪情-CSS解构系列之-新浪页面解构-01

    目录: 一. 新浪的布局特点 二. 内容细节的特点 三. 其中相关的一些基础技术点 1. 常见布局方法 2. 布局要点 3. Debugger误区 4.列表 5.字体颜色 6.CSS选择符 7.CSS ...

随机推荐

  1. 剑指offer 29 多于一半的数

    1. 思路比较简单, 每次从数组中抽出两个数, 若是不同则丢弃两个数, 最后剩下的数即为所求 2. 书中给出的代码实现比较巧妙. 遍历数组中的元素, 变量 result 记录当前元素, time 记录 ...

  2. ArcGIS Android SDK 中文标注乱码

    Android使用如下代码添加标注: TextSymbol ts = new TextSymbol(12, "名称", Color.RED);Graphic gp = new Gr ...

  3. onSaveInstanceState

    我们已经分析过Activity的启动流程,从中也分析了Activity的生命周期.而其中有一个生命周期方法:onSaveInstanceState方法,今天我们主要讲解一下onSaveInstance ...

  4. M451例程讲解之GPIO.H

    到了CORTEX-M4,几乎每一快都有很大的知识量,单单GPIO库文件这一项就有很长的章节要描述,加油吧 GPIO.h.是最基础的一个库文件,下面结合数据手册来一一进行讲解: 先把库文件粘上,方便一一 ...

  5. nmon工具

    下载地址 1.http://nmon.sourceforge.net/pmwiki.php?n=Site.Download tar xvzf  *.tar.gz,需要配置权限 chmod -x,同时配 ...

  6. 简介Objective-C语言

    2011-05-11 11:20 佚名 百度百科 字号:T | T Objective-C,是扩充C的面向对象编程语言.主要使用于Mac OS X和GNUstep这两个使用OpenStep标准的系统, ...

  7. iOS UILabel两侧加阴影

    - (void)viewDidLoad { [super viewDidLoad]; [self.view setBackgroundColor:[UIColor grayColor]]; // Do ...

  8. android-修改TextView中部分文字的颜色

    :

  9. 如何用原生js替换字符串中的某个字符(或字符串)为指定的字符串?

    <html> <head><title>我的第一个 HTML 页面</title></head><script type=" ...

  10. Python: 使用pip升级所有包

    pip 当前内建命令并不支持升级所有已安装的Python模块. 列出当前安装的包:  pip list 列出可升级的包:  pip list --outdate 升级一个包:  pip install ...