设为首页 加入收藏

TOP

关于状压DP的一道题(五)
2013-12-05 13:05:43 来源: 作者: 【 】 浏览:559
Tags:关于 一道

 

  //状态转移过程

  for (int i = 2 ; i < n ; i ++ ) {

  for (int j = 0 ; j < num[i - 1] ; j ++ ) {

  for (int k = 0 ; k < num[i] ; k ++ ) {

  if((M[i] & st[k][i])|| (M[i - 1] & st[j][i - 1]) ||

  ((st[j][i - 1] << 1) & st[k][i]) || ((st[j][i - 1] >> 1) & st[k][i]))continue ;

  if(st[j][i - 1] & st[k][i])continue ;

  for (int l = 0 ; l < num[i - 2] ; l ++ ) {

  if((M[i - 2] & st[l][i - 2] )|| (st[l][i - 2] & st[j][i - 1])) continue ;

  if(((st[l][i - 2] >> 1) & st[j][i - 1]) || ((st[l][i - 2] << 1) & st[j][i - 1]))continue ;

  if(!dp[(i + 2) % 3][l][j]) continue ;

  int s = (st[l][i - 2] >> 2 ) & st[k][i] ;//右下

  if(s) {

  s <<= 1 ;

  if((s & M[i - 1]) != s)continue ;

  }

  s = (st[l][i - 2] << 2 ) & st[k][i] ;//左下

  if(s) {

  s >>= 1 ;

  if((s & M[i - 1]) != s)continue ;

  }

  s = (st[l][i - 2]) & st[k][i] ;//上方

  if(s){

  if((s & M[i - 1]) != s)continue ;

  }

  dp[i % 3][j][k] = max(dp[i % 3][j][k] , dp[(i + 2) % 3][l][j] + Count[k][i]) ;

  ans = max(ans ,dp[i % 3][j][k]) ;

  // bug ;

  }

  }

  }

  }

  cout << ans << endl ;

  }

  return 0 ;

  }

        

首页 上一页 2 3 4 5 6 7 8 下一页 尾页 5/9/9
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇二进制位最后出现1的概率 下一篇对每个宝藏进行一次SPFA

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·PostgreSQL 索引 - (2025-12-25 22:20:43)
·MySQL Node.js 连接 (2025-12-25 22:20:41)
·SQL 撤销索引、表以 (2025-12-25 22:20:38)
·Linux系统简介 (2025-12-25 21:55:25)
·Linux安装MySQL过程 (2025-12-25 21:55:22)