Coderforces 507B 易错

背景:一直WA,一直以为是double精度问题,结果是:在运算过程中,超出int数据范围。

思路:我的思路是分类讨论,网上好的思路是ceil(d/2r)即可。

学习:

1.数据类型的范围:int 2.1的10次方

                               longlong 9.2的19次方(longlong在 linux下为%lld,windows下为%I64d).

2.这类数学类型的题,思考就好,不要畏惧!

#include<stdio.h>
#include<math.h>

int main(void){
	  long long int r,x1,y1,x2,y2;
		while(scanf("%I64d%I64d%I64d%I64d%I64d",&r,&x1,&y1,&x2,&y2)!=EOF){
			double xx=(double)((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
			double temp=sqrt(xx)-(double)r*2.0;
			int count=0;
			while(1) {
			if((temp-(double)r*2.0) >= 0){
			temp-=(double)r*2.0;
			count++;
		  }
			else break;
		  }
		  if(sqrt(xx) <= (double)r*2.0){
		  	if(xx==0.0) printf("0\n");
		  	else printf("1\n");
		  }else if(temp == 0.0){
		  	printf("%d\n",count+1);
		  }else{
		  	printf("%d\n",count+2);
		  }	
		} 
		return 0;
} 


                                                                      

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值