5573  Binary Tree(构造)

题意:给你一个二叉树,根节点为1,子节点为父节点的2倍和2倍+1,从根节点开始依次向下走k层,问如何走使得将路径上的数进行加减最终结果得到n。

联想到二进制。

思路和这个差不多吧:http://blog.csdn.net/u013068502/article/details/50094561

#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
 ? a : gcd(b, a % b);}
int lcm(int a, int b){return a / gcd(a, b) * b;}
int main()
{
    int T;
    scanf("%d", &T);
    ; cas <= T; cas++)
    {
        ;
        scanf("%d%d", &n, &k);
         == )
        {
             n--;
             flag = ;
        }
        LL all = ( << (k + )) - ;
        LL res = (all - n) >> ;
        printf("Case #%d:\n", cas);
        ; i < k; i++)
        {
            LL temp =  << i;
            )) printf( : temp);
            ) printf("%I64d -\n", temp);
            else printf("%I64d +\n", temp);
            res >>= ;
        }
    }
    ;
}            

5578  Friendship of Frog

题意:给你一个字符串,找最近的相同字符

 #include <set>
 #include <cmath>
 #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
  ? a : gcd(b, a % b);}
 int lcm(int a, int b){return a / gcd(a, b) * b;}
 const int INF = 0x3f3f3f3f;
 ];
 int main()
 {
     int T;
     scanf("%d", &T);
     getchar();
     ; cas <= T; cas++)
     {
         scanf("%s", s);
         int len = strlen(s);
         int ans = INF;
         ; i < len; i++)
         {
             ; j < len; j++)
             {
                 if(s[i] == s[j])
                 {
                     ans = min(ans, abs(i - j));
                 }
             }
         }
         printf( : ans);
     }
     ;
 }

5583  Kingdom of Black and White

题意:给你一个01字符串,要求最多改变一个字符(即0->1或1->0),使相邻相同字符的平方和最大

漏了考虑,改变中间一个区间之后,两个到三个区间变成相同字符的情况。WA了。

 #include <set>
 #include <cmath>
 #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
  ? a : gcd(b, a % b);}
 int lcm(int a, int b){return a / gcd(a, b) * b;}
 ;
 int s[maxn];
 LL len[maxn];
 int main()
 {
     int T;
     scanf("%d", &T);
     getchar();
     ; cas <= T; cas++)
     {
         mem(s, -);
         char ch;
         ;
         while(~scanf("%c", &ch))
         {
             if(ch == '\n') break;
             s[slen++] = ch - ';
         }
         , cur = , cnt = ;
         while(cur <= slen)
         {
             ])
             {
                 len[cnt++] = cur - temp;
                 temp = cur;
             }
             cur++;
         }
         LL ans = ;
         ; i < cnt; i++)
         {
             ans += len[i] * len[i];
         }
         LL rec = ans;
         ; i < cnt; i++)
         {
             ) break;
             ] ==  && i != )
             {
                 ans = max(ans,
                           rec - len[i - ] * len[i - ] - len[i - ] * len[i - ] - len[i] * len[i]
                           + (len[i - ] + len[i - ] + len[i]) * (len[i - ] + len[i - ] + len[i]));
             }
             ])
             {
                 ans = max(ans, rec +  * (len[i - ] - len[i] + ));
             }
             ])
             {
                 ans = max(ans, rec +  * (len[i] - len[i - ] + ));
             }
         }
         printf("Case #%d: %I64d\n", cas, ans);

     }
     ;
 }

5584  LCM Walk(数学推导)

题意:有一只青蛙,它从起点(x,y)出发,每次它会走  LCM(x,y)  步到达点  (x+LCM(x,y),y)  或点  (x,y+LCM(x,y))  ,最终,它会到达点(ex,ey),现给你终点(ex,ey),要你求出它的起点有多少种可能。

 #include <set>
 #include <cmath>
 #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
  ? a : gcd(b, a % b);}
 int lcm(int a, int b){return a / gcd(a, b) * b;}
 ;

 int main()
 {
     int T, fx, fy;
     scanf("%d", &T);
     ; cas <= T; cas++)
     {
         scanf("%d%d", &fx, &fy);
         LL ans = ;
         )
         {
             int g = gcd(fx, fy);
             if(fy > fx) swap(fx, fy);
             ) break;
             int m1 = fx / (fy + g);
             int m2 = fy / g;
             fx = m1 * g;
             fy = m2 * g;
             ans++;
         }
         printf();
     }
     ;
 } 

2015ACM/ICPC亚洲区上海站的更多相关文章

  1. HDU-5583-Kingdom of Black and White(2015ACM/ICPC亚洲区上海站-重现赛)

    Kingdom of Black and White                                                                           ...

  2. (HDU 5558) 2015ACM/ICPC亚洲区合肥站---Alice's Classified Message(后缀数组)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=5558 Problem Description Alice wants to send a classi ...

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

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

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

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

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

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

  6. 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 ...

  7. 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 ...

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

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

  9. 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 ...

随机推荐

  1. 单元测试与Moq

    这个篇幅里面,记录单元测试与Moq模拟包的知识点. 单元测试 每一个模块,都应该有对应的单元测试.单元测试可以保证你的代码准确性,大大减少出现BUG的几率.一个好的单元测试,也是重构代码必不可少的部分 ...

  2. <!DOCTYPE html>作用

    1.定义: DOCTYPE标签是一种标准通用标记语言的文档类型声明,它的目的是要告诉标准通用标记语言解析器,它应该使用什么样的文档类型定义(DTD)来解析文档. <!DOCTYPE> 声明 ...

  3. ppt2013技术整理

    1. 显示选择窗格 便于选择该页的所有元素.分组.隐藏与显示等. 位于:开始-编辑-选择-选择窗格 2. 显示动画窗格 便于调节页面中元素的动画状态. 位于:动画-高级动画-动画窗格 3. 绑定动画触 ...

  4. 不把C作为第一门语言是个好主意么

    ----------------------------------------------------------------------------------   不把C作为第一门语言是个好主意 ...

  5. Python学习笔记——迭代器(RandSeq和AnyIter)

    1.RandSeq #coding:utf-8 #!/usr/bin/env python 'randSeq.py -- 迭代' #从random模块里仅仅导入choice方法 from random ...

  6. 【转】Controllers and Routers in ASP.NET MVC 3

    Controllers and Routers in ASP.NET MVC 3 ambilykk, 3 May 2011 CPOL 4.79 (23 votes) Rate: vote 1vote ...

  7. 使用JVMTI创建调试和监控代理

    Java 虚拟机工具接口(JVMTI)提供了一个编程接口,允许你(程序员)创建software agent 来监视和控制你的Java应用. JVMTI 代替了原来的Java Virtual Machi ...

  8. Go - 变量初始化 及 注意事项

    Go变量 初始化 对 复合类型(数组.切片.字典.结构体)变量的初始化是,有一些语法限制: 1.初始化表达式必须包含类型标签: 2.左花括号必须在类型尾部,不能另起一行: 3.多个成员初始值以逗号分隔 ...

  9. js 制作MD5加密

    主要使用已经写好的JS插件,由于网上有很多,同时自己也可根据原理写出,但为了加快开发速度,我选择了能使用的,写得还不错的js http://pajhome.org.uk/crypt/md5/md5.h ...

  10. jquery 用attr修改src 淡入淡出

    $("#wanwan").animate({ opacity: 'toggle' }, "slow", null, function () { $(" ...