设为首页 加入收藏

TOP

CSU1664: 防水堤坝
2015-11-21 00:59:12 来源: 作者: 【 】 浏览:2
Tags:CSU1664: 防水 堤坝

Description

在太平洋的一个小岛上,岛民想要建立一个环岛的堤坝,我们可以将小岛简化为一个二维平面,你需要使用K条边(这些边要么是水平或者垂直长度为1的边,要么是45度倾斜的长度为√2的边)围成一个多边形,多边形的顶点必须位于整点,然后要让围成的多边形面积最大,你需要求出最大面积是多少。

Input

输入包含多个测试实例,每组实例给出一个数K。(3≤K≤2000000000)

Output

每一行对应一个要求的答案。(保留一位小数)

Sample Input

3
4
5
6

Sample Output

0.5
2.0
2.5
4.0

HINT

?

Source


中文不需要解释题意了,这道题关键还是画图。。。找规律,真的是很坑,k=7的时候一开始怎么画都是4.5,后来终于才发现是5.5 总之比较蛋疼的一题
#include 
  
   
#include 
   
     #include 
    
      #include 
     
       #include 
      
        #include 
       
         #include
         #include 
         
           #include 
          
            #include 
           
             #include 
            
              #include 
             
               #include 
              
                #include 
               
                 using namespace std; #define lson 2*i #define rson 2*i+1 #define LS l,mid,lson #define RS mid+1,r,rson #define UP(i,x,y) for(i=x;i<=y;i++) #define DOWN(i,x,y) for(i=x;i>=y;i--) #define MEM(a,x) memset(a,x,sizeof(a)) #define W(a) while(a) #define gcd(a,b) __gcd(a,b) #define LL long long #define N 200005 #define INF 0x3f3f3f3f #define EXP 1e-8 #define lowbit(x) (x&-x) const int mod = 1e9+7; int main() { LL n,x,y; LL ans; while(~scanf("%lld",&n)) { ans = 0; x = n/4; y = n%4; if(y<2) ans = 4*x*x; else ans = 4*x*(x+1); if(y==1) ans+=2*x-1; else if(y==3) ans+=2*x+1; if(ans&1) printf("%lld.5\n",ans/2); else printf("%lld.0\n",ans/2); } return 0; } 
               
              
             
            
           
          
         
       
      
     
    
   
  


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇CSU1661: Query Mutiple 下一篇CSU1656: Paper of FlyBrother(后..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: