题目链接

异或的性质。 求s到t的最少步骤, 等价于求0到s^t的最少步骤。



通过最少的步骤达到s^t的状态, 等价于求0到s^t的最短路。 先将最短路求出来然后O(1)查询。

  1. #include <iostream>
  2. #include <vector>
  3. #include <cstdio>
  4. #include <cstring>
  5. #include <algorithm>
  6. #include <complex>
  7. #include <cmath>
  8. #include <map>
  9. #include <set>
  10. #include <string>
  11. #include <queue>
  12. #include <stack>
  13. #include <bitset>
  14. using namespace std;
  15. #define pb(x) push_back(x)
  16. #define ll long long
  17. #define mk(x, y) make_pair(x, y)
  18. #define lson l, m, rt<<1
  19. #define mem(a) memset(a, 0, sizeof(a))
  20. #define rson m+1, r, rt<<1|1
  21. #define mem1(a) memset(a, -1, sizeof(a))
  22. #define mem2(a) memset(a, 0x3f, sizeof(a))
  23. #define rep(i, n, a) for(int i = a; i<n; i++)
  24. #define fi first
  25. #define se second
  26. typedef complex <double> cmx;
  27. typedef pair<int, int> pll;
  28. const double PI = acos(-1.0);
  29. const double eps = 1e-8;
  30. const int mod = 1e9+7;
  31. const int inf = 1061109567;
  32. const int dir[][2] = { {-1, 0}, {1, 0}, {0, -1}, {0, 1} };
  33. const int maxn = 1e6+5;
  34. int vis[maxn], dis[maxn], a[16], head[maxn], num;
  35. struct node
  36. {
  37. int to, nextt;
  38. }e[maxn*10];
  39. void init() {
  40. mem1(head);
  41. num = 0;
  42. }
  43. void add(int u, int v) {
  44. e[num].to = v, e[num].nextt = head[u], head[u] = num++;
  45. }
  46. void spfa() {
  47. queue<pll> q;
  48. q.push(mk(0, 0));
  49. mem(vis);
  50. mem2(dis);
  51. dis[0] = 0;
  52. vis[0] = 1;
  53. while(!q.empty()) {
  54. pll tmp = q.front(); q.pop();
  55. for(int i = head[tmp.se]; ~i; i = e[i].nextt) {
  56. int v = e[i].to;
  57. if(vis[v])
  58. continue;
  59. vis[v] = 1;
  60. if(dis[v]>dis[tmp.se]+1) {
  61. dis[v] = dis[tmp.se]+1;
  62. q.push(mk(-dis[v], v));
  63. }
  64. }
  65. }
  66. }
  67. void solve() {
  68. int n, m;
  69. cin>>n>>m;
  70. for(int i = 0; i < n; i++) {
  71. scanf("%d", &a[i]);
  72. }
  73. for(int i = 0; i <= 1e5; i++) {
  74. for(int j = 0; j < n; j++) {
  75. add(i, a[j]^i);
  76. }
  77. for(int j = 0; j < 17; j++) {
  78. add(i, i^(1<<j));
  79. }
  80. }
  81. spfa();
  82. ll ans = 0;
  83. int s, t;
  84. for(int i = 1; i <= m; i++) {
  85. scanf("%d%d", &s, &t);
  86. s ^= t;
  87. ans += i*dis[s];
  88. ans %= mod;
  89. }
  90. cout<<ans<<endl;
  91. }
  92. int main()
  93. {
  94. int t;
  95. cin>>t;
  96. while(t--) {
  97. init();
  98. solve();
  99. }
  100. return 0;
  101. }

hdu 5637 Transform 最短路的更多相关文章

  1. HDU 5637 Transform 单源最短路

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5637 题意: http://bestcoder.hdu.edu.cn/contests/contes ...

  2. HDU 5637 Transform 搜索

    题意:bc round 74 div1 1002 中文题 分析(官方题解):注意到答案实际上只和s⊕t有关, bfs预处理下从0到xx的最短步数, 然后查询O(1)回答即可. #include < ...

  3. HDU 5637 Transform

    题意: 有两种变换: 1. 改变此数二进制的某一位(1变成0 或者 0变成1) 2. 让它与给出的n个数当中的任意一个做异或运算 给你两个数s, t,求从s到t最少要经过几步变换,一共m组查询思路: ...

  4. hdu 5637 BestCoder Round #74 (div.2)

    Transform  Accepts: 7  Submissions: 49  Time Limit: 4000/2000 MS (Java/Others)  Memory Limit: 131072 ...

  5. hdu 4568 Hunter 最短路+dp

    Hunter Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  6. hdu2112(HDU Today 简单最短路)

    Problem Description 经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强.这时候,XHD ...

  7. F - JDG HDU - 2112 (最短路)&& E - IGNB HDU - 1242 (dfs)

    经过锦囊相助,海东集团终于度过了危机,从此,HDU的发展就一直顺风顺水,到了2050年,集团已经相当规模了,据说进入了钱江肉丝经济开发区500强.这时候,XHD夫妇也退居了二线,并在风景秀美的诸暨市浬 ...

  8. HDU 5521.Meeting 最短路模板题

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  9. poj 3463/hdu 1688 求次短路和最短路个数

    http://poj.org/problem?id=3463 http://acm.hdu.edu.cn/showproblem.php?pid=1688 求出最短路的条数比最短路大1的次短路的条数和 ...

随机推荐

  1. C# AES,AesManaged使用学习

    加密 static byte[] EncryptBytes_Aes(byte[] plainText, byte[] Key, byte[] IV) { // Check arguments. ) t ...

  2. 标准C++的vector使用

    原文:http://blog.csdn.net/pandy1110/article/details/5963908 C++内置的数组支持容器的机制,但是它不支持容器抽象的语义.要解决此问题我们自己实现 ...

  3. ARP网关占用

    30网段已经发生了2次ARP了 排查方法:我直去核心交换机直连镜像口,用wireshark抓包,过滤出ARP的包 发现的确有ARP的攻击,因为没有统计公司电脑和无线路由的MAC地址,所以只能一个个把无 ...

  4. 27 Remove Element

    Given an array and a value, remove all instances of that value in place and return the new length. T ...

  5. HttpServletRequest 报错 myeclipese支持tomcat

    做WEB项目的时候,别人拷贝了一份源码给你导入myeclipse结果发现一堆报错 HttpServletRequest  一排红色波浪线..... 这个原因主要是没有tomcat下的一个jar包 se ...

  6. LinkList的实现

    public class MyLinkedList<AnyType> implements Iterable<AnyType> { @Override public Itera ...

  7. ajax 数据回传

    response.getWriter().print(reval > 0 ? true : false); //=========================== Object[] str ...

  8. Linux01--文件管理,常用命令 权限管理

    一.Ø文件系统 1.Linux文件系统特点  • Linux文件系统为单根的树状结构  •文件系统根为”/”  •文件名大小写敏感,除了”/”都是可用字符文件名以”.”开始的为隐藏文件  •文件路径使 ...

  9. 学javascript突发奇想,只用浏览器就能转换进制

    只需要三行就可以了 具体代码如下 <script> document.write(new Number(8).toString(2));//toSting方法可以转换任何进制 </s ...

  10. 拓扑排序(TopologicalSort)算法

    拓扑排序算法应用: 有些事情做都需要按照流程的去做,比如你准备约你小女友去影院看速度与激情7大片,首先你想的是我怎么到达影院,然后达到影院,你可以先买票,或者等小女友来了一起买票,然后一起进电影大厅. ...