V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
pyengwoei
V2EX  ›  程序员

求一个简单的算法, 8 个数 int[] aaa = { 299, 649, 529, 519, 269, 649, 259, 219 }; 分成 2 组 4 个一组,大于等于 1400 就减 300

  •  
  •   pyengwoei · 2015-11-10 14:45:24 +08:00 · 2291 次点击
    这是一个创建于 3296 天前的主题,其中的信息可能已经有所发展或是发生改变。
    求一个简单的算法, 8 个数 int[] aaa = { 299, 649, 529, 519, 269, 649, 259, 219 }; 分成 2 组 4 个一组,大于等于 1400 就减 300 ,大于等于 1100 就减 200 ,大于等于 800 就减 100 。最后再减去每组当中最小的一个,求最后总和最小的组合方案
    14 条回复    2015-12-23 17:14:05 +08:00
    a302800411
        1
    a302800411  
       2015-11-10 14:49:26 +08:00
    不是 homework 吧....
    pyengwoei
        2
    pyengwoei  
    OP
       2015-11-10 14:54:13 +08:00
    不是的,今天不是双 11 吗,我准备买 8 件衣服,就上面那些价格,算过去算过来,感觉最后应该可以省 400-500 老毛啦
    ljbha007
        3
    ljbha007  
       2015-11-10 14:56:08 +08:00
    优惠力度这么大呀 求楼主公司网站 我也要买买买
    pyengwoei
        4
    pyengwoei  
    OP
       2015-11-10 14:57:47 +08:00
    529, 519 , 649 , 649 这 4 个一组意思就是 这 4 件衣服 519 那件不算钱
    a302800411
        5
    a302800411  
       2015-11-10 15:35:51 +08:00
    跑出来了....
    519
    269
    259
    219
    一组
    总共要
    2144
    qiayue
        6
    qiayue  
       2015-11-10 15:40:24 +08:00
    能减一千多啊
    qiayue
        7
    qiayue  
       2015-11-10 15:40:44 +08:00
    @qiayue 好吧,算错了,不到一千
    zealot0630
        8
    zealot0630  
       2015-11-10 17:36:19 +08:00   ❤️ 1
    scala> def c(n: Int, l: List[Int]): Seq[(List[Int], List[Int])] = if (n == 0) Seq((Nil, l)) else if (n == l.size) Seq((l, Nil)) else c(n-1, l.tail).map{ case (s,n) => ((l.head :: s), n) } ++ c(n, l.tail).map{ case (s, n) => (s, (l.head :: n)) }
    c: (n: Int, l: List[Int])Seq[(List[Int], List[Int])]

    scala> def coupon(l: List[Int]) = l.sum match { case x if x >= 1400 => x - 300; case x if x >= 1100 => x - 200; case x if x >= 800 => x - 100 }
    coupon: (l: List[Int])Int

    scala> c(4, List(299, 649, 529, 519, 269, 649, 259, 219)).minBy{ case (x,y) => coupon(x) - x.min + coupon(y) - y.min }
    res1: (List[Int], List[Int]) = (List(299, 269, 259, 219),List(649, 529, 519, 649))
    xuyinan503
        9
    xuyinan503  
       2015-11-11 15:24:55 +08:00 via Android   ❤️ 1
    299, 649, 529, 519, 269, 649, 259, 219
    和为 3392 大于 2800
    最优的情况可考虑两个 1400 以上
    在考察实际数据,有两个 600+,两个 500+,四个 200+
    随意组合 600+,500+,两个 200+组成 1500+即可

    最后花费 2792
    xuyinan503
        10
    xuyinan503  
       2015-11-11 15:26:19 +08:00 via Android
    上边的不对,少看了一个条件
    xuyinan503
        11
    xuyinan503  
       2015-11-11 15:29:21 +08:00 via Android
    zealot 应该是正解
    pyengwoei
        12
    pyengwoei  
    OP
       2015-12-23 17:06:19 +08:00
    @zealot0630 这个貌似可以啦
    pyengwoei
        13
    pyengwoei  
    OP
       2015-12-23 17:12:13 +08:00
    不过 这个算法 是语言写的
    pyengwoei
        14
    pyengwoei  
    OP
       2015-12-23 17:14:05 +08:00
    @zealot0630 这个算法是什么语言写的啦 看不太明白
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3737 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 10:41 · PVG 18:41 · LAX 02:41 · JFK 05:41
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.