这道题让我有了砸电脑的冲动
题目描述
现代数学的著名证明之一是 Georg Cantor 证明了有理数是可枚举的。他是用下面这一张表来证明这一命题的:
我们以 Z 字形给上表的每一项编号。第一项是 1/11/1,然后是 1/21/2,2/12/1,3/13/1,2/22/2,…
输入格式
整数𝑁N(1≤𝑁≤1071≤N≤107)。
输出格式
表中的第 𝑁N 项。
输入输出样例
输入 #1复制
7
输出 #1复制
1/4
通过横纵坐标和的奇偶来进行模拟移动,如果为偶数,x-1,y+1;如果为奇数,x+1,y-1;当然要特判边界情况,在x-1的情况时,如果x==1就无法减1,那么就让y+=1作为下一个位置;同理,如果当前和恰好为奇数,而y==1时,就让x+=1作为下一个位置
然后就是模拟N-1步即可,第一次循环找出的是编号为2的位置,所以n-1次循环找出来的是编号为n的位置
#include<iostream>
using namespace std;
int main()
{
int n;
cin>>n;
int x=1,y=1;
for(int i=2;i<=n;i++)
{
int sum = (x+y)%2;
if(!sum)
{
if(x==1) y+=1;
else x-=1,y+=1;
}
else
{
if(y==1) x+=1;
else y-=1,x+=1;
}
}
cout<<x<<'/'<<y<<endl;
return 0;
}