洛谷P-1563-双向循环链表的运用

前面不是题解!!!最后一个代码才是
借用这个题目来举个例子:


题目描述
小南有一套可爱的玩具小人, 它们各有不同的职业。

有一天, 这些玩具小人把小南的眼镜藏了起来。 小南发现玩具小人们围成了一个圈,它们有的面朝圈内,有的面朝圈外。如下图:

在这里插入图片描述
这时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;
}


发布了9 篇原创文章 · 获赞 3 · 访问量 711

猜你喜欢

转载自blog.csdn.net/qq_22156483/article/details/104085532
今日推荐