这时singersinger告诉小南一个谜題: “眼镜藏在我左数第3个玩具小人的右数第11个玩具小人的左数第22个玩具小人那里。
小南发现, 这个谜题中玩具小人的朝向非常关键, 因为朝内和朝外的玩具小人的左右方向是相反的: 面朝圈内的玩具小人, 它的左边是顺时针方向, 右边是逆时针方向; 而面向圈外的玩具小人, 它的左边是逆时针方向, 右边是顺时针方向。
emsp小南一边艰难地辨认着玩具小人, 一边数着:
singersinger朝内, 左数第33个是archerarcher。
archerarcher朝外,右数第11个是thinkerthinker。
thinkerthinker朝外, 左数第22个是writewriter。
所以眼镜藏在writerwriter这里!
虽然成功找回了眼镜, 但小南并没有放心。 如果下次有更多的玩具小人藏他的眼镜, 或是谜題的长度更长, 他可能就无法找到眼镜了 。 所以小南希望你写程序帮他解决类似的谜題。 这样的谜題具体可以描述为:
有 nn个玩具小人围成一圈, 已知它们的职业和朝向。现在第11个玩具小人告诉小南一个包含mm条指令的谜題, 其中第 zz条指令形如“左数/右数第ss,个玩具小人”。 你需要输出依次数完这些指令后,到达的玩具小人的职业。
输入的第一行包含两个正整数 n,m ,表示玩具小人的个数和指令的条数. 接下来n行,每行包含一个证书和一个字符创,一逆时针顺序给出每个玩具小人的朝向和职业.其中 0 表示朝向圈内 1 表示朝向圈外保证不会出现其他的数。字符串长度不超过 1010 且仅由小写字母构成,字符串不为空,并且字符串两两不同。整数和字符串之间用一个空格隔开。 接下来 m 行,其中第 i行包含两个证书ai,si ,表示第i条指令,若 ai=0,表示向左数si个人;若ai = 1,表示向右数 si个人,保证ai不会出现其他的数,1<= si < n.
输出一个字符串,表示从第一个读入的小人开始,依次数完 mm 条指令后到达的小人的职业。
/* 输入输出样例 7 3 0 singer 0 reader 0 mengbier 1 thinker 1 archer 0 writer 1 mogician 0 3 1 1 0 2 运行结果: writer */ package blue.luogu; import java.util.Scanner; public class P1563 { public static void main(String[] args) { Scanner in = new Scanner(System.in); int n, m; n = in.nextInt();//小人的个数 m = in.nextInt();//指令的条数 person[] person = new person[n]; for (int i = 0; i < n; i++) {//输入小人的朝向和职业 int temp = in.nextInt();//临时借用 String str = in.next(); person[i] = new person(temp, str); } int ji = 0;//作为移动时候的角标 for (int i = 0; i < m; i++) {//输入指令 方向和个数 int f, ge; f = in.nextInt();//方向 ge = in.nextInt();//移动个数 if (person[ji].chaoxiang == 0 && f == 0) {//移动方向判断 ji -= ge; } else if (person[ji].chaoxiang == 0 && f == 1) { ji += ge; } else if (person[ji].chaoxiang == 1 && f == 0) { ji += ge; } else if (person[ji].chaoxiang == 1 && f == 1) { ji -= ge; } while(ji < 0 || ji >= n) { if (ji < 0) {//防止数组越界 ji += n; } else if (ji >= n) { ji -= n; } } } System.out.println(person[ji].name); } public static class person {//创建对象类 int chaoxiang; String name; public person(int fangx, String name) { this.chaoxiang = fangx; this.name = name; } //getset方法 public int getChaoxiang() { return chaoxiang; } public void setChaoxiang(int chaoxiang) { this.chaoxiang = chaoxiang; } public String getName() { return name; } public void setName(String name) { this.name = name; } } }题目链接:P1563 玩具谜题