4
//好扯,感觉自己根本就分析不出其内在的逻辑,真的想不出
#include <stdio.h>
int main()
{
int n, m, i, s = 0;
while(scanf("%d",&n)&&n!=0)
{
s=0;
scanf("%d",&m);
for (i = 2; i <= n; i++)
s = (s + m) % i;
printf ("%d\n", s+1);
}
}
/**************************************************************
Problem: 1356
User: hndxztf
Language: C++
Result: Accepted
Time:290 ms
Memory:1020 kb
****************************************************************/
//很自然的一种思路,但是时间是个硬伤,无表头建表,循环链表的删除。。。收获还是不少的
#include <cstdio>
#include <cstdlib>
using namespace std;
typedef struct LNode{
struct LNode *next;
int data;
}*LinkList;
LinkList CreateList(LinkList &L,int n)
{
LinkList q=NULL,p=NULL;
L=(LinkList)malloc(sizeof(LinkList*));
L->data=1;
L->next=L;
p=L;
for(int i=2;i<=n;i++)
{
q=(LinkList)malloc(sizeof(LinkList*));
q->data=i;
q->next=L;
p->next=q;
p=q;
}
return L;
}
int FindNum(LinkList L,int m)
{
LinkList q=NULL,p=L;
int count=1;
while(p->next!=p)
{
if(count<m)
{
p=p->next;
count++;
}
else if(count==m)
{
q=p->next;
p->data=q->data;//通过将后面节点的值赋给前个结点达到删除当前结点的目的
//在循环链表中是可行的
p->next=q->next;
//delete q;
//q=NULL;
count=1;
}
}
return p->data;
}
int main()
{
LinkList L=NULL;
int n,m;
while(scanf("%d",&n)&&n!=0)
{
scanf("%d",&m);
L=CreateList(L,n);
printf("%d\n",FindNum(L,m));
}
return 0;
}
/**************************************************************
Problem: 1356
User: hndxztf
Language: C++
Result: Time Limit Exceed
****************************************************************/原文:http://blog.csdn.net/mnmlist/article/details/39270935