算法 — 地大复试
模拟
while循环和MOD循环计数
1.约瑟夫问题
http://bailian.openjudge.cn/practice/3254
using namespace std;
bool isNoPeople(vector<bool> c)//判断当前数组是否一个小孩都没有了
{
bool nopeople = true;
for (bool ival : c)
{
if ( ival == true)
nopeople = false;
}
return nopeople;
}
int main()
{
int n, p, m;//n人数, p游戏起点(对于idx为p-1), m为传递次数
cin >> n >> p >> m;
vector<bool> c(n, true);//其实用数组同样效果没必要非得用vector.
int i = p-1;//模拟的起点idx
while (!isNoPeople(c))//💡控制条件不是指定次数而是一种状态时就不再使用for来写,while会更清晰和可操作性高
{
int t = m;//每轮更新剔除小孩的传递次数
while (t > 0)//只要t>0就一直传递
{
while (c[i] == false)//当小孩没有在座位上(小孩已经剔除)⇒执行向下传递直到传递到小孩存在的位置退出循环
i = (i + 1) % n;
--t;//下标为i位置的小孩传出
if (t == 0)//如果传出时次数为0(暴雷了)
{
cout << i + 1 << ',';//idx为i的小孩对应为第i+1个小孩剔除(打印输出)
c[i] = false;//小孩座位标记剔除标记为false
break;//本轮剔除小孩结束进行下一轮直到一个小孩都没有
}
i = (i + 1) % n;//没有暴雷,就传给下一个小孩
}
}
}