题目要求:

  题目记得不太清楚,大概的意思是一个商店的打折方案如下:设一个客户买了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. 从头认识java-18.2 主要的线程机制(2)-Executors的使用

    在前面的章节我们都是直接对Thread进行管理,我们这里解释一下还有一个管理Thread的类Executors. 1.样例: package com.ray.ch17; import java.uti ...

  2. iOS开发之--搭建本地的SVN服务器

    近期入职的新公司,后台没有分配svn账号,需要在本地搭建一个服务器,方便和代码,看了看网上的教程,一直有这样那样的问题, 其中最主要的问题还是路径拼接的问题,最后终于解决了,特在此分享下,如果大家有更 ...

  3. 使用binlog日志还原数据详解

    1)看一下你的mysql服务器有没开启binlog日志(ON为开启,OFF为未开启) show variables like 'log_bin'; 2)找到你的binlog文件在哪 登录 mysql ...

  4. Objective-C代码学习大纲(3)

    Objective-C代码学习大纲(3) 2011-05-11 14:06 佚名 otierney 字号:T | T 本文为台湾出版的<Objective-C学习大纲>的翻译文档,系统介绍 ...

  5. 【Python算法】渐进记法 与 性能测量工具cProfile

    对于某个比较简单的算法,我们有时候确实能够精确地分析出算法的复杂度. 比如算法复杂度为5n^2+10n+6,但是事实上并不需要这样,因为当n足够大时,可以忽略掉低阶项和最高次项的系数,因此就引出了“渐 ...

  6. Spark源码分析 – Shuffle

    参考详细探究Spark的shuffle实现, 写的很清楚, 当前设计的来龙去脉 Hadoop Hadoop的思路是, 在mapper端每次当memory buffer中的数据快满的时候, 先将memo ...

  7. good blog

    https://blog.csdn.net/fgf00/article/details/52793739

  8. ArcGIS Server管理工具之批量发布动态地图服务工具.md

    友好阅读链接:(http://swj.me/2015/08/26/batchPublishtools/) update0918: 修复了创建链接文件时而出错的bug 修复了在24011的警告已处理的情 ...

  9. python学习笔记(四)— 函数

    一.函数是什么? 函数一词来源于数学,但编程中的「函数」概念,与数学中的函数是有很大不同的,编程中的函数在英文中也有很多不同的叫法.在BASIC中叫做subroutine(子过程或子程序),在Pasc ...

  10. python基础知识体系

    一.编程风格.语法要求.变量格式.基本数据类型.运算.流程控制.用户交互 二.字符串.列表.元组.字典.迭代器和生成器 三.函数.内置函数.文件操作.异常处理.模块.常用模块.lambda.yield ...