• 请不要在回答技术问题时复制粘贴 AI 生成的内容
pyengwoei
V2EX  ›  程序员

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

  •  
  •   pyengwoei · Nov 10, 2015 · 2718 views
    This topic created in 3888 days ago, the information mentioned may be changed or developed.
    求一个简单的算法, 8 个数 int[] aaa = { 299, 649, 529, 519, 269, 649, 259, 219 }; 分成 2 组 4 个一组,大于等于 1400 就减 300 ,大于等于 1100 就减 200 ,大于等于 800 就减 100 。最后再减去每组当中最小的一个,求最后总和最小的组合方案
    14 replies    2015-12-23 17:14:05 +08:00
    SkyEcho
        1
    SkyEcho  
       Nov 10, 2015
    不是 homework 吧....
    pyengwoei
        2
    pyengwoei  
    OP
       Nov 10, 2015
    不是的,今天不是双 11 吗,我准备买 8 件衣服,就上面那些价格,算过去算过来,感觉最后应该可以省 400-500 老毛啦
    ljbha007
        3
    ljbha007  
       Nov 10, 2015
    优惠力度这么大呀 求楼主公司网站 我也要买买买
    pyengwoei
        4
    pyengwoei  
    OP
       Nov 10, 2015
    529, 519 , 649 , 649 这 4 个一组意思就是 这 4 件衣服 519 那件不算钱
    SkyEcho
        5
    SkyEcho  
       Nov 10, 2015
    跑出来了....
    519
    269
    259
    219
    一组
    总共要
    2144
    qiayue
        6
    qiayue  
    PRO
       Nov 10, 2015
    能减一千多啊
    qiayue
        7
    qiayue  
    PRO
       Nov 10, 2015
    @qiayue 好吧,算错了,不到一千
    zealot0630
        8
    zealot0630  
       Nov 10, 2015   ❤️ 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  
       Nov 11, 2015 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  
       Nov 11, 2015 via Android
    上边的不对,少看了一个条件
    xuyinan503
        11
    xuyinan503  
       Nov 11, 2015 via Android
    zealot 应该是正解
    pyengwoei
        12
    pyengwoei  
    OP
       Dec 23, 2015
    @zealot0630 这个貌似可以啦
    pyengwoei
        13
    pyengwoei  
    OP
       Dec 23, 2015
    不过 这个算法 是语言写的
    pyengwoei
        14
    pyengwoei  
    OP
       Dec 23, 2015
    @zealot0630 这个算法是什么语言写的啦 看不太明白
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   4153 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 44ms · UTC 10:10 · PVG 18:10 · LAX 03:10 · JFK 06:10
    ♥ Do have faith in what you're doing.