PAT 1048 数字加密

PAT 1048 数字加密

题目描述

思路讲解

分析:首先将a和b倒置,将字符串a和b中较短的那个末尾添加0直到两个字符串长度相等,然后从0开始依次处理每一位,如果当前位是奇数位(i % 2 == 0)则将a[i]的数字加上b[i]的数字再对13取余,结果添加在字符串c的末尾;如果是偶数位,计算b[i]和a[i]的差值,如果小于0就加10,然后将结果添加在字符串c的末尾,最后倒序输出字符串c~

代码展示

cpp 复制代码
#include <iostream>
#include <algorithm>

using namespace std;

int main() {
    string a, b, c;
    cin >> a >> b;

    int lena = a.length(), lenb = b.length();

    reverse(a.begin(), a.end());
    reverse(b.begin(), b.end());

    if (lena > lenb)
        b.append(lena - lenb, '0');
    else
        a.append(lenb - lena, '0');

    char str[14] = {"0123456789JQK"};

    for (int i = 0; i < a.length(); i++) {
        if (i % 2 == 0) {
            c += str[(a[i] - '0' + b[i] - '0') % 13];
        }
        else {
            int temp = b[i] - a[i];
            if (temp < 0) temp = temp + 10;
            c += str[temp];
        }
    }
    for (int i = c.length() - 1; i >= 0; i--)
        cout << c[i];

    return 0;
}
相关推荐
八个程序员3 分钟前
c++——探讨a÷b(long long)
开发语言·c++
77wpa3 分钟前
VS Code(Visual Studio Code)开发调试 C/C++ 工程配置
c++·vscode
bxlj_jcj14 分钟前
分布式ID方案、雪花算法与时钟回拨问题
分布式·算法
墨染点香15 分钟前
LeetCode 刷题【179. 最大数】
算法·leetcode·职场和发展
失忆已成习惯.19 分钟前
西农数据结构第四次实习题目参考
数据结构·算法·图论
kyle~19 分钟前
排序---堆排序(Heap Sort)
数据结构·c++·算法
yesyesido26 分钟前
3D在线魔方模拟器
科技·算法·3d·生活·业界资讯·交友·帅哥
王老师青少年编程26 分钟前
线性DP第12课:线性DP应用案例实践:数字三角形
c++·动态规划·dp·线性dp·csp·信奥赛·数字三角形
是苏浙30 分钟前
蓝桥杯备战day1
算法
汉克老师31 分钟前
CCF-NOI2025第一试题目与解析(第二题、序列变换(sequence))
c++·算法·动态规划·noi