拼多多0802笔试 0AC
第一题98,距离0的时候输出字符串就行了 我输出的是0 0,94或者96的同学是没有考虑最后一次刚好到终点不用输出字符串,是输出 0 times。
第二题5%,看了就不想写,太绕了。直接抖机灵输出了一个 8 2 1 1 1 1 1 1 1这种结果
第三题暴力50%,挺无语的,同学用c++暴力100%
第四天DFS36%,提示复杂度过高。感觉没法剪枝,不知道怎么做,可能是dp吧。
public class Main04 {
static int result=0;
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
char[][] feild = new char[6][6];
for (int i = 0; i < 6; i++) {
feild[i] = in.nextLine().toCharArray();
}
dfs(feild,0,0);
System.out.println(result);
}
private static void dfs(char[][] feild, int x, int y) {
if (y>=6)
{
dfs(feild,x+1,0);
return;
}
if (x>=6)
{
result=(result+1)%1000000009;
return;
}
if (feild[x][y]!='*')
{
for (char k = '1'; k < '7'; k++) {
if(!(x-1>=0&&feild[x-1][y]==k)&&!(y-1>=0&&feild[x][y-1]==k))
{
feild[x][y]=k;
dfs(feild,x,y+1);
feild[x][y]='#';
}
}
}
else
dfs(feild,x,y+1);
return;
}
}