zoukankan      html  css  js  c++  java
  • POJ 1038 Bugs Integrated, Inc. ——状压DP

    状态压缩一下当前各格子以及上面总共放了几块,只有012三种情况,直接三进制保存即可。

    然后转移的时候用搜索找出所有的状态进行转移。

    #include <map>
    #include <queue>
    #include <cstdio>
    #include <cstring>
    #include <iostream>
    #include <algorithm>
    using namespace std;
    #define F(i,j,k) for (int i=j;i<=k;++i)
    #define D(i,j,k) for (int i=j;i>=k;--i)
    #define ll long long
    #define mp make_pair
    #define mask(i) ((mask%pow[i+1])/pow[i])
    #define a(i) (a[x][i])
    int dp[2][500005],pow[20],n,m,k;
    int a[205][20],t,now,pre;
    void print(int mask)
    {F(i,0,m-1)printf("%d",(mask%pow[i+1])/pow[i]);}
    void dfs(int x,int y,int mask,int val)
    {
    //	printf("Dfs %d %d %d ",x,y,val); print(mask); printf("
    ");getchar();
    	if (y>=m){dp[pre][mask]=max(val,dp[pre][mask]);return;}
    	if (y+2<m&&!a(y)&&!a(y+1)&&!a(y+2)&&mask(y)==mask(y+1)&&mask(y+1)==mask(y+2))
    	{
    		if (mask(y)==1)
    		{
    //			print(mask); printf(" to ");
    			mask-=pow[y]+pow[y+1]+pow[y+2];
    //			print(mask); printf("
    ");
    			dfs(x,y+3,mask,val+1);
    			mask+=pow[y]+pow[y+1]+pow[y+2];
    		}
    		else
    		{
    //			print(mask); printf(" to ");
    			mask+=pow[y]+pow[y+1]+pow[y+2];
    //			print(mask); printf("
    ");
    			dfs(x,y+3,mask,val);
    			mask-=pow[y]+pow[y+1]+pow[y+2];
    		}
    	}
    	if (y+1<m&&!a(y)&&!a(y+1)&&mask(y)==mask(y+1))
    	{
    		if (mask(y)<2)
    		{
    //			print(mask); printf(" to ");
    			mask+=pow[y]+pow[y+1];
    //			print(mask); printf("
    ");
    			dfs(x,y+2,mask,val);
    			mask-=pow[y]+pow[y+1];
    		}
    		else
    		{
    //			print(mask); printf(" to ");
    			mask-=2*pow[y]+2*pow[y+1];
    //			print(mask); printf("
    ");
    			dfs(x,y+2,mask,val+1);
    			mask+=2*pow[y]+2*pow[y+1];
    		}
    	}
    //	printf("%d  mask (%d)
    ",mask(y),y);
    	if (!mask(y))
    	{
    		dfs(x,y+1,mask,val);
    	}
    }
    int main()
    {
    	scanf("%d",&t);
    	pow[0]=1;
    	F(i,1,14)pow[i]=pow[i-1]*3;
    	while (t--)
    	{
    		memset(a,0,sizeof a);
    		scanf("%d%d%d",&n,&m,&k);
    		F(i,1,k)
    		{
    			int x,y;scanf("%d%d",&x,&y);
    			x--; y--;
    			a[x][y]=1;
    		}
    		F(i,0,m-1) a[n][i]=1;
    		now=1;pre=0;
    		memset(dp[pre],-1,sizeof dp[pre]);
    		dp[pre][0]=0;
    		F(i,0,n)
    		{
    			now^=1; pre^=1;
    			memset(dp[pre],-1,sizeof dp[pre]); //printf("memset %d
    ",pre);
    			F(j,0,pow[m]-1) if (~dp[now][j])
    			{
    //				printf("%d is no ",i); print(j); printf(" == ");printf("%d
    ",dp[now][j]);
    				dfs(i,0,j,dp[now][j]);
    			}
    		}
    		printf("%d
    ",dp[pre][0]);
    	}
    }
    

      

  • 相关阅读:
    linux安装nodejs
    Ubuntu下配置TFTP服务以及 android下使用TFTP
    笔记-《数据通信与网络教程》-第一章
    X86汇编基础-《Linux内核分析》云课堂笔记
    文章点击量排行TOP100-IBM power8算法挑战赛第三期
    LeetCode:Climbing Stairs
    LeetCode:Search for a Range
    LeetCode:Longest Substring Without Repeating Characters
    LeetCode:Linked List Cycle II
    LeetCode:Merge Sorted Array
  • 原文地址:https://www.cnblogs.com/SfailSth/p/6687352.html
Copyright © 2011-2022 走看看