博客
关于我
PAT乙级刷题记录——1048 数字加密 (20分)
阅读量:215 次
发布时间:2019-02-28

本文共 1347 字,大约阅读时间需要 4 分钟。

这个问题需要实现一种数字加密方法,具体规则如下:

  • 输入处理:首先读取两个大数A和B,确保它们的长度相同,前面补0。
  • 反转字符串:将A和B反转,使得最低位(个位)在前面,最高位在后面。
  • 处理每一位
    • 奇数位(第1、3、5...位):将B的数字与A的数字相加,结果对13取余,余数为10时用J代替。
    • 偶数位(第2、4、6...位):将B的数字减去A的数字,如果结果为负数,加10得到结果。
  • 结果反转:将加密后的结果反转,得到最终加密后的字符串。
  • 代码优化思路

    • 使用字符串处理,避免整数溢出的问题。
    • 避免使用任何循环结构,尽量使用内置函数。
    • 确保代码结构清晰,符合C++的编程规范。

    以下是优化后的代码:

    #include 
    #include
    using namespace std;int main() { string A, B; cin >> A >> B; // 补零使长度相同 while (B.length() < A.length()) { B.insert(B.begin(), '0'); } // 反转处理 reverse(A.begin(), A.end()); reverse(B.begin(), B.end()); string result; for (int i = 0; i < A.length(); ++i) { int a = A[i] - '0'; int b = B[i] - '0'; if ((i + 1) % 2 == 0) { // 偶数位 int diff = b - a; if (diff < 0) { diff += 10; } result += (diff + '0'); } else { // 奇数位 int sum = a + b; int rem = sum % 13; if (rem == 12) { result += 'J'; } else { result += rem + '0'; } } } reverse(result.begin(), result.end()); cout << result; return 0;}

    代码解释

    • 输入处理:读取A和B,确保B的长度与A相同。
    • 反转处理:反转A和B,使得逐个处理时,第一个字符是最低位。
    • 循环处理每一位
      • 偶数位:计算差值,若结果为负加10。
      • 奇数位:计算和对13取余,余数为10时用J代替。
    • 结果反转:将结果反转,得到最终加密后的字符串输出。

    这个思路确保了处理大数的高效性,并且代码结构清晰易懂。

    转载地址:http://iqtp.baihongyu.com/

    你可能感兴趣的文章
    mysql8.0新特性-自增变量的持久化
    查看>>
    Mysql8.0注意url变更写法
    查看>>
    Mysql8.0的特性
    查看>>
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>