Theatre Square_Codeforces

本文介绍了一种算法,用于解决用正方形覆盖特定长方形的问题。通过比较长方形的长和宽与正方形的边长,确定所需正方形的数量。文章提供了详细的解题思路及C++代码实现。

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

2017年3月1日14:00:42
题意:给三个数,前两个为组成长方形的长和宽,后一个为正方形的边长,求需要几个正方形能覆盖住长方形

解题思路: 先找到长方形的最大边长max,最小边长min,如果正方形的边长 大于max,直接输出1 return 0;
如果正方形的边长大于min,如果 max%a==0 输出max/a 否则输出 max/a+1 注意,上面这两个条件 一定要先行找出,不然
下面的操作 max/a 或 min/a 没准会出现 0 如果 max%a ==0 并且 min%a==0 输出 max/a * min*a
否则 就加一(剩余空间补全) 坑点:必须long long型,不然会溢出

代码如下:

#include <iostream>
#include <cstdio>
int main(){
    long long n,m,a;
    scanf("%lld %lld %lld",&n,&m,&a);
    long long max=n>=m?n:m;
    long long min=n>m?m:n;
    if(a>=max){
        printf("1\n");
        return 0;
    }
    if(a>=min){
        if(max%a!=0)
            printf("%lld\n",(max/a+1));
        else
            printf("%lld\n",max/a);
        return 0;
    }
    if(max%a){
        if(min%a)
            printf("%lld\n",(max/a+1)*(min/a+1));
        else
            printf("%lld\n",(max/a+1)*(min/a));
        return 0;
    }
    else{
        if(min%a)
            printf("%lld\n",(max/a)*(min/a+1));
        else
            printf("%lld\n",(max/a)*(min/a));
        return 0;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值