这道题看了刘汝佳的代码真的是天秀, 很值得学习。

具体看代码

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<cctype>
  4. #include<map>
  5. #define REP(i, a, b) for(int i = (a); i < (b); i++)
  6. using namespace std;
  7. const int MAXN = 51234;
  8. struct node
  9. {
  10. string s;
  11. int l, r;
  12. node(string s = "", int l = 0, int r = 0) : s(s), l(l), r(r) {}
  13. bool operator < (const node& rhs) const //map用设置优先级
  14. {
  15. if(s != rhs.s) return s < rhs.s;
  16. if(l != rhs.l) return l < rhs.l;
  17. return r < rhs.r;
  18. }
  19. }s[MAXN];
  20. map<node, int> g;
  21. int done[MAXN], kase, cnt, k;
  22. string str;
  23. int solve()
  24. {
  25. string cur;
  26. while(isalpha(str[k])) cur += str[k++]; //string很方便, 当作一个数直接加就ok了
  27. int id = ++cnt; //不知道要不要的时候先预留一个id, 然后不要cnt--, 很轻松就删除了。
  28. node& t = s[id] = node(cur, 0, 0); //变量名不想打那么长所以引用来偷懒
  29. if(str[k] == '(') //根据括号来拓展
  30. {
  31. k++;
  32. t.l = solve(); k++;
  33. t.r = solve(); k++;
  34. }
  35. if(g[t]) { cnt--; return g[t]; } //去掉重复
  36. return g[t] = id;
  37. }
  38. void print(int u)
  39. {
  40. if(done[u] == kase) //省去了清零, 秀!
  41. {
  42. printf("%d", u);
  43. return;
  44. }
  45. done[u] = kase;
  46. cout << s[u].s; //学习这种输出方式,先输出根节点, 然后递归。
  47. if(s[u].l != 0)
  48. {
  49. putchar('(');
  50. print(s[u].l);
  51. putchar(',');
  52. print(s[u].r);
  53. putchar(')');
  54. }
  55. }
  56. int main()
  57. {
  58. int T;
  59. scanf("%d", &T);
  60. for(kase = 1; kase <= T; kase++)
  61. {
  62. g.clear();
  63. cin >> str;
  64. k = cnt = 0;
  65. print(solve()); //两个函数一起写
  66. puts("");
  67. }
  68. return 0;
  69. }

紫书 例题 11-1 UVa 12219 (表达式树)的更多相关文章

  1. 紫书 例题 11-13 UVa 10735(混合图的欧拉回路)(最大流)

    这道题写了两个多小时-- 首先讲一下怎么建模 我们的目的是让所有点的出度等于入度 那么我们可以把点分为两部分, 一部分出度大于入度, 一部分入度大于出度 那么显然, 按照书里的思路,将边方向后,就相当 ...

  2. 紫书 例题8-3 UVa 1152(中途相遇法)

    这道题要逆向思维, 就是求出答案的一部分, 然后反过去去寻找答案存不存在. 其实很多其他题都用了这道题目的方法, 自己以前都没有发现, 这道题专门考这个方法.这个方法可以没有一直往下求, 可以省去很多 ...

  3. 紫书 例题8-12 UVa 12627 (找规律 + 递归)

    紫书上有很明显的笔误, 公式写错了.g(k, i)的那个公式应该加上c(k-1)而不是c(k).如果加上c(k-1)那就是这一次 所有的红气球的数目, 肯定大于最下面i行的红气球数 我用的是f的公式, ...

  4. 紫书 例题8-4 UVa 11134(问题分解 + 贪心)

     这道题目可以把问题分解, 因为x坐标和y坐标的答案之间没有联系, 所以可以单独求两个坐标的答案 我一开始想的是按照左区间从小到大, 相同的时候从右区间从小到大排序, 然后WA 去uDebug找了数据 ...

  5. 紫书 例题8-17 UVa 1609 (构造法)(详细注释)

    这道题用构造法, 就是自己依据题目想出一种可以得到解的方法, 没有什么规律可言, 只能根据题目本身来思考. 这道题的构造法比较复杂, 不知道刘汝佳是怎么想出来的, 我想的话肯定想不到. 具体思路紫书上 ...

  6. 紫书 例题 9-5 UVa 12563 ( 01背包变形)

    总的来说就是价值为1,时间因物品而变,同时注意要刚好取到的01背包 (1)时间方面.按照题意,每首歌的时间最多为t + w - 1,这里要注意. 同时记得最后要加入时间为678的一首歌曲 (2)这里因 ...

  7. 紫书 例题 10-26 UVa 11440(欧拉函数+数论)

    这里用到了一些数论知识 首先素因子都大于M等价与M! 互质 然后又因为当k与M!互质且k>M!时当且仅当k mod M! 与M!互质(欧几里得算法的原理) 又因为N>=M, 所以N!为M! ...

  8. 紫书 例题7-14 UVa 1602(搜索+STL+打表)

    这道题想了很久不知道怎么设置状态,怎么拓展,怎么判重, 最后看了这哥们的博客 终于明白了. https://blog.csdn.net/u014800748/article/details/47400 ...

  9. 紫书 例题 10-2 UVa 12169 (暴力枚举)

    就是暴力枚举a, b然后和题目给的数据比较就ok了. 刘汝佳这道题的讲解有点迷,书上讲有x1和a可以算出x2, 但是很明显x2 = (a * x1 +b) 没有b怎么算x2?然后我就思考了很久,最后去 ...

随机推荐

  1. vscode代码格式化 空格的配置

    一个项目中同事使用webstorm,看我代码的时候说我传上去的会多出空格, VSCode 编辑 Setting.json文件,列出一些可以配置的项目   "javascript.format ...

  2. UVALive-8072 Keeping On Track 树形dp 联通块之间缺失边的个数

    题目链接:https://cn.vjudge.net/problem/UVALive-8072 题意 给出n+1个点和n条边,每对点之间只能存在一条边. 现在要找出一个节点,使得去掉这个点后,所剩每对 ...

  3. python3编写登录接口

    #/usr/bin/env python#yehui'''作业一:博客 作业二:编写登陆接口 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定'''import getpass, os, pic ...

  4. [terry笔记]学校管理系统

    如下是要求: # 角色:学校.学员.课程.讲师# 要求:# 1. 创建北京.上海 2 所学校# 2. 创建linux , python , go 3个课程 , linux\py 在北京开, go 在上 ...

  5. Mysql怎么样避免全表扫描,sql查询优化

    对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引: 尝试下面的技巧以避免优化器错选了表扫描: 使用ANALYZE TABLE tbl_name为扫 ...

  6. 协议栈处理中的conntrack HASH查找/Bloom过滤/CACHE查找/大包与小包/分层处理风格

    1.路由CACHE的优势与劣势 分级存储体系已经存在好多年了.其精髓在于"将最快的存储器最小化.将最慢的存储器最大化",这样的结果就使资源利用率的最大化.既提高了訪问效率,又节省了 ...

  7. CC2540/CC2541 : Set the Peripheral Being Advertising while It is Being Connected

    There is possible to set your CC254X be scanable when it is in connection. But, based on my test,the ...

  8. bzoj1218: [HNOI2003]激光炸弹(DP二维前缀和)

    1218: [HNOI2003]激光炸弹 题目:传送门 题解: 一道经典题目啊... 为了更好的操作...把整个坐标系向右上角移动,从(1,1)开始 那么f[i][j]统计一下以(i,j)作为右上角, ...

  9. hdoj--3592--World Exhibition(差分约束)

    World Exhibition Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  10. HTML5学习笔记(一):HTML5基本概念

    1.HTML的发展历程 HTML(1994年,W3C成立) HTML2(1995年) HTML3(1996年) HTML4.0(1997年) HTML4.01(1999年)——HTML5(2008年: ...