C语言求弦数

本文介绍了如何使用C语言编写代码来查找5到100之间的弦数,通过判断给定半径r下是否存在正整数解x和y满足x^2+y^2=r^2,利用圆的对称性优化搜索范围,时间复杂度为O(n^2)。
摘要由CSDN通过智能技术生成

问题:用C语言求5-100的弦数

弦数:一个正整数x其平方等于某两个正整数的平方和,例如: 3 2 + 4 2 = 5 2 3^2+4^2=5^2 32+42=52,则5为弦数。

解:

首先判断一个数字r是不是弦数,另外两个数字为x,y,问题转换为:对于半径为r的圆: x 2 + y 2 = r 2 x^2+y^2=r^2 x2+y2=r2是否存在正整数解,由圆的对称性,我们只需要在 x ∈ [ 1 , r 2 ] x\in[1,\frac{r}{\sqrt 2}] x[1,2 r]上,即角度在 ( π / 4 , π / 2 ) 的 (\pi/4,\pi/2)的 (π/4,π/2)圆上寻找解,将x代入圆的方程后,求解y,并确认y是否为整数。

#include <stdio.h>
#include <math.h>
#include <stdlib.h>
int main()
{
	/*****code here********/
	int x,r;
	float y;
	printf("弦数有:\n");
	for(r=5;r<100;r++)
		for(x=1;x<r/sqrt(2);x++)
		{
			y = sqrt(r*r-x*x);
			if(y==(int)y)
			{
				printf("%d,坐标(%d,%f)\n",r,x,y);
				break;
			}
		}
	/*****code here********/
	system("pause");
	return 0;
}	

时间复杂度为O( n n n)

  • 44
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值