博客
关于我
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/

    你可能感兴趣的文章
    nodejs 读取xlsx文件内容
    查看>>
    nodejs 运行CMD命令
    查看>>
    nodejs-mime类型
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs字符与字节之间的转换
    查看>>
    NodeJs学习笔记001--npm换源
    查看>>
    NodeJs学习笔记002--npm常用命令详解
    查看>>
    nodejs封装http请求
    查看>>
    nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
    查看>>
    Nodejs异步回调的处理方法总结
    查看>>
    NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
    查看>>
    Nodejs教程09:实现一个带接口请求的简单服务器
    查看>>
    nodejs服务端实现post请求
    查看>>
    nodejs框架,原理,组件,核心,跟npm和vue的关系
    查看>>
    Nodejs模块、自定义模块、CommonJs的概念和使用
    查看>>
    nodejs端口被占用原因及解决方案
    查看>>