zoukankan      html  css  js  c++  java
  • 2013 ACM/ICPC Asia Regional Hangzhou Online hdu4739 Zhuge Liang's Mines

    Zhuge Liang's Mines

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 44    Accepted Submission(s): 9

    Problem Description
    In the ancient three kingdom period, Zhuge Liang was the most famous and smartest military leader. His enemy was Shima Yi, who always looked stupid when fighting
    against Zhuge Liang. But it was Shima Yi who laughed to the end. 
    Once, Zhuge Liang sent the arrogant Ma Shu to defend Jie Ting, a very important fortress. Because Ma Shu is the son of Zhuge Liang's good friend Ma liang, even Liu
    Bei, the Ex. king, had warned Zhuge Liang that Ma Shu was always bragging and couldn't be used, Zhuge Liang wouldn't listen. Shima Yi defeated Ma Shu and took Jie
    Ting. Zhuge Liang had to kill Ma Shu and retreated. To avoid Shima Yi's chasing, Zhuge Liang put some mines on the only road. Zhuge Liang deployed the mines in a
    Bagua pattern which made the mines very hard to remove. If you try to remove a single mine, no matter what you do ,it will explode. Ma Shu's son betrayed Zhuge
    Liang , he found Shima Yi, and told Shima Yi the only way to remove the mines: If you remove four mines which form the four vertexes of a square at the same time,
    the removal will be success. In fact, Shima Yi was not stupid. He removed as many mines as possible. Can you figure out how many mines he removed at that time?
    The mine field can be considered as a the Cartesian coordinate system. Every mine had its coordinates. To simplify the problem, please only consider the squares which
    are parallel to the coordinate axes.
     
    Input
    There are no more than 15 test cases. In each test case:
    The first line is an integer N, meaning that there are N mines( 0 < N <= 20 ).
    Next N lines describes the coordinates of N mines. Each line contains two integers X and Y, meaning that there is a mine at position (X,Y). ( 0 <= X,Y <= 100)
    The input ends with N = -1.
     
    Output
    For each test case ,print the maximum number of mines Shima Yi removed in a line.
     
    Sample Input
    3
    1 1
    0 0
    2 2
    8
    0 0
    1 0
    2 0
    0 1
    1 1
    2 1
    10 1
    10 0
    -1
     
    Sample Output
    0
    4
     

    先暴力找出所有的正方形(因为地雷最多只有20个,所以n^4完全没问题),再0,1背包下选那些正方形能选到最多正方形就行了。

      1 #include <iostream>
      2 #include <stdio.h>
      3 #include <algorithm>
      4 #include <string.h>
      5 #include <math.h>
      6 #include <queue>
      7 #include <map>
      8 
      9 using namespace std;
     10 typedef struct abcd
     11 {
     12     double x,y;
     13 } abcd;
     14 abcd a[30];
     15 int t;
     16 int maxa;
     17 int c[1000];
     18 int b[1000][4];
     19 bool cmp(abcd x,abcd y)
     20 {
     21     if(x.x!=y.x)return x.x<y.x;
     22     else return x.y<y.y;
     23 }
     24 void dfs(int x,int sum)
     25 {
     26     if(x>=t)
     27     {
     28         if(maxa<sum)
     29         maxa=sum;
     30         return ;
     31     }
     32     int i;
     33     int fla=0;
     34     for(i=x;i<t;i++)
     35     {
     36         if((c[b[i][0]]||c[b[i][1]]||c[b[i][2]]||c[b[i][3]])==0)
     37         {
     38             fla=1;
     39             c[b[i][0]]=1;c[b[i][1]]=1;c[b[i][2]]=1;c[b[i][3]]=1;
     40             dfs(i+1,sum+4);
     41             c[b[i][0]]=0;c[b[i][1]]=0;c[b[i][2]]=0;c[b[i][3]]=0;
     42         }
     43     }
     44     if(!fla)
     45     {
     46         if(maxa<sum)
     47         maxa=sum;
     48     }
     49 }
     50 int fun(int i,int j,int x,int y)
     51 {
     52     if(a[i].x==a[j].x&&a[j].x==a[x].x) return 0;
     53     if(a[i].y==a[j].y&&a[j].y==a[x].y) return 0;
     54     if(a[i].x!=a[j].x||a[x].x!=a[y].x)
     55     return 0;
     56     if(a[i].y!=a[x].y||a[j].y!=a[y].y)
     57     return 0;
     58     if(a[j].y-a[i].y!=a[x].x-a[i].x)
     59     return 0;
     60     else return 1;
     61 }
     62 int main()
     63 {
     64     int n;
    
     65     while(scanf("%d",&n))
     66     {
     67         if(n==-1)
     68             break;
     69         int i,j,x,y;
     70         for(i=0; i<n; i++)
     71         {
     72             scanf("%lf%lf",&a[i].x,&a[i].y);
     73         }
     74         sort(a,a+n,cmp);
     75         memset(c,0,sizeof(c));
     76         maxa=0;
     77         t=0;
     78         for(i=0; i<n; i++)
     79         {
     80             for(j=i+1; j<n; j++)
     81             {
     82                 for(x=j+1; x<n; x++)
     83                 {
     84                     for(y=x+1; y<n; y++)
     85                     {
     86                         if(fun(i,j,x,y))
     87                         {
     88                             b[t][0]=i;
     89                             b[t][1]=j;
     90                             b[t][2]=x;
     91                             b[t][3]=y;
     92                             t++;
     93                         }
     94                     }
     95                 }
     96             }
     97         }
     98         dfs(0,0);
     99        cout<<maxa<<endl;
    100     }
    101 }
    View Code
  • 相关阅读:
    Selenium3+python3自动化(十六)--单选框和复选框(radiobox、checkbox)
    Selenium3+python3自动化(十五)--JS处理滚动条,window.scrollTo(xpos,ypos)
    Selenium3+python3自动化(十四)--alertsconfirmprompt
    Selenium3+python3自动化(十三)--select下拉框
    Selenium3+python3自动化(十二)--iframe
    UPC-5627 Boxes(思维)
    UPC-5007 High Score(计算)
    UPC-5003 Dunglish(模拟)
    Hrbust-1830 第一个重复出现的数(线段树区间最值查询)
    UPC-5599 Minimum Sum(线段树求区间最小值+二分区间计数)
  • 原文地址:https://www.cnblogs.com/ERKE/p/3322747.html
Copyright © 2011-2022 走看看