找回密码
 欢迎注册
查看: 25801|回复: 1

[讨论] 如何匹配两个函数,使得得分最高

[复制链接]
发表于 2014-6-3 02:58:24 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?欢迎注册

×
由\(M\)个函数\(f_i(x)\)构成集合\(F=\{f_i(x)|i=1\space to\space M\}\),
其中\(f_i(x)\)的定义域都为\(X=\{i|i=1\space to\space K\}\),值域都为\(Y=\{i|i=1\space to\space L\}\)。
\(M,K,L\)有限,且为正整数。

现在,
随机生成在\(1\)到\(M\)之间均匀分布的一个整数\(i\),从F中选择函数\(f_i(x)\),
随机生成在\(1\)到\(K\)之间均匀分布的一个整数\(n\),

令\(j=1\space to \space n\),对每个\(j\)
随机生成在\(1\)到\(K\)之间均匀分布的一个整数\(k\),
随机生成在\(1\)到\(L\)之间均匀分布的一个整数\(l\),
用整数\(l\)替换\(f_i(k)\)的值。

循环完毕,得到\(f_i(x)\)的值被替换后的函数\(g(x)\)。
___________________________________________________________________

若只有\(F,X,Y\)对应的数据,和\(g\)的输入与输出的对应关系,
如何回答\(g\)是由哪个\(f_i\)生成的?

答案可以是:
不确定,得\(a\)分
确定并且指出\(f_i(x)\)是\(F\)的第几个元素,得\(b=1\)分
错误答案,得\( 0 \)分
其中\( 0 \le a \le b = 1 \)

以上的随机试验重复\(n\)次,当\(n \to \infty \),
如何回答,能使得得分率\(S=\dfrac{总得分}{n}\)最多?

若存在方案使得得分率\(S\)最大,那么该得分率\(S\)是多少?
毋因群疑而阻独见  毋任己意而废人言
毋私小惠而伤大体  毋借公论以快私情
 楼主| 发表于 2014-6-3 03:04:47 | 显示全部楼层
测试数据

M=32,K=8,L=2
a=0.5,b=1

F={{1,1,2,2,1,1,2,1},{2,1,2,1,2,1,2,2},{1,2,2,1,1,1,1,1},{2,2,2,2,2,1,2,1},{2,2,2,2,1,1,1,1},{2,1,1,2,2,1,1,1},{1,1,2,2,1,2,1,2},{1,2,1,1,1,1,1,1},{2,1,1,1,1,2,1,2},{1,1,2,2,1,2,2,1},{2,2,2,2,1,2,1,1},{2,2,1,1,2,2,1,1},{1,1,2,2,2,2,2,1},{2,1,1,1,1,1,2,2},{1,1,2,2,1,2,2,2},{1,2,1,1,2,2,2,2},{2,1,1,1,2,2,2,2},{2,2,2,2,2,2,2,1},{2,1,1,1,2,2,1,1},{1,2,2,2,2,2,2,1},{1,1,1,1,2,2,1,2},{1,2,2,2,1,1,1,2},{1,2,2,1,1,2,2,1},{2,1,2,1,1,2,2,2},{1,1,2,2,2,2,1,2},{1,1,2,1,2,2,2,1},{1,1,1,2,2,1,1,2},{2,2,1,2,1,1,1,1},{2,2,1,1,2,1,2,1},{1,2,2,2,1,1,2,2},{2,2,1,1,1,1,1,2},{1,2,2,2,1,1,2,2}}

策略总是按最小距离给出答案,不回答不确定
测试100000次,得到0.355546的得分率
这里正确率的误差要如何估计呢?

mathematica测试代码:
  1. mM=32;kK=8;lL=2;
  2. testcount=100000


  3. correct=0
  4. xX=Table[i,{i,1,kK}]
  5. yY=Table[i,{i,1,lL}]
  6. Table[f[i]=Table[RandomInteger[{1,lL}],{j,1,kK}],{i,1,mM}]
  7. For[n=1,n<=testcount,++n,
  8. i=RandomInteger[{1,mM}];
  9. ff=f[i];
  10. nn=RandomInteger[{1,kK}];
  11. For[j=1,j<=nn,++j,
  12. k=RandomInteger[{1,kK}];
  13. l=RandomInteger[{1,lL}];
  14. ff[[xX[[k]]]]=yY[[l]];
  15. ];
  16. match=Ordering[Table[Norm[f[j]-ff,1],{j,1,mM}],1];
  17. If[match[[1]]==i,correct++];
  18. ];
  19. N[correct/testcount]
复制代码
毋因群疑而阻独见  毋任己意而废人言
毋私小惠而伤大体  毋借公论以快私情
您需要登录后才可以回帖 登录 | 欢迎注册

本版积分规则

小黑屋|手机版|数学研发网 ( 苏ICP备07505100号 )

GMT+8, 2025-1-23 07:24 , Processed in 0.022200 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表