POPPUR爱换

标题: 借显卡区真心求助,工作中遇到问题了,数学题 [打印本页]

作者: 孤胆小鱼    时间: 2012-6-25 18:36
标题: 借显卡区真心求助,工作中遇到问题了,数学题
本帖最后由 孤胆小鱼 于 2012-6-25 19:15 编辑

请版版帮帮忙不要删,工作中遇到大麻烦了,请数学好的同学帮忙,能算出来的有礼物赠送,聊表心意
[attach]1927505[/attach]
附件内是一个表格文件。(之前表格打错了,现在表格正确的,对不起!)

有两A,D两列数字
D列每个数字是A列数字其中某几个的求和,A列数字不重复使用,A和D列数字各自求和后是一样的
现在需要知道A列中的5860000包含在D列的哪个数字里(D列小于5860000的数字可以不管的),并且D列的这个数字是由A列哪几个数字求和而成的
这能算出来吗?


作者: nanshan    时间: 2012-6-25 19:32
1。过滤D列中大于5860000
2。 过滤后的D列每单元,减去5860000
3。 减过的数字,在A列中查询

作者: 孤胆小鱼    时间: 2012-6-25 19:39
nanshan 发表于 2012-6-25 19:32
1。过滤D列中大于5860000
2。 过滤后的D列每单元,减去5860000
3。 减过的数字,在A列中查询

是过滤小于5860000的吧
减去之后的数字,也可能是A列中好几个组成的啊

我连下班的心情都没有了
作者: 孤胆小鱼    时间: 2012-6-25 20:13
先下班了,哎
哪位同学能帮忙算出来请PM下地址,我送份礼物给您
作者: Edison    时间: 2012-6-25 20:43
建议到 Excelhome 的函数区求助。
作者: samsunggram    时间: 2012-6-25 22:54
本帖最后由 samsunggram 于 2012-6-25 22:55 编辑

194837265
  5627384
   43765
     546
       ?


求问号里的值

作者: samsunggram    时间: 2012-6-25 22:56
9163
9243
42822162
2363622162
提示:pair    推理出这组数字的意思
作者: taian    时间: 2012-6-25 23:07
本帖最后由 taian 于 2012-6-25 23:13 编辑

暂时想到一个很傻的办法:
把两列数据顺一下大小,对D列数字从小到大逐个规划求解,在下一个数字规划求解里面添加约束条件:前面的解所用到的A列数字为0"false",这样逐个做到最大为止。。。
由于比较花时间,我没有做下去。。。LZ如果实在想不出其他比较好的办法,可以用这个
作者: cctvgxtv    时间: 2012-6-25 23:30
提示: 作者被禁止或删除 内容自动屏蔽
作者: taian    时间: 2012-6-25 23:44
改进一下:
取消之前的约束条件
添加一列“校验列”,内容为对之前的解的可变单元区进行求和,然后加上约束条件:校验列小于等于1
这样可以避免在约束条件里面手动输入83个项这么麻烦

作者: kinno    时间: 2012-6-26 00:24
马克明天看看
作者: nanshan    时间: 2012-6-26 00:32
偶只能用笨方法, A数列从单个排序,然后两两相加,然后三三相加,直到所有相加,形成一个队列

然后D队列中大于5860000的数值,减去5860000,然后在上队列中查找

作者: 孤胆小鱼    时间: 2012-6-26 00:32
感谢各位的回复了,发到excelhome论坛试试了。谢谢taian朋友,真心说你说的我也不太懂,还是感谢你!
明天挨骂是小,关键耽误了客户的货,还可能被有关部门怀疑,我心理压力好大
作者: taian    时间: 2012-6-26 00:49
本帖最后由 taian 于 2012-6-26 00:51 编辑

啊。。。按照这个办法到51000会出现不止一个解,这下麻烦了,天知道后面会不会多个解,改一下策略:

每一个D列数字对应一列变量0、1($E$2:$AD$84),共83个,其中每一个对应一个A列数字。每一列变量和对应数字A相乘求和(例如:C2=SUMPRODUCT(A2:A84,AD2:AD84)),得出对应的数字D

添加一列校验列,B:每一个校验值对所在行的变量进行求和(例如:B2=SUM(E2:AD2))

规划求解,添加约束条件:校验列所有值均为1;求和列C的值为对应D列数字的值;变量取值二进制。求解

.
..
...

天杀的excel居然“可变单元格过多”
于是咱投降了,求高手
作者: lingxia196    时间: 2012-6-26 00:50
不太懂excel
编程的话用循环遍历很容易就可以实现了
作者: kinno    时间: 2012-6-26 09:11
帮顶,有点不好下手




欢迎光临 POPPUR爱换 (https://we.poppur.com/) Powered by Discuz! X3.4