OpenJudge-NOI-1.5.16-买房子

一、题目链接

http://noi.openjudge.cn/ch0105/16/

二、解题思路

⑴ 设定一个int变量ans,代表买得起房的年份,初始时ans为-1,代表买不起房;
⑵ 设定两个double变量savings、price,分别代表程序员的总积蓄、房价,初始时:
		savings = N,price = 200;
⑶ 显然,从第1年开始,到第20年为止,通过循环,做如下操作:
	① 如果程序员的总积蓄savings大于等于房价price,代表当年能够买得起房,令ans为当前年份,然后直接
	退出循环;否则,代表当年买不起房,更新总积蓄和房价:
		savings = savings + N,price = price + price * K / 100
⑷ 循环结束后,如果ans不等于-1,则输出ans;否则输出Impossible。

三、程序代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int N = input.nextInt(); // 程序员的年薪
        int K = input.nextInt(); // 房价的年增长率
        double savings = N; // 程序员的总积蓄
        double price = 200; // 房价,初始为200
        int ans = -1; // 买得起房的年份,初始为-1,代表买不起房
        /* 从第1年开始,到第20年为止 */
        for (int i = 1; i <= 20; i++) {
            if (savings >= price) { // 如果当前年份能够买得起房
                ans = i; // 则首先记录当前年份
                break; // 然后直接退出循环
            }
            else { // 否则,当前年份买不起房
                savings = savings + N; // 继续增加积蓄
                price = price + price * K / 100; // 房价继续上涨
            }
        }
        // 根据ans的值输出是否买得起房
        System.out.print(ans == -1 ? "Impossible" : ans);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江苏科技大学_计算机学院_潘磊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值