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

2015-11-10 14:45:24 +08:00
 pyengwoei
求一个简单的算法, 8 个数 int[] aaa = { 299, 649, 529, 519, 269, 649, 259, 219 }; 分成 2 组 4 个一组,大于等于 1400 就减 300 ,大于等于 1100 就减 200 ,大于等于 800 就减 100 。最后再减去每组当中最小的一个,求最后总和最小的组合方案
2230 次点击
所在节点    程序员
14 条回复
a302800411
2015-11-10 14:49:26 +08:00
不是 homework 吧....
pyengwoei
2015-11-10 14:54:13 +08:00
不是的,今天不是双 11 吗,我准备买 8 件衣服,就上面那些价格,算过去算过来,感觉最后应该可以省 400-500 老毛啦
ljbha007
2015-11-10 14:56:08 +08:00
优惠力度这么大呀 求楼主公司网站 我也要买买买
pyengwoei
2015-11-10 14:57:47 +08:00
529, 519 , 649 , 649 这 4 个一组意思就是 这 4 件衣服 519 那件不算钱
a302800411
2015-11-10 15:35:51 +08:00
跑出来了....
519
269
259
219
一组
总共要
2144
qiayue
2015-11-10 15:40:24 +08:00
能减一千多啊
qiayue
2015-11-10 15:40:44 +08:00
@qiayue 好吧,算错了,不到一千
zealot0630
2015-11-10 17:36:19 +08:00
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
2015-11-11 15:24:55 +08:00
299, 649, 529, 519, 269, 649, 259, 219
和为 3392 大于 2800
最优的情况可考虑两个 1400 以上
在考察实际数据,有两个 600+,两个 500+,四个 200+
随意组合 600+,500+,两个 200+组成 1500+即可

最后花费 2792
xuyinan503
2015-11-11 15:26:19 +08:00
上边的不对,少看了一个条件
xuyinan503
2015-11-11 15:29:21 +08:00
zealot 应该是正解
pyengwoei
2015-12-23 17:06:19 +08:00
@zealot0630 这个貌似可以啦
pyengwoei
2015-12-23 17:12:13 +08:00
不过 这个算法 是语言写的
pyengwoei
2015-12-23 17:14:05 +08:00
@zealot0630 这个算法是什么语言写的啦 看不太明白

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/235068

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX