ZOJ 3675 Trim the Nails(bfs)

Trim the NailsTime Limit:2 Seconds Memory Limit:65536 KB

Robert is clipping his fingernails. But the nail clipper is old and the edge of the nail clipper is potholed.

The nail clipper’s edge isNmillimeters wide. And we useNcharacters(‘.’ or ‘*’) to represent the potholed nail clipper. ‘.’ represents 1 bad millimeter edge, and ‘*’ represents 1 good millimeter edge.(eg. "*****" is a 5 millimeters nail clipper with the whole edge good. "***…" is a 6 millimeters nail clipper with half of its edge good and half of its edge bad.)

Notice Robert can turn over the clipper. Turning over a "**…*"-nail clipper will make a "*…**"-nail clipper.

One-millimeter good edge will cut down Robert’s one-millimeter fingernail. But bad one will not. It will keep the one-millimeter unclipped.

Robert’s fingernail isMmillimeters wide. How many times at least should Robert cut his fingernail?

Input

There will be multiple test cases(about 15). Please process to the end of input.

First line contains one integerN.(1≤N≤10)

Second line containsNcharacters only consists of ‘.’ and ‘*’.

Third line contains one integerM.(1≤M≤20)

Output

One line for each case containing only one integer which is the least number of cuts. If Robert cannot clipper his fingernail then output -1.

Sample Input8****..**46*..***7Sample Output12HintWe use ‘-‘ to present the fingernail.For sample 1:fingernail:—-nail clipper:****..**Requires one cut.For sample 2:fingernail:——-nail clipper:*..***nail clipper turned over: ***..*Requires two cuts.

题意: Robert需要剪指甲,但是他的指甲刀有缺陷,有些是剪不到的,

他的指甲刀形如是一个字符串,符号’.’代表指甲刀这处有缺陷这处的指甲不能修剪到,

符号’*’代表这处是完好的,这处的可以修剪到;如指甲刀**..**,要剪长度为6的指甲,

则剪出来的指甲(1代表该处指甲已修剪,,0则没有)是110011,这需要再剪一次;

指甲刀可以左右移动,还可以翻转;

题解:一直从最左端有指甲的位置开始 剪,指甲钳分正反两种状态剪指甲,bfs求出最小步数。-1的情况全是‘.’。

可以先处理出两把指甲钳,正反各一把,用一个数表示。指甲原始状态可以用(1<<L)-1表示,即全部

都是1,然后进行位运算,把剩下的状态求出来,知直到0.

#include<cstring>#include<algorithm>#include<iostream>#include<cstdio>#include<cmath>#include<queue>using namespace std;int n,L,ans;char s[14];int Jidong,_Jidong;struct node{int nail;int step;};queue<node>que;bool vis[(1<<20)+50];void debug(int x){while(x){printf("%d",x&1 );x>>=1;}printf("\n");}void bfs(){while(que.size())que.pop();memset(vis,false,sizeof vis);node it;it.nail=L;it.step=0;que.push(it);vis[L]=true;while(que.size()){it=que.front();if(it.nail==0){ans=it.step;return;}que.pop();while((it.nail&1)==0){it.nail>>=1;}int nit=it.nail,_nit=it.nail;for(int i=0;i<=20;i++){if((nit&(1<<i))&&(Jidong&(1<<i)))nit^=(1<<i);if((_nit&(1<<i))&&(_Jidong&(1<<i)))_nit^=(1<<i);}node _it;_it.nail=nit;_it.step=it.step+1;if(!vis[nit]){vis[nit]=true;que.push(_it);}_it.nail=_nit;if(!vis[_nit]){vis[_nit]=true;que.push(_it);}}}int main(){//freopen("test.in","r",stdin);while(cin>>n){scanf("%s",s);cin>>L;Jidong=0,_Jidong=0;int length=strlen(s);for(int i=0,j=length-1;i<length;i++,j–){if(s[i]=='*'){Jidong|=(1<<i);_Jidong|=(1<<j);}}//debug(Jidong);if(!Jidong){printf("-1\n");continue;}while((Jidong&1)==0)Jidong>>=1;while((_Jidong&1)==0)_Jidong>>=1;L=(1<<L)-1;ans=-1;bfs();printf("%d\n",ans );}return 0;}

版权声明:本文为博主原创文章,未经博主允许不得转载。

却又小到连一粒嫉妒的沙石也不能容纳

ZOJ 3675 Trim the Nails(bfs)

相关文章:

你感兴趣的文章:

标签云: