zoukankan      html  css  js  c++  java
  • 【NOIP模拟】妹子

    题面

    万人迷皮皮轩收到了很多妹子的礼物,由于皮皮轩觉得每个妹子都不错,所以将她们礼物的包装盒都好好保存,但长此以往皮皮轩的房间里都堆不下了,所以只能考虑将一些包装盒放进其他包装盒里节省空间。方便起见,我们不考虑包装盒的高度和厚度,只考虑包装盒的长宽。一句话题意:给出两个矩形,问是否可以将一个矩形放在另一个矩形的内部(含边界),多测。

    对于 100% 的数据,n ≤ 10,a 1 ,b 1 ,a 2 ,b 2 ≤ 1000。

    分析

    其实矩形是可以旋转的放的,所以不能直接判边长,但是旋转也很好实现,直接枚举旋转的度数。

    如图,只需要枚举这个橘色的角,再分别用三角函数算出红线和蓝线有没有超过大的矩形

    代码

    1. #include<bits/stdc++.h>  
    2. using namespace std;  
    3. #define db double  
    4. #define pi 3.14  
    5. #define deg(a) (a*pi/180)  
    6. db x,y,mx,line;  
    7. int n,a1,b1,a2,b2,ok;  
    8. template<class T>    
    9. inline void read(T &x)    
    10. {    
    11.     x=0;    
    12.     static char c=getchar();    
    13.     while(c<'0'||c>'9') c=getchar();    
    14.     while(c>='0'&&c<='9')    
    15.     x=x*10+c-'0',c=getchar();    
    16. }  
    17.   
    18. int main()  
    19. {  
    20.     read(n);  
    21.     while(n--)  
    22.     {  
    23.         read(a1),read(b1),read(a2),read(b2);ok=0;  
    24.         if(a1>b1)swap(a1,b1);if(a2>b2)swap(a2,b2);  
    25.         if(a1>a2){swap(b1,b2),swap(a1,a2);}  
    26.         if(b1<=b2){printf("Yes ");continue;}  
    27.         for(db d=0;d<=90.0;d+=(db)0.01)  
    28.             if(b1*sin(deg(d))+a1*cos(deg(d))<=a2&&a1*sin(deg(d))+b1*cos(deg(d))<=b2)  
    29.                 {printf("Yes ");ok=1;break;}  
    30.         if(!ok)printf("No ");  
    31.     }  
    32.     return 0;  
    33. }  
  • 相关阅读:
    memcached+狀態模式+工廠方法使用
    狀態模式
    UML类图
    Quartz.NET
    第四次作业---计算器的第二步
    做 fzu oj 1106 题目学到的
    做fzu oj 1045 做减法学到的sprintf()函数
    第三次补作业
    第三次作业随笔(new)包含了补作业
    远征系列---离港篇(学杂记)
  • 原文地址:https://www.cnblogs.com/NSD-email0820/p/9849633.html
Copyright © 2011-2022 走看看