前面不是题解!!!最后一个代码才是
借用这个题目来举个例子:
题目描述
小南有一套可爱的玩具小人, 它们各有不同的职业。
有一天, 这些玩具小人把小南的眼镜藏了起来。 小南发现玩具小人们围成了一个圈,它们有的面朝圈内,有的面朝圈外。如下图:
这时singer告诉小南一个谜題: “眼镜藏在我左数第3个玩具小人的右数第1个玩具小人的左数第2个玩具小人那里。 ”
小南发现, 这个谜题中玩具小人的朝向非常关键, 因为朝内和朝外的玩具小人的左右方向是相反的: 面朝圈内的玩具小人, 它的左边是顺时针方向, 右边是逆时针方向; 而面向圈外的玩具小人, 它的左边是逆时针方向, 右边是顺时针方向。
小南一边艰难地辨认着玩具小人, 一边数着:
singer朝内, 左数第3个是archer。
archer朝外,右数第1个是thinker。
thinker朝外, 左数第2个是write。
所以眼镜藏在writer这里!
虽然成功找回了眼镜, 但小南并没有放心。 如果下次有更多的玩具小人藏他的眼镜, 或是谜題的长度更长, 他可能就无法找到眼镜了 。 所以小南希望你写程序帮他解决类似的谜題。 这样的谜題具体可以描述为:
有 n个玩具小人围成一圈, 已知它们的职业和朝向。现在第1个玩具小人告诉小南一个包含m条指令的谜題, 其中第 z条指令形如“左数/右数第ss,个玩具小人”。 你需要输出依次数完这些指令后,到达的玩具小人的职业。
输入格式
输入的第一行包含两个正整数 n,m表示玩具小人的个数和指令的条数。
接下来 nn 行,每行包含一个整数和一个字符串,以逆时针为顺序给出每个玩具小人的朝向和职业。其中 0 表示朝向圈内,1 表示朝向圈外。 保证不会出现其他的数。字符串长度不超过 10 且仅由小写字母构成,字符串不为空,并且字符串两两不同。整数和字符串之间用一个空格隔开。
接下来 m 行,其中第 i行包含两个整数 ai,sia表示第 i 条指令。若 ai=0表示向左数 si个人若 ai=1表示向右数 si个人,保证 ai不会出现其他的数,1<=si<n
输出格式
输出一个字符串,表示从第一个读入的小人开始,依次数完 m 条指令后到达的小人的职业。
读完题我们可以发现,这是一个圆桌坐着一圈人,可能向左也可能向右走,当时想到了完全符合双向循环链表,所以就直接模拟了题目,代码就是这个鸭子
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct node
{
char name[10];
int fx;
struct node *next;
struct node *last;
};
int main()
{
int i,j,n,m,a,b,x,a1,a2;
scanf("%d %d",&n,&m);
struct node *p,*q,*head,*t;
head=(struct node *)malloc(sizeof(struct node));
head->next=NULL;
for(i=0;i<n;i++)
{
p=(struct node *)malloc(sizeof(struct node));
p->next=NULL;
scanf("%d %s",&p->fx,p->name);
if(p->fx==1)
{
p->fx=-1;
}
if(p->fx==0)
{
p->fx=1;
}
if(head->next==NULL)
{
head->next=p;
q=p;
}
else
{
q->next=p;
p->last=q;
}
q=p;
}
p->next=head->next;
head->next->last=p;
t=head->next;
for(i=0;i<m;i++)
{
scanf("%d %d",&a,&b);
if(a==0)
a=-1;
x=a*b*(t->fx);
if(x<0)
{
for(j=0;j<-x;j++)
{
t=t->last;
}
}
else
{
for(j=0;j<x;j++)
{
t=t->next;
}
}
}
printf("%s",t->name);
return 0;
}
正儿八经题解
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
struct node
{
char name[10];
int fx;
}list[1000001];
int main()
{
int i,j,n,m,a,b,x,p=0;
scanf("%d %d",&n,&m);
for(i=0;i<n;i++)
{
scanf("%d %s",&list[i].fx,list[i].name);
if(list[i].fx==1)
{
list[i].fx=-1;
}
if(list[i].fx==0)
{
list[i].fx=1;
}
}
for(i=0;i<m;i++)
{
scanf("%d %d",&a,&b);
if(a==0)
a=-1;
x=a*b*(list[p].fx);
p+=x;
if(p<0)
{
p=p%n;
p=p+n;
}
else
{
p=p%n;
}
}
printf("%s",list[p].name);
return 0;
}