码迷,mamicode.com
首页 > 其他好文 > 详细

P1014 Cantor表

时间:2017-06-18 11:55:10      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:font   break   cst   color   scan   main   blog   amp   bsp   

洛谷 p1014

题目描述

现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的。他是用下面这一张表来证明这一命题的:

1/1 1/2 1/3 1/4 1/5 …

2/1 2/2 2/3 2/4 …

3/1 3/2 3/3 …

4/1 4/2 …

5/1 …

… 我们以Z字形给上表的每一项编号。第一项是1/1,然后是1/2,2/1,3/1,2/2,…

输入输出格式

输入格式:

 

整数N(1≤N≤10000000)

 

输出格式:

 

表中的第N项

 

输入输出样例

输入样例#1:
7
输出样例#1:
1/4

【思路】找规律
【code】
#include<iostream>
#include<cstdio>
using namespace std;
int n,k=1,cnt;
int main()
{
    scanf("%d",&n);
    while(1)
    {
        if(n-k>=0)
        n-=k,cnt++,k++;//cnt表示第几层。 
        else
        break;
    }
    if(!n)
    printf("%d/%d\n",1,cnt);
    else
    if((cnt+1)&1)
        printf("%d/%d\n",k-n+1,n);
    else
        printf("%d/%d\n",n,k-n+1);
    return 0;
}

 



P1014 Cantor表

标签:font   break   cst   color   scan   main   blog   amp   bsp   

原文地址:http://www.cnblogs.com/zzyh/p/7043605.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!