你好,就按照你的办法来就可以啦
n = 100; m = 3;
s = 1:n; %1到n号人编好了号码
while(length(s)>1) %如果剩余人数大于1人,继续报数
s = circshift(s,m-1); % 第m个人向左移动m-1位,即移到了第一位,然后前面m-1个人移到了末位
s(1)=[]; % 把移到第一位的人推出去
end
fprintf('最后剩余的人的编号:%d\n',s)
结果是当m=3,n=100时:
最后剩余的人的编号:28
你可以改变m和n,随时获取最后那个人
有帮助望采纳,谢谢啦