这题是有点难度的了。
没事,照样直接来:
#include<bits/stdc++.h>
using namespace std;
int a[10][10],f[1000005],ans=0;
void dr(int h,int l)
{
memset(a,-1,sizeof(a));
for(int i=1;i<=h;i++)
{
for(int j=1;j<=l;j++)
cin>>a[i][j];
}
}
void dg(int dep,int i,int j,int s)
{
if(dep==6) f[s]=1;
else
{
if(a[i-1][j]!=-1) dg(dep+1,i-1,j,s*10+a[i-1][j]);
if(a[i+1][j]!=-1) dg(dep+1,i+1,j,s*10+a[i+1][j]);
if(a[i][j-1]!=-1) dg(dep+1,i,j-1,s*10+a[i][j-1]);
if(a[i][j+1]!=-1) dg(dep+1,i,j+1,s*10+a[i][j+1]);
}
}
int main()
{
dr(5,5);
for(int i=1;i<=5;i++)
{
for(int j=1;j<=5;j++)
{
dg(1,i,j,a[i][j]);
}
}
for(int i=0;i<=999999;i++)
{
if(f[i]==1)
{
ans++;
}
}
cout<<ans;
return 0;
}