公平的席位分配(MATLAB程序)

更新时间:2024-06-22 10:41:01 阅读量: 综合文库 文档下载

说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。

席位分配问题的MATLAB程序

说明:

1. 本程序用三种方法,分别是惯例法、d’honht分配法和Q值法。 2. 可以模拟出任意一种分配情况,即可以推广到N种情形。 3. 三种分配方案供你选择,相互比较。 4. 请务必阅读注意事项。

注意:

1. 以下包含两个程序,下载完后把程序拷贝到matlab的M文件中, 2. 第一个程序可以任意命名,只要符合规范就可以(本人以”xiweifenpei”命名,

这样便于查看),第二个程序一定要命名为“xiwei”,因为程序中要用到函数。 3. 下载完后先把程序拷贝到txt文件中,再从txt拷贝到M文件中,这样可以避免乱

码。

程序一: clear all clc

disp('席位分配:') P=1000

p=[235 333 432] N=10

[x,y]=size(p); zu=x*y;

disp('惯例分配方法:') for i = 1:zu

n(i) =p(i)*N/P; end n;

m=n-fix(n); for i=1:zu

if n(i)==max(m)+fix(n(i)) n(i)=fix(n(i))+1; else

n(i)=fix(n(i)); end end

disp('惯例分配人数:') n

disp('d’honht方法:') pp=[]; for i=1:N pi=p/i;

pp=[pp; pi]; end pp

m=zeros(1,zu); for i=1:N

[x,y]=find(pp==max(pp(:))); pp(x,y)=0; m(y)=m(y)+1; end pp

disp('d’honht分配人数:') m

disp('Q值法分配方法:')

q=ones(1,zu); Q=[]; p;

for i=1:zu

Q(i)=p(i)*p(i)/(q(i)*(q(i)+1)); end Q;

xiwei(p,q,Q,N,zu) 程序二:

再次提醒,以“xiwei”为文件名保存, function xiwei(p,q,Q,N,zu) if sum(q)==N

disp('Q值法分配人数:') q

return; else

for i=1:zu

if Q(i)==max(Q) q(i)=q(i)+1;

Q(i)=p(i)*p(i)/(q(i)*(q(i)+1)); break; end end end

xiwei(p,q,Q,N,zu)

本文来源:https://www.bwwdw.com/article/o1d3.html

Top