A题 Oracle

http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=703&pid=1001

大数相加:

rec[p]=;
rec[]+=k;
;i<p;i++)
)  rec[i] = rec[i] - ,rec[i+] ++ ;
)
 printf("%d",rec[p]);
 #include <cstdio>
 #include <cstring>
 ;
 int rec[maxn];
 ];
 int main()
 {
     int T;
     scanf("%d",&T);
     getchar();
     while(T--)
     {
         memset(num,,sizeof(num));
         char ch=getchar();
         ;//记录非零数的数量
         ')
         {
             ') cnt++;
             num[ ch-' ]++;
             ch=getchar();
         }
         )
         {
             printf("Uncertain\n");continue;
         }

         ;
         while (!num[k])
             k++;
         num[k]--;

         ;
         ;i<=;i++)
         {
             while(num[i])
             {
                 rec[p++] = i;
                 num[i]--;
             }
         }
         rec[p]=;
         rec[]+=k;
         ;i<p;i++)
             )  rec[i] = rec[i] - ,rec[i+] ++ ;
         )
             printf("%d",rec[p]);

         ;i>=;i--)
             putchar('+rec[i]);
         puts("");

     }
     ;
 }

B题  Arrange

http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=703&pid=1002

根据B和C数组的改变,可以推测出A数组中原序列的值。

①B数组不变,C数组变大,A[i] = C[i],可供挑选数字,增加 C[i] - C[i-1] - 1 个。

②C数组不变,B数组变小,A[i] = B[i],可供挑选数字,增加 B[i-1] - B[i] - 1 个。

③B,C数据均不变,计算一下可能的种类数

④其余情况,均说明不存在合法序列

 #include <cstdio>
  + ;
 ;
 int B[maxn],C[maxn];
 int main()
 {
     int T;
     scanf("%d",&T);
     while(T--)
     {
         int n;
         scanf("%d",&n);
         ;i < n;i++)
             scanf("%d",&B[i]);
         ;i < n;i++)
             scanf("%d",&C[i]);
         ;
         ] != C[])    flag = ;
         ;//remain
         ;
         ;i < n;i++)
         {
             ] && C[i] == C[i-])
             {
                 )    {flag = ;break;}
                 else {ans = ans * rem % mod; rem--;}
             }
             ] && C[i] > C[i-]){rem = rem + C[i] - C[i-] - ;}
             ] && C[i] == C[i-]){rem = rem + B[i-] - B[i] - ;}
             ;break;}
         }
         )   {printf("0\n");continue;}
         printf("%I64d\n",ans);
     }
     ;
 }

C题Wool

http://bestcoder.hdu.edu.cn/contests/contest_chineseproblem.php?cid=703&pid=1003

假设我们需要加入的边为c,若abc构成一个三角形,若要使c的可选择范围最小,那么即 a-b 到 a+b的范围最大(假设a>=b)

可以通过数学,发现,显然当a确定的时候,b越大,这个范围越大,所以我们对a数组进行排序后,记录相邻两个ai的a-b和a+b。

再对结点node进行排序之后,这道题的核心代码部分

ll rem=,cur_ri=L-;//longlong写成int
;i<=n;i++)
{
    )
    {
        ll l1 = cur_ri + ;
        ll r1 = node[i].left - ;
        if(l1 > R || r1 < L) continue;
        rem = rem + min(R,r1) - max(L,l1) + ;
    }
    if(cur_ri < node[i].right)  cur_ri = node[i].right;
}                                                
 #include <cstdio>
 #include <cstring>
 #include <iostream>
 #include <algorithm>
 using namespace std;
  + ;
 typedef long long ll;
 int n;
 ll L,R;
 ll a[maxn];
 struct Node
 {
     ll left,right;
 }node[maxn];
 bool cmp(const Node&a,const Node&b)
 {
     return a.left<b.left || ( (a.left == b.left) && (a.right < b.right) );
 }
 int main()
 {
     int T;
     cin>>T;
     while(T--)
     {
         cin>>n>>L>>R;
         ;i<n;i++)
             cin>>a[i];
         sort(a,a+n);

         ;i<n;i++)
         {
             node[i].left=a[i]-a[i-]+;
             node[i].right=a[i]+a[i-]-;
         }
         node[n].left = 2e18;
         sort(node+,node++n,cmp);

         ll rem=,cur_ri=L-;
         ;i<=n;i++)
         {
             )
             {
                 ll l1 = cur_ri + ;
                 ll r1 = node[i].left - ;
                 if(l1 > R || r1 < L) continue;
                 rem = rem + min(R,r1) - max(L,l1) + ;
             }
             if(cur_ri < node[i].right)  cur_ri = node[i].right;
         }
         cout<<rem<<endl;
     }
     ;

BestCoder 2nd Anniversary的更多相关文章

  1. BestCoder 2nd Anniversary的前两题

    Oracle Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total Su ...

  2. hdu 5719 BestCoder 2nd Anniversary B Arrange 简单计数问题

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5719 题意:一个数列为1~N的排列,给定mn[1...n]和mx[1...n],问有符合的排列数为多少 ...

  3. hdu 5720 BestCoder 2nd Anniversary Wool 推理+一维区间的并

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5720 题意:有n(n <= 105)个数 ,每个数小于等于 1018:问在给定的[L,R]区间中 ...

  4. BestCoder 2nd Anniversary 1001 Oracle

    找到最小的非零数字拆开来相加. 高精度. #include <iostream> #include <cstdio> #include <cstring> #inc ...

  5. BestCoder 2nd Anniversary 1002 Arrange

    排除所有不符合条件后根据当前位置上下界计算, 由于前面取的数肯定在之后的区间内,所以去掉已取的个数即可. #include <iostream> #include <cstdio&g ...

  6. BestCoder 2nd Anniversary/HDU 5719 姿势

    Arrange Accepts: 221 Submissions: 1401 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/2 ...

  7. BestCoder 2nd Anniversary/HDU 5718 高精度 模拟

    Oracle Accepts: 599 Submissions: 2576 Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 262144/26 ...

  8. 二分图点染色 BestCoder 1st Anniversary($) 1004 Bipartite Graph

    题目传送门 /* 二分图点染色:这题就是将点分成两个集合就可以了,点染色用dfs做, 剩下的点放到点少的集合里去 官方解答:首先二分图可以分成两类点X和Y, 完全二分图的边数就是|X|*|Y|.我们的 ...

  9. BestCoder 1st Anniversary($) 1003 Sequence

    题目传送门 /* 官方题解: 这个题看上去是一个贪心, 但是这个贪心显然是错的. 事实上这道题目很简单, 先判断1个是否可以, 然后判断2个是否可以. 之后找到最小的k(k>2), 使得(m-k ...

随机推荐

  1. 【Beta】Scrum03

    Info 时间:2016.12.01 21:30 时长:15min 地点:大运村1号公寓5楼楼道 类型:日常Scrum会议 NXT:2016.12.04 21:30 Task Report Name ...

  2. HTTP Content-type 对照表

    Application Type 文件扩展名 Content-Type(Mime-Type) 描述 . application/x-   .* application/octet-stream 二进制 ...

  3. Jquery动态添加的元素绑定事件的3种方法

    假设我们点击li标签,弹出他的文本,如果是动态添加的li,点击是没有效果的,压根弹不出来文本. 下面博主分享一下为动态添加的元素绑定事件的三种方法,网上一般都是两种,我在这里多增加了一种. 事件案例: ...

  4. web前端基础知识-(三)JavaScript基本操作

    JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编程代码. JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行. JavaScrip ...

  5. thinkphp语言包

    1.config.php语言包相关配置. //开启语言包 'LANG_SWITCH_ON' => true, 'LANG_AUTO_DETECT' => true, // 自动侦测语言 开 ...

  6. JSon 对象转字符的一些方法

    引用System.Web.Entity.dll public static string ToJSON(this object obj) { JavaScriptSerializer serializ ...

  7. log4jdbc 使用

    像 hibernate, mybatis 都是不打印真正执行的sql的,所以借助 log4jdbc 打印sql以及统计执行时间是非常方便的. 配置log4jdbc 有很多种方法,比如通过spring的 ...

  8. 如何快速上手使用STM32库函数

    一.背景 如前文所述,利用标准库函数的好处在于,可以快速开发,不用去对着数据手册,小心翼翼的一位一位的配置那些繁复的寄存器,因为这些工作意法半导体已经找了一些顶级的工程师帮你做了,杰作既是其库函数.当 ...

  9. HQL常用的查询语句

    摘录自某人,比较有用,比较全. // HQL: Hibernate Query Language. // 特点: // >> 1,与SQL相似,SQL中的语法基本上都可以直接使用. // ...

  10. Linux C 文件操作,系统调用 -- open()、read() 和 标准I/O库 -- fopen()、fread()

    函数汇总: open().write().read().close() fopen().fwrite().fread().fclose() 一.什么是文件 在讲述文件操作之前,我们首先要知道什么是文件 ...