5532  Almost Sorted Array

题目大意:给你一个序列,如果它拿掉其中一个数后,可以是该序列成为非递减或非递增序列,则输出YES。

有两种思路,第一种代码比较简单,是LIS,复杂度nlogn,第二种是On的复杂度。

LIS的代码如下。

 #include <set>
 #include <queue>
 #include <cstdio>
 #include <vector>
 #include <cstring>
 #include <algorithm>
 using namespace std;
 typedef long long LL;
 #define mem(x,y) memset(x, y, sizeof(x))
 #define lson l,m,rt << 1
 #define rson m+1,r,rt << 1 | 1

 const int INF = 0x3f3f3f3f;
 ;
 int s[maxn], dp[maxn];
 int T, n;
 bool judge()
 {
     mem(dp, INF);
     ; i < n; i++)
     {
         *upper_bound(dp, dp + n, s[i]) = s[i];
     }
     int len = lower_bound(dp, dp + n, INF) - dp;
     mem(dp, INF);
     ; i < n; i++)
     {
         *upper_bound(dp, dp + n, -s[i]) = -s[i];
     }
     int len2 =  lower_bound(dp, dp + n, INF) - dp;
     len = max(len2, len);

     );
 }

 int main()
 {
     scanf("%d",&T);
     while(T--)
     {
         scanf("%d", &n);
         ; i < n; i++)
         {
             scanf("%d", s+i);
         }
         printf("%s\n", judge() ? "YES" : "NO");
     }
     ;
 }

5533  Dancing Stars on Me题意:给你n个点对,然后求一个正多边形(当然是凸的)。问存不存在。

题目给的坐标都是整数,看一看那个tanα = 1 / n (n = 1, 2, 3, 4,....)好像只有α = 45°的时候才有可能构成正多边形。

然后瞎搞搞。。

#include <cstdio>
#include <algorithm>
using namespace std;
;
int T, n;
];
struct ss{int x, y;}s[maxn];
int get_dis(int x1, int y1, int x2, int y2)
{
    return  (x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2);
}

int main()
{
    scanf("%d", &T);
    while(T--)
    {
        scanf("%d", &n);
        ; i < n; i++)
        {
            scanf("%d%d", &s[i].x, &s[i].y);
        }
        ) {printf("NO\n");continue;}

        , tot = ;
        ; i < n; i++)
        {
            ; j < n; j++)
            {
                temp[tot] = get_dis(s[i].x, s[i].y, s[j].x, s[j].y);
                tot++;
            }
        }
        sort(temp, temp + tot);
        ] == temp[]) ok = ;
        printf("%s\n", ok ? "YES" : "NO");
    }
    ;
}

5536  Chip Factory

题意:在数组a中找到三个数满足,ai+aj ^ ak 的值最大且i,j,k各不相同。

经典的异或用01字典树,推荐使用数组形式,快而且内存小。

 #include <cstdio>
 #include <cstring>
 #include <algorithm>
 using namespace std;
 typedef long long LL;
  + ;
  * maxn;
 int n, T;
 LL a[maxn];
 LL sz, ch[maxnode][], val[maxnode];

 void init()
 {
     sz = ;
     memset(ch[], , ]));
 }

 //d=1表示插入,d=-1表示删除
 void trie_update(LL x, int d)
 {
     ;
     ; i >= ; i--)
     {
         ;
         if(!ch[u][c])
         {
             memset(ch[sz], , sizeof(ch[sz]));
             val[sz] = ;
             ch[u][c] = sz++;
         }
         u = ch[u][c];
         val[u] += d;
     }
 }

 LL trie_query(LL v)
 {
     LL ans = ;
     ;
     ; i >= ; i--)
     {
         ;
         ] && val[ch[u][c ^ ]])
         {
             ans |= ( << i);
             u = ch[u][c ^ ];
         }
         else u = ch[u][c];
     }
     return ans;
 }

 int main()
 {
     scanf("%d", &T);
     while(T--)
     {
         init();
         scanf("%d", &n);
         ; i < n; i++)
         {
             scanf("%I64dd", a + i);
             trie_update(a[i], );
         }

         LL ans = (a[] + a[]) ^ a[];
         ; i < n; i++)
         {
             trie_update(a[i], -);
             ; j < n; j++)
             {
                 trie_update(a[j], -);
                 LL temp = trie_query((LL)a[i] + a[j]);
                 ans = max(ans, temp);
                 trie_update(a[j], );
             }
             trie_update(a[i], );
         }

         printf("%I64d\n", ans);
     }

     ;
 }

5538  House Building

题意:求这个东西的表面积。

 #include <cstdio>
 #include <algorithm>
 using namespace std;
 int n, m, T;
 #define judge(x, y) 0 <= x && x < n && 0 <= y && y < m
 ][];
 , , -, };
 , -, , };
 int main()
 {
     scanf("%d", &T);
     while(T--)
     {
         , bottom = , cnt = ;
         scanf("%d%d", &n, &m);
         ; i < n; i++)
         {
             ; j < m; j++)
             {
                 scanf("%d", &ma[i][j]);
                 tot += ma[i][j];
                 if(ma[i][j])        bottom++;
                 )    cnt += (ma[i][j] - ) * ;
             }
         }
          * tot - bottom - cnt;
         ;
         ; i < n; i++)
         {
             ; j < m; j++)
             {
                 ; k < ; k++)
                 {
                     int fx = i + dx[k];
                     int fy = j + dy[k];
                     if(judge(fx, fy))
                     {
                         d += min(ma[fx][fy], ma[i][j]);
                     }
                 }
             }

         }
         ans -= d;
         printf("%d\n", ans);
     }
     ;
 }

2015ACM/ICPC亚洲区长春站的更多相关文章

  1. 2015ACM/ICPC亚洲区长春站 L hdu 5538 House Building

    House Building Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) ...

  2. 2015ACM/ICPC亚洲区长春站 J hdu 5536 Chip Factory

    Chip Factory Time Limit: 18000/9000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)T ...

  3. 2015ACM/ICPC亚洲区长春站 H hdu 5534 Partial Tree

    Partial Tree Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)To ...

  4. 2015ACM/ICPC亚洲区长春站 G hdu 5533 Dancing Stars on Me

    Dancing Stars on Me Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  5. 2015ACM/ICPC亚洲区长春站 F hdu 5533 Almost Sorted Array

    Almost Sorted Array Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Ot ...

  6. 2015ACM/ICPC亚洲区长春站 E hdu 5531 Rebuild

    Rebuild Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total S ...

  7. 2015ACM/ICPC亚洲区长春站 B hdu 5528 Count a * b

    Count a * b Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Tot ...

  8. 2015ACM/ICPC亚洲区长春站 A hdu 5527 Too Rich

    Too Rich Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  9. HDU-5532//2015ACM/ICPC亚洲区长春站-重现赛-F - Almost Sorted Array/,哈哈,水一把区域赛的题~~

    F - Almost Sorted Array Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

随机推荐

  1. 69个经典Spring面试题和答案

    Spring 是个java企业级应用的开源开发框架.Spring主要用来开发Java应用,但是有些扩展是针对构建J2EE平台的web应用.Spring 框架目标是简化Java企业级应用开发,并通过PO ...

  2. BZOJ4570: [Scoi2016]妖怪

    题目传送门 4570: [Scoi2016]妖怪 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 491 Solved: 125 [Submit][Sta ...

  3. apache2.4 绿色版环境配置。

    http://jingyan.baidu.com/article/9faa723152c5d6473d28cb47.html http://jingyan.baidu.com/article/9faa ...

  4. python3--函数(函数,全局变量和局部变量,递归函数)

    1.1函数 1.1.1什么是函数 函数就是程序实现模块化的基本单元,一般实现某一功能的集合.函数名:就相当于是程序代码集合的名称参数:就是函数运算时需要参与运算的值被称作为参数函数体:程序的某个功能, ...

  5. Java框架Struts2

    struts2的核心和工作原理   在学习struts2之前,首先我们要明白使用struts2的目的是什么?它能给我们带来什么样的好处? 设计目标 Struts设计的第一目标就是使MVC模式应用于we ...

  6. 统计SqlServer每张表内的数据量

    CREATE TABLE #temp (TableName VARCHAR (255), RowCnt INT)EXEC sp_MSforeachtable 'INSERT INTO #temp SE ...

  7. javascript 高级程序设计 -有感

    本来我想写一个高级程序设计总结的,结果发现我进入了一扇门,里面所有的字都要逐字逐句的理解,所有描述已经是非常精炼了,我最初的想法无异于老鼠吃大象. 我现在记录的是我在看这本时的感想. 2015.4月9 ...

  8. Shell入门教程:流程控制(6)while 循环

    while循环的语法: while 条件测试 do     命令区域 done 举例: #!/bin/bash declare -i i=1 declare -i sum=0 while ((i< ...

  9. T-SQL 语句的优化

    SQL调优. 1.索引是数据库调优的最根本的优化方法.聚簇索引.非聚簇索引. 聚簇索引:物理序与索引顺序相同.(只能有一个) 非聚簇索引:物理顺序与索引顺序不相同. 2.调整WHERE 子句中的连接顺 ...

  10. MySQL的语句执行顺序

    MySQL的语句执行顺序 MySQL的语句一共分为11步,如下图所标注的那样,最先执行的总是FROM操作,最后执行的是LIMIT操作.其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入 ...