【模拟+面积计算+PI精度控制】HDU-1065 I Think I Need a Houseboat

本文介绍了一种计算特定条件下半圆面积及其随时间增长的算法。通过给定圆上的点坐标,利用勾股定理求得半径,进而计算半圆面积,并确定面积达到特定数值所需的最小年数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
在这里插入图片描述

注解

1、给定圆上一点x,y坐标,求以原点为圆心的经过(x,y)的半圆面积。每年面积增长50,问此面积最少是第几年后才能达到?
2、已知x,y坐标,根据勾股定理方便求出圆的半径的平方就是xx+yy,然后可以求出半圆面积PIrr/2.0。再除以50,取上底板(ceil),就是答案。
3、注意PI的精度,精度不对会导致答案错误。

代码

#include <iostream>
#include <cmath>

using namespace std;

const double PI = 3.1415926;

int main() {
    int N;
    scanf("%d", &N);
    for(int i=1; i<=N; i++){
        double x, y;
        scanf("%lf%lf", &x, &y);
        double area = PI * (x*x+y*y) / 2.0;
        int year = ceil(area/50.0);
        printf("Property %d: This property will begin eroding in year %d.\n", i, year);
    }
    printf("END OF OUTPUT.\n");
    return 0;
}

结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值