博客
关于我
P1014_Cantor表 (JAVA语言)
阅读量:151 次
发布时间:2019-02-27

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

为了解决这个问题,我们需要找到Cantor表中的第N项。Cantor表是一个有理数序列,按照特定的规律排列。我们的目标是通过给定的N,确定其对应的分数。

方法思路

  • 确定所在行:Cantor表中的每一行代表不同的分母,行号k的第一个元素的位置可以通过三角数公式来确定。三角数T(k) = k*(k+1)/2表示前k行的最后一个元素的位置。
  • 二分查找行号:使用二分查找来确定行号k,使得T(k) >= N。这个过程确保我们能准确找到N所在的行。
  • 确定位置:找到行号后,计算N在该行中的位置m。分数即为m/k。
  • 解决代码

    import java.util.Scanner;public class P1014_Cantor表 {    public static void main(String[] args) {        Scanner in = new Scanner(System.in);        int n = in.nextInt();        int low = 1;        int high = 200000;        int k_row = 0;        while (low <= high) {            int mid = (low + high) / 2;            long T_mid = (long) mid * (mid + 1) / 2;            if (T_mid < n) {                low = mid + 1;            } else {                high = mid - 1;            }        }        k_row = low;        int m = n - (k_row - 1) * k_row / 2;        System.out.println(m + "/" + k_row);    }}

    代码解释

  • 输入读取:使用Scanner读取输入的整数N。
  • 二分查找行号:通过二分查找确定N所在的行号k_row,使得三角数T(k_row) >= N。
  • 计算位置:计算N在该行中的位置m,分数即为m/k_row。
  • 输出结果:将分子和分母用"/"连接,输出结果。
  • 这种方法确保了高效准确地找到Cantor表中的第N项,并且适用于较大的N值。

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

    你可能感兴趣的文章
    OSG学习:人机交互——普通键盘事件:着火的飞机
    查看>>
    OSG学习:几何体的操作(一)——交互事件、简化几何体
    查看>>
    OSG学习:几何体的操作(二)——交互事件、Delaunay三角网绘制
    查看>>
    OSG学习:几何对象的绘制(一)——四边形
    查看>>
    OSG学习:几何对象的绘制(三)——几何元素的存储和几何体的绘制方法
    查看>>
    OSG学习:几何对象的绘制(二)——简易房屋
    查看>>
    OSG学习:几何对象的绘制(四)——几何体的更新回调:旋转的线
    查看>>
    OSG学习:场景图形管理(一)——视图与相机
    查看>>
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>
    OSG学习:空间变换节点和开关节点示例
    查看>>
    OSG学习:纹理映射(一)——多重纹理映射
    查看>>
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>