码迷,mamicode.com
首页 > 其他好文 > 详细

HDU-5100-Chessboard

时间:2015-04-08 14:44:08      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:

题目链接

http://acm.hdu.edu.cn/showproblem.php?pid=5100

用k*1的方块覆盖n*n的正方形,最多覆盖多少

有个结论:当n%k!=0时,最多为:n*n-min(a,b);其中a=(n%k)*(n%k),b=(k-n%k)*(k-n%k);

代码

#include<stdio.h>
#include<iostream>
#include<algorithm>
using namespace std;
int main(void)
{
int num,n,k,a,b;
scanf("%d",&num);
while(num--)
{
scanf("%d %d",&n,&k);
a=(n%k)*(n%k);
b=(k-n%k)*(k-n%k);
if(k>n)
printf("0\n");
else
printf("%d\n",n*n-min(a,b));
}
return 0;
}

HDU-5100-Chessboard

标签:

原文地址:http://www.cnblogs.com/liudehao/p/4402105.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!