[sicily online]1151. 魔板

來源:互聯網
上載者:User

題目分析:

簡單魔板由於N比較小,所以可以用暴力DFS,但是這個題目N比較大,所以要進行狀態判斷

一共有8!個狀態,需要把這些狀態對應到整數上去,正好是康拓展開

所以本題DFS+康拓展開

#include<iostream>  #include <iomanip>  #include<stdio.h>  #include<cmath>  #include<iomanip>  #include<list>  #include <map>  #include <vector>  #include <string>  #include <algorithm>  #include <sstream>  #include <stack>  #include<queue>  #include<string.h>  #include<set>  using namespace std;  int N;  char initdata[2][4]={{'1','2','3','4'},{'8','7','6','5'}};  char goal[2][4];  typedef struct STATUS  {  vector<char> oper;  unsigned deep;  char data[2][4];}Status;  int factory[8] = { 0, 1, 2, 6, 24, 120,720, 5040};bool code[40321];//共有這麼多個狀態int encode(char data[][4])//康托展開{int sum=0;for(int i=0;i<8;i++){int count=0;for(int j=i+1;j<8;j++){if(data[j/4][j%4]<data[i/4][i%4])count++;}sum+=count*factory[8-i-1];}return sum;}bool equal(char data[][4])  {  for(int i=0;i<2;i++)  {  for(int j=0;j<4;j++)  {  if(data[i][j]!=goal[i][j])  return false;  }  }  return true;  }  int main()  {  while(cin>>N&&N!=-1)  {  for(int i=0;i<8;i++)  cin>>goal[i/4][i%4];  queue<Status> qu;//表示深度  Status st;  st.deep=N;  memcpy(st.data,initdata,sizeof(initdata));  memset(code,0,sizeof(code));code[encode(initdata)]=true;qu.push(st);  bool flag=false;  while(!qu.empty())  {  Status to=qu.front();  qu.pop();  if(equal(to.data))  {  cout<<to.oper.size()<<" ";  for(int i=0;i<to.oper.size();i++)  cout<<to.oper[i];  cout<<endl;  flag=true;  break;  }  if(to.deep<=0)  continue;  Status op;  op.deep=to.deep-1;  memcpy(op.data,to.data,sizeof(initdata));  for(int i=0;i<4;i++)//A操作  swap(op.data[0][i],op.data[1][i]);  op.oper=to.oper;  op.oper.push_back('A'); int cc=encode(op.data);if(code[cc]==false){qu.push(op);code[cc]=true;}memcpy(op.data,to.data,sizeof(initdata));  for(int i=0;i<2;i++)//B操作  {  char tmp=op.data[i][3];  for(int j=3;j>0;j--)  {  op.data[i][j]=op.data[i][j-1];  }  op.data[i][0]=tmp;  }  op.oper=to.oper;  op.oper.push_back('B');  cc=encode(op.data);if(code[cc]==false){qu.push(op);code[cc]=true;}memcpy(op.data,to.data,sizeof(initdata));  char tmp=op.data[0][1];  op.data[0][1]=op.data[1][1];  op.data[1][1]=op.data[1][2];  op.data[1][2]=op.data[0][2];  op.data[0][2]=tmp;  op.oper=to.oper;  op.oper.push_back('C');  cc=encode(op.data);if(code[cc]==false){qu.push(op);code[cc]=true;}}  if(flag==false) cout<<-1<<endl;  }  }                                 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.