| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 562 人关注过本帖
标题:大矩形切割为小矩形的题目
取消只看楼主 加入收藏
a2659633
Rank: 2
等 级:论坛游民
帖 子:25
专家分:25
注 册:2010-12-15
结帖率:50%
收藏
 问题点数:0 回复次数:2 
大矩形切割为小矩形的题目
将a*b的矩形剪切为c*d的矩形,我是这样的:
先简单判断max(a,b)>=max(c,d)&&min(a,b)>=min(c,d),这样剪切成功。
再考虑沿着对角线切,k是矩形a*b对角线,H是对角线k上的高,x=min(c,d)/2;y=max(c,d);由相似三角形有,( len /k)=((H-x)/H);解出len=k - (k*k*x)/a*b;
判断y<=len,则剪切成功。
这样正确吗?或者给出你的判定原理
图片附件: 游客没有浏览图片的权限,请 登录注册

#include<stdio.h>
#include<math.h>
int main()
{
    int n,a,b,c,d;
    double max,min,max2,min2;
    double maxt,mint;
    scanf("%d",&n);
    while(n--)
    {
        scanf("%d%d%d%d",&a,&b,&c,&d);
        if(a*b<c*d) {printf("Cutting is impossible.\n");continue;}
        max=a>b?a:b;
        min=a>b?b:a;
        max2=c>d?c:d;
        min2=c>d?d:c;
        mint=sqrt(a*a+b*b);
        maxt=mint-(a*a+b*b)*(min2/2)/(a*b);
        if(max>=max2&&min>=min2||(max2<=maxt)) printf("Cutting is possible.\n");
                else
            printf("Cutting is impossible.\n");
    }
    return 0;
}
搜索更多相关主题的帖子: include 切割 成功 double 对角线 
2011-11-05 19:49
a2659633
Rank: 2
等 级:论坛游民
帖 子:25
专家分:25
注 册:2010-12-15
收藏
得分:0 
我提交,结果wa,求解,拜谢~

我知道,人格可以鄙视人民币,但是人民币可以打败人格。
2011-11-05 19:50
a2659633
Rank: 2
等 级:论坛游民
帖 子:25
专家分:25
注 册:2010-12-15
收藏
得分:0 
测试数据:
10 10 8 8 可以
8 8 10 10 不可以
142 142 2 198 可以

我知道,人格可以鄙视人民币,但是人民币可以打败人格。
2011-11-05 20:48
快速回复:大矩形切割为小矩形的题目
数据加载中...
 
   



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

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