记录编号 35811 评测结果 AAAAAAAAAAA
题目名称 法雷序列 最终得分 100
用户昵称 GravatarTBK 是否通过 通过
代码语言 C++ 运行时间 0.017 s
提交时间 2012-03-03 17:00:39 内存使用 0.42 MiB
显示代码纯文本
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <string>
#include <iomanip>
using namespace std;
int a,b,c,d=1,t;
struct fun
{
	double x;
	int y;
	int z;
}f[10000];
int Compare( const void *elem1 , const void *elem2 )
{
	struct fun *elem3 = (struct fun *)elem1;
	struct fun *elem4 = (struct fun *)elem2;
	return (elem3->x > elem4->x)?1:-1;
}
int gcd(int p,int q)
{
	if (p==0) return q;
	if (q==0) return p;
	if (p<q)
	{
		t=p;
		p=q;
		q=t;
	}
	if (p%q==0) return q;
	return gcd(q,p%q);
}
int main(void)
{
	freopen ("frac1.in","r",stdin);
	freopen ("frac1.out","w",stdout);
	scanf("%d",&a);
	if (a==0) exit(0);	
	f[0].x=0;
	f[0].y=0;
	f[0].z=1;
	for (b=1;b<=a;b++)
		for (c=a;c>=b;c--)
			if (gcd(b,c)==1)
			{
				f[d].x=(double)((double)b/(double)c);
				f[d].y=b;
				f[d].z=c;
				d++;
			}
	qsort(f,d,sizeof(fun),Compare);
	for (b=0;b<d;b++) printf("%d/%d\n",f[b].y,f[b].z);
	fclose(stdin);
	fclose(stdout);
	return 0;
}