1 条题解

  • 0
    @ 2025-8-24 23:09:57

    自动搬运

    查看原文

    来自洛谷,原作者为

    avatar Charged_Charge
    Stealth

    搬运于2025-08-24 23:09:57,当前版本为作者最后更新于2025-06-21 12:16:33,作者可能在搬运后再次修改,您可在原文处查看最新版

    自动搬运只会搬运当前题目点赞数最高的题解,您可前往洛谷题解查看更多

    以下是正文


    洛谷 P11751

    题目大意:

    给定两个字母加密方式,输出解密后的字符串。

    解题思路:

    按照题目模拟即可。注意,只有连续且完整的加密串有效,所以,我们手动把开头与结尾的加密串加上一个点,放便后面的判断。然后,我们只需要遍历一遍字符串,按照 vw 的判断方法对往后连续 44 个和 88 个字符进行判断,看这些字符满足哪个字母的判断条件,就输出那个字母。

    AC 代码:

    #include<bits/stdc++.h>
    using namespace std;
    int n;
    string s, c;
    int main() {
    	cin >> n;
    	cin >> s >> c;
    	s = "." + s + ".";
    
    	for (int i = 0; i < n; i++) {
    		if (s[i] == '.' && s[i + 1] == '\\' && s[i + 2] == '.' && s[i + 3] == '.' && s[i + 4] == '/' && s[i + 5] == '.') {
    			cout << 'v';
    		} else if (s[i] == '.' && s[i + 1] == '\\' && s[i + 2] == '.' && s[i + 3] == '.' && s[i + 4] == '/' && s[i + 5] == '\\' && s[i + 6] == '.' && s[i + 7] == '.' && s[i + 8] == '/' && s[i + 9] == '.') {
    			cout << 'w';
    		}
    	}
    
    	return 0;
    }
    
    • 1

    信息

    ID
    11520
    时间
    1000ms
    内存
    512MiB
    难度
    1
    标签
    递交数
    0
    已通过
    0
    上传者