| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1464 人关注过本帖
标题:现在你有个大小的矩形,现在你要把他们全部拼在一起,问怎样拼接才能使它们 ...
只看楼主 加入收藏
bjjbcbk
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2015-11-19
结帖率:66.67%
收藏
已结贴  问题点数:20 回复次数:8 
现在你有个大小的矩形,现在你要把他们全部拼在一起,问怎样拼接才能使它们的周长最小,输出最小的周长
图片附件: 游客没有浏览图片的权限,请 登录注册
搜索更多相关主题的帖子: 大小 矩形 全部 最小 输出 
2018-03-18 16:58
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:10 
发现bug编辑掉~

[此贴子已经被作者于2018-3-20 23:03编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-03-18 18:52
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:10 
我来补充一下原理~
所有用正方形拼接成的图形周长都是偶数~
因为每一条边都可以找到与其对应的一条邻边~
所以可以说周长是所以长边x加所有宽边y的和*2
也就是说让x+y的和最小~
然而知道总个数就等于知道总面积~
所以这样让长边和宽边尽量接近的情况下周长最小了~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-03-18 20:12
bjjbcbk
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2015-11-19
收藏
得分:0 
回复 2楼 九转星河
感激不尽
2018-03-18 23:03
Scinfip
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2018-3-20
收藏
得分:0 
回复 3楼 九转星河
我想请教下,如果输入为15的时候,貌似输出是14,好像结果不对哦
收到的鲜花
  • 九转星河2018-03-20 23:02 送鲜花  10朵   附言:难得发现bug一只~
2018-03-20 21:46
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 5楼 Scinfip
那正确结果是啥~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-03-20 21:48
Scinfip
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2018-3-20
收藏
得分:0 
回复 6楼 九转星河
我觉得应该是16吧
2018-03-20 22:40
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 7楼 Scinfip
这个看看有没有问题~

程序代码:

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

unsigned fun( unsigned );

int main( void )
{
    unsigned s;
    
    scanf("%u",&s);
    
    printf("%u\n",fun(s));

    return 0;
}

unsigned fun( unsigned s )
{
    unsigned d;
    
    assert(s-1<1e6);
    
    d=sqrt(s);
    
    return 2*(d+ceil(1.*s/d));
}


[此贴子已经被作者于2018-3-21 00:14编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2018-03-20 23:01
Scinfip
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2018-3-20
收藏
得分:0 
回复 8楼 九转星河
基本懂了,谢谢大佬

[此贴子已经被作者于2018-3-21 00:07编辑过]

2018-03-20 23:27
快速回复:现在你有个大小的矩形,现在你要把他们全部拼在一起,问怎样拼接才能使 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.038827 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved