栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

Cantor 表 {C语言解法}

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Cantor 表 {C语言解法}

现代数学的著名证明之一是 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≤10^7)。

输出格式

表中的第 N 项。

例:

7

1/4  

暴力法
#include
int main()
{

    int up=1,down=1;//up分子,down分母
    int num;
    int flag=1;//计数器
    int temp;//中介变量
    scanf("%d",&num);
    while(flag!=num)
    {
        if(up==1&&down%2!=0&&flag!=num)
        {
            flag++;
            down++;
        }
        if(down==1&&up%2==0&&flag!=num)
        {
            flag++;
            up++;
        }

        if(down%2==0)
        {
            temp=up;
            while(temp!=down&&flag!=num)
            {
                down--;
                up++;
                flag++;
            }
        }
        if(up%2!=0)
        {
            temp=down;
            while(temp!=up&&flag!=num)
            {
                down++;
                up--;
                flag++;
            }
        }
    }
    printf("%d/%d",up,down);
    return 0;
}

技术法
#include
int main()
{
	int n,k=1;
	scanf("%d",&n);
	while (n>k)
	{
		n=n-k;
		k++;
	}
	if(k%2==0)
	printf("%d/%d",n,k+1-n);
	else
	printf("%d/%d",k+1-n,n);
	return 0;
}

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/513140.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号