社区讨论

大蒟蒻求助

P1563[NOIP 2016 提高组] 玩具谜题参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lo84biyy
此快照首次捕获于
2023/10/27 12:33
2 年前
此快照最后确认于
2023/10/27 12:33
2 年前
查看原帖
原代码(WA两个点九十)
CPP
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int n,m;
struct node
{
	int head;
	string name;
}a[N];
int main()
{
	ios::sync_with_stdio(false);
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i].head>>a[i].name;
	}
	int now=1;
	int x,y;
    for(int i=1;i<=m;i++)
    {
        cin>>x>>y;
        if(a[now].head==0&&x==0)now=(now+n-y)%n;
        else if(a[now].head==0&&x==1)now=(now+y)%n;
        else if(a[now].head==1&&x==0)now=(now+y)%n;
        else if(a[now].head==1&&x==1)now=(now+n-y)%n;
    }
    cout<<a[now].name;
}
按照题解微调后(100)
CPP
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5;
int n,m;
struct node
{
	int head;
	string name;
}a[N];
int main()
{
	ios::sync_with_stdio(false);
	cin>>n>>m;
	for(int i=0;i<n;i++)
	{
		cin>>a[i].head>>a[i].name;
	}
	int now=0;
	int x,y;
    for(int i=1;i<=m;i++)
    {
        cin>>x>>y;
        if(a[now].head==0&&x==0)now=(now+n-y)%n;
        else if(a[now].head==0&&x==1)now=(now+y)%n;
        else if(a[now].head==1&&x==0)now=(now+y)%n;
        else if(a[now].head==1&&x==1)now=(now+n-y)%n;
    }
    cout<<a[now].name;
}

唯一区别就是读入人物朝向和姓名时,从从1开始读,now=1,改为从0开始读,now=0.

回复

0 条回复,欢迎继续交流。

正在加载回复...