新手,想问问上面的程序,整个解释一上,详细点,小弟我看不懂这程序是什么意思

新手,想问问下面的程序,整个解释一下,详细点,我看不懂这程序是什么意思
#include<iostream>
using namespace std;
int sum(int a[],int x)
{
int i,b=0;
for(i=0;i<x;i++)b=b+a[i];
return b;
}
int main()
{
int a[100],m,n,i,b=-1;
cin>>m>>n;
for(i=0;i<m;i++)a[i]=1;
while(sum(a,m)!=1)
{
for(i=0;i<n;i++)
{
b++;
if(b==m)b=0;
if(a[b]==0)i--;
}
a[b]=0;
cout<<b+1<<"号淘汰\n";
}
for(i=0;a[i]==0;i++);
cout<<i+1<<"号为大王\n";
return 0;
}

------解决方案--------------------
cin >> m >> n;//m总个数<100 n 没个n淘汰
for (i = 0; i < m; i++)a[i] = 1;//给数组a初始化 没个标记1 1还没有被淘汰的 0 被淘汰

while (sum(a, m) != 1) {//当数据的 标记和为1是 退出循环 剩下的一个为大王了
for (i = 0; i < n; i++) {
b++;
if (b == m)b=0;//到达最后的时 重新开始
if (a[b] == 0)i--; //跳过 已经被淘汰的
}
a[b] = 0; //找到被淘汰的 数组标志为0
cout << b + 1 << "号淘汰\n";
}
for (i = 0; a[i] == 0; i++); //查找数组中1所在的位置

这程序有问题貌似 我如果输入m输入0的话 数组的和就是0 死循环