巢穴

about:blank

P2996

模拟..wa了一次..因为用文件做的..忘了去掉文件了..
而且一开始看错了题...
导致最后改的时候代码乱七八糟的..orz..
#include <iostream>
using namespace std;
char pie_1[6]={'K','Q','R','B','N','P'};
char pie_2[15]={'k','q','r','b','n','p'};


bool hash[18][34];
char ch[18][34];
int main()
{
 
for (int i=1;i<=17;i++)
  
for (int j=1;j<=33;j++)
      cin
>>ch[i][j];
 cout
<<"White: ";
 
//find White piece
 bool first=false;
 memset(hash,
0,sizeof(hash));
 
for (int k=0;k<6;)
 
{
  
bool is=false;
  
for (int i=17;i>=1&&(!is);i--)
  
{
   
for (int j=1;j<=33&&(!is);j++)
   
{
      
if (hash[i][j]) continue;
      
if (ch[i][j]==pie_1[k])
      
{
       hash[i][j]
=true;
       
is=true;
       
if (!first) 
          
{cout<<pie_1[k]<<(char)(j/4+1+96)<<8-i/2+1;first=true;}
       
else
       
{
        
if (k>4) cout<<","<<(char)(j/4+1+96)<<8-i/2+1;
        
else
            cout
<<","<<pie_1[k]<<(char)(j/4+1+96)<<8-i/2+1;
       }

      }

   }

  }

  
if (!is) k++;
 }
  
 cout
<<endl;
 first
=false;
 cout
<<"Black: ";
  memset(hash,
0,sizeof(hash));
 
for (int k=0;k<6;)
 
{
  
bool is=false;
  
for (int i=1;i<=17&&(!is);i++)
  
{
   
for (int j=1;j<=33&&(!is);j++)
   
{
      
if (hash[i][j]) continue;
      
if (ch[i][j]==pie_2[k])
      
{
       hash[i][j]
=true;
       
is=true;
       
if (k==0
         
{ cout<<pie_1[k]<<(char)(j/4+1+96)<<8-i/2+1;first=true;}
       
else
       
{
        
if (k>4) cout<<","<<(char)(j/4+1+96)<<8-i/2+1;
        
else
            cout
<<","<<pie_1[k]<<(char)(j/4+1+96)<<8-i/2+1;
       }

      }

   }

  }

  
if (!is) k++;
 }
  
 cout
<<endl;

  
return  0;
}

posted on 2009-10-04 14:32 Vincent 阅读(95) 评论(0)  编辑 收藏 引用 所属分类: 数据结构与算法


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理