线段树的任意一棵子树都相当于节点数与该子树相同的线段树。于是假装在树形dp即可,记忆化搜索实现,有效状态数是logn级别的。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<algorithm>
  7. #include<map>
  8. using namespace std;
  9. #define ll long long
  10. #define P 998244353
  11. char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<''||c>'')) c=getchar();return c;}
  12. int gcd(int n,int m){return m==?n:gcd(m,n%m);}
  13. int read()
  14. {
  15. int x=,f=;char c=getchar();
  16. while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
  17. while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
  18. return x*f;
  19. }
  20. ll n;
  21. map<ll,ll> f[],g[];
  22. void solve(ll n)
  23. {
  24. if (g[].find(n)!=g[].end()) return;
  25. ll lson=n+>>,rson=n-lson;
  26. solve(lson),solve(rson);
  27. f[][n]=max(f[][lson],f[][lson])+max(f[][rson],f[][rson]);
  28. f[][n]=max(f[][lson]+max(f[][rson],f[][rson]),f[][rson]+max(f[][lson],f[][lson]))+;
  29. ll x=f[][lson]==f[][lson]?g[][lson]+g[][lson]:(f[][lson]>f[][lson]?g[][lson]:g[][lson]);
  30. ll y=f[][rson]==f[][rson]?g[][rson]+g[][rson]:(f[][rson]>f[][rson]?g[][rson]:g[][rson]);
  31. g[][n]=x*y%P;
  32. if (f[][lson]+max(f[][rson],f[][rson])==f[][rson]+max(f[][lson],f[][lson]))
  33. g[][n]=(g[][lson]*y+x*g[][rson])%P;
  34. else if (f[][lson]+max(f[][rson],f[][rson])>f[][rson]+max(f[][lson],f[][lson])) g[][n]=g[][lson]*y%P;
  35. else g[][n]=x*g[][rson]%P;
  36. return;
  37. }
  38. int main()
  39. {
  40. #ifndef ONLINE_JUDGE
  41. freopen("bzoj5123.in","r",stdin);
  42. freopen("bzoj5123.out","w",stdout);
  43. const char LL[]="%I64d\n";
  44. #else
  45. const char LL[]="%lld\n";
  46. #endif
  47. cin>>n;f[][]=,f[][]=-n,g[][]=,g[][]=;
  48. solve(n);
  49. if (f[][n]==f[][n]) cout<<f[][n]<<' '<<(g[][n]+g[][n])%P;
  50. else if (f[][n]>f[][n]) cout<<f[][n]<<' '<<g[][n];
  51. else cout<<f[][n]<<' '<<g[][n];
  52. return ;
  53. }

BZOJ5123 线段树的匹配(树形dp)的更多相关文章

  1. 【bzoj5123】[Lydsy12月赛]线段树的匹配 树形dp+记忆化搜索

    题目描述 求一棵 $[1,n]$ 的线段树的最大匹配数目与方案数. $n\le 10^{18}$ 题解 树形dp+记忆化搜索 设 $f[l][r]$ 表示根节点为 $[l,r]$ 的线段树,匹配选择根 ...

  2. BZOJ1758[Wc2010]重建计划——分数规划+长链剖分+线段树+二分答案+树形DP

    题目描述 输入 第一行包含一个正整数N,表示X国的城市个数. 第二行包含两个正整数L和U,表示政策要求的第一期重建方案中修建道路数的上下限 接下来的N-1行描述重建小组的原有方案,每行三个正整数Ai, ...

  3. CF700E Cool Slogans SAM、线段树合并、树形DP

    传送门 在最优的情况下,序列\(s_1,s_2,...,s_k\)中,\(s_i (i \in [2 , k])\)一定会是\(s_{i-1}\)的一个\(border\),即\(s_i\)同时是\( ...

  4. bzoj千题计划164:bzoj5123: 线段树的匹配

    http://www.lydsy.com/JudgeOnline/upload/201712/prob12.pdf dp[len][0/1] 表示节点表示区间长度为len,节点选/不选的 最大匹配 s ...

  5. 【Codeforces720D】Slalom 线段树 + 扫描线 (优化DP)

    D. Slalom time limit per test:2 seconds memory limit per test:256 megabytes input:standard input out ...

  6. [基本操作]线段树分治和动态dp

    不知道为什么要把这两个没什么关系的算法放到一起写...可能是都很黑科技? 1.线段树分治 例题:bzoj4026 二分图 给你一个图,资瓷加一条边,删一条边,询问当前图是不是二分图 如果用 LCT 的 ...

  7. [HDU4867]Xor (线段树分治+类数位dp)

    [HDU4867]Xor (线段树分治+类数位dp) 提供一种\((m+n) log a log m\)带有常数约\(\frac{1}{log n}\)的算法 处理询问,将后来加入的数算进序列中,则每 ...

  8. 1304F2 - Animal Observation (hard version) 线段树or单调队列 +DP

    1304F2 - Animal Observation (hard version) 线段树or单调队列 +DP 题意 用摄像机观察动物,有两个摄像机,一个可以放在奇数天,一个可以放在偶数天.摄像机在 ...

  9. bzoj5123 [Lydsy12月赛]线段树的匹配

    题意: 线段树是这样一种数据结构:根节点表示区间 [1, n]:对于任意一个表示区间 [l, r] 的节点,若 l < r, 则取 mid = ⌊l+r/2⌋,该节点的左儿子为 [l, mid] ...

随机推荐

  1. 如何打war包和jar包

    1.jar包的导出 答:右键项目,export—jarfile  生成. 2.war包的导入 答:方法一:右键项目,export—WAR file 生成. 方法二:[ant文件]—[deploy-be ...

  2. Fiddler 抓包https配置 提示:creation of the root certificate was not successful 证书安装不成功

    window7 提示:creation of the root certificate was not successful 证书安装不成功 1.cmd 命令行   找到fiddler的安装目录  如 ...

  3. adb server version (31) doesn't match this client (39) 解决方案

    adb server version (31) doesn't match this client (39) 问题的解决方案, 在cmd中输入adb nodaemon server -a后解决了, 记 ...

  4. python容器类型的协议

    1.协议(Protocols)与其他编程语言中的接口恒相似,它规定你哪些地方必须要定义,然而在python中的协议就显得不那么正式,事实上,在python中,协议更像是一种指南. 2.序列类型和映射类 ...

  5. 使用request+Beautiful爬取妹子图

    一.request安装 pip install requests request使用示例 import requests response = requests.get('https://www.mz ...

  6. happybase(TSocket read 0 bytes)

    关于报错happybase 是使用python连接hbase的一个第三方库,目前基于thrift1 .在使用过程中经常碰到报错 TTransportException(type=4, message= ...

  7. socket 编程 : shutdown vs close

    TCP/IP 四次挥手 首先作者先描述一下TCP/IP 协议中四次挥手的过程,如果对此已经熟悉的读者可以跳过本节. 四次挥手 这是一个很经典的示例图,众所周知tcp socket 在一个生命周期中有很 ...

  8. linux一切皆文件之文件描述符(一)

    一.知识准备 1.在linux中,一切皆为文件,所有不同种类的类型都被抽象成文件.如:普通文件.目录.字符设备.块设备.套接字等 2.当一个文件被进程打开,就会创建一个文件描述符.这时候,文件的路径就 ...

  9. RabbitMQ和Kafka,更加便捷高效的消息队列使用方式,请放心食用

    一.RabbitMQ实例介绍RabbitMQ实例由华为云分布式消息服务(DMS)团队打造,实例采用物理隔离的方式部署,租户独占RabbitMQ实例.一键式部署,完全兼容开源RabbitMQ的使用方式, ...

  10. 在js中保存数据

    localStorage: localStorage.setItem("key", "value"); localStorage.getItem("k ...