码迷,mamicode.com
首页 > 数据库 > 详细

MemSQL Start[c]UP 2.0 - Round 1(无聊练手B题)

时间:2014-08-08 09:34:46      阅读:281      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   io   for   art   

http://codeforces.com/contest/452/problem/B
 
B. 4-point polyline
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

You are given a rectangular grid of lattice points from (0, 0) to (n, m) inclusive. You have to choose exactly 4 different points to build a polyline possibly with self-intersections and self-touching. This polyline should be as long as possible.

A polyline defined by points p1, p2, p3, p4 consists of the line segments p1 p2, p2 p3, p3 p4, and its length is the sum of the lengths of the individual line segments.

Input

The only line of the input contains two integers n and m (0 ≤ n, m ≤ 1000). It is guaranteed that grid contains at least 4 different points.

Output

Print 4 lines with two integers per line separated by space — coordinates of points p1, p2, p3, p4 in order which represent the longest possible polyline.

Judge program compares your answer and jury‘s answer with 10 - 6 precision.

Sample test(s)
input
1 1
output
1 1
0 0
1 0
0 1
input
0 10
output
0 1
0 10
0 0
0 9

 

 

------------------------------------------------------------------------------------------------------------------

说的是给你一个矩形区域,让你画三条线,怎样画使得线最长

根据n和m的大小,有四种画法,一是X型,一是斜对角的Z型

#include<cstdio>
#include<cmath>
using namespace std;
int main()
{
    int n,m;
    scanf("%d%d",&n,&m);
    if(n==0)
    {
        printf("0 1\n0 %d\n0 0\n0 %d\n",m,m-1);
    }
    else if(m==0)
    {
        printf("1 0\n%d 0\n0 0\n%d 0\n",n,n-1);
    }
    else if(m>=n)
    {
        if(2*sqrt(m*m+n*n)+m<sqrt(m*m+n*n)+2*sqrt(m*m+(n-1)*(n-1))) printf("1 0\n%d %d\n0 0\n%d %d\n",n,m,n-1,m);
        else printf("0 0\n%d %d\n%d 0\n0 %d\n",n,m,n,m);
    }
    else
    {
        if(2*sqrt(m*m+n*n)+n<sqrt(m*m+n*n)+2*sqrt((m-1)*(m-1)+n*n)) printf("0 1\n%d %d\n0 0\n%d %d\n",n,m,n,m-1);
        else printf("0 0\n%d %d\n0 %d\n%d 0\n",n,m,m,n);
    }
    return 0;
}

 

 

MemSQL Start[c]UP 2.0 - Round 1(无聊练手B题),布布扣,bubuko.com

MemSQL Start[c]UP 2.0 - Round 1(无聊练手B题)

标签:style   blog   http   color   os   io   for   art   

原文地址:http://www.cnblogs.com/ccccnzb/p/3898599.html

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