24小时热门版块排行榜    

查看: 1776  |  回复: 11
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

theday0323

木虫 (小有名气)

[求助] 急:求助求解不等式方程组 已有1人参与

N1,N2,N3,N4,N5,N6都是正整数
N1+N3+N5=N2+N4+N6;
N1-N2>=0;
N1-N2+N3-N4>=0;
N1<=N;
N1-N2+N3<=N;
N1-N2+N3-N4+N5<=N;
求(N1+N2+N3+N4+N5+N6)/2的值分别在N到3N时解的个数,防止计算量太大,假定N为100.

求程序啊,急
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

aprillf

木虫 (正式写手)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
theday0323: 金币+8, 有帮助, 摁 谢了,如果有能简化时间的算法就好了 2014-08-25 17:48:04
theday0323: 金币+20, ★★★★★最佳答案, 等了这么久,就给你了,只有你是应助贴就给你了,谢了 2014-08-28 10:26:56
对于比较小的N可以高效计算;
N=100时解的个数估计有上千万甚至更多,

所以下面的结果仅供参考了:

急:求助求解不等式方程组

SetSystemOptions["ReduceOptions"->{"DiscreteSolutionBound"->10000000}];

f[n_]:=Module[{eqn},eqn=(n1+n3+n5==n2+n4+n6)&&(n1>=n2)&&(n1-n2+n3-n4>=0)&&(n1<=n)&&(n1-n2+n3<=n)&&(n1-n2+n3-n4+n5<=n)&&(2n<=n1+n2+n3+n4+n5+n6<=6n)&&(n1>0)&&(n2>0)&&(n3>0)&&(n4>0)&&(n5>0)&&(n6>0);Length@Reduce[eqn,{n1,n2,n3,n4,n5,n6},Integers]]

Flatten[{#,Timing[f@#]}]&/@Range[5,30]//TableForm[#,TableHeadings->{None,{"n","timing","numbers"}}]&
10楼2014-08-25 12:29:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 12 个回答

walk1997

金虫 (著名写手)


jjdg: 金币+1, 感谢参与 2014-06-11 12:25:16
这是考试题目还是实际碰到的问题呀?
把约束条件重新排列一下
直接做个循环应该就可以

» 本帖已获得的红花(最新10朵)

2楼2014-06-08 16:54:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

theday0323

木虫 (小有名气)

送红花一朵
引用回帖:
2楼: Originally posted by walk1997 at 2014-06-08 16:54:12
这是考试题目还是实际碰到的问题呀?
把约束条件重新排列一下
直接做个循环应该就可以

实际碰到的问题啊
主要是不会写  求指导
如果我有表述不清楚的地方 指出来 我再改 谢了
3楼2014-06-08 21:38:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

walk1997

金虫 (著名写手)

★ ★
theday0323(jjdg代发): 金币+2, 辛苦了 2014-06-11 12:25:31
引用回帖:
3楼: Originally posted by theday0323 at 2014-06-08 21:38:29
实际碰到的问题啊
主要是不会写  求指导
如果我有表述不清楚的地方 指出来 我再改 谢了...

比较死的循环代码,花了5000s的时间才算完....另外个代码可以用并行,不知道速度能提高多少,或者你编译成C算算
Clear["Global`*"];
n = 100;
n6 = n1 + n2 + n3 - n4 - n5;
j = 0;
t1 = AbsoluteTime[];
Do[If[n <= (n1 + n2 + n2 + n3 + n4 + n5 + n6)/2 <= 3 n && n6 >= 1,
  j = j + 1], {n1, 1, n}, {n2, 1, n1}, {n3, 1, n - n1 + n2}, {n4, 1,
   n1 - n2 + n3}, {n5, 1, n - n1 + n2 - n3 + n4}];
t2 = AbsoluteTime[];
t2 - t1
Print[j]

5038.6471942

1022862022
4楼2014-06-09 11:08:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见