博客
关于我
热身题A——The 3n + 1 problem
阅读量:201 次
发布时间:2019-02-28

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

为了解决这个问题,我们需要计算给定范围内每个数的循环长度,并找出最大值。我们将利用记忆化技术来优化计算过程,避免重复计算,提高效率。

方法思路

  • 问题分析:给定一个数n,按照特定步骤进行循环,直到得到1。我们需要计算每个数的循环长度,并找出给定范围内最大的循环长度。
  • 记忆化技术:使用一个数组记录每个数的循环长度,避免重复计算,提高效率。
  • 生成数处理:对于每个数k,处理其生成的数(3k+1和2k),预先记录它们的循环长度,进一步优化计算。
  • 解决代码

    #include 
    #include
    using namespace std;int find(int n, vector
    & vis, int i, int j) { if (n == 1) return 1; if (vis[n] != 0) return vis[n]; vis[n] = 1; // 初始化循环长度为1 if (n % 2 == 1) { int next = 3 * n + 1; if (next >= i && next <= j) { vis[next] = vis[n] - 1; // 预处理3k+1的长度 } } else { int next = 2 * n; if (next >= i && next <= j) { vis[next] = vis[n] + 1; // 预处理2k的长度 } } int cnt = 1; while (true) { n = (n % 2 == 1) ? 3 * n + 1 : n / 2; cnt++; if (n == 1) break; } vis[n] = cnt; return cnt;}int main() { vector
    vis(1000001, 0); // vis[i]存储i的循环长度 int i, j, max_len; while (true) { cin >> i >> j; if (i > j) swap(i, j); max_len = 0; for (int k = i; k <= j; ++k) { if (vis[k] == 0) { // 未计算过 int len = find(k, vis, i, j); if (len > max_len) max_len = len; } } cout << i << ' ' << j << ' ' << max_len << endl; }}

    代码解释

  • find函数:计算给定数n的循环长度,使用记忆化数组vis记录结果。
  • 预处理生成数:对于每个数k,处理其生成的数(3k+1和2k),预先记录它们的循环长度。
  • 主函数:读取输入,处理每个范围,计算并输出最大循环长度。
  • 通过这种方法,我们可以高效地处理大范围内的查询,避免重复计算,提高了性能。

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

    你可能感兴趣的文章
    none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
    查看>>
    None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
    查看>>
    NOPI读取Excel
    查看>>
    NoSQL&MongoDB
    查看>>
    NoSQL介绍
    查看>>
    Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
    查看>>
    Notepad++在线和离线安装JSON格式化插件
    查看>>
    notepad++最详情汇总
    查看>>
    notepad如何自动对齐_notepad++怎么自动排版
    查看>>
    Notification 使用详解(很全
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    Now trying to drop the old temporary tablespace, the session hangs.
    查看>>
    nowcoder—Beauty of Trees
    查看>>
    np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
    查看>>
    np.power的使用
    查看>>
    NPM 2FA双重认证的设置方法
    查看>>
    npm ERR! ERESOLVE could not resolve报错
    查看>>
    npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
    查看>>
    npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
    查看>>
    npm install digital envelope routines::unsupported解决方法
    查看>>