解题思路:
注意事项:
多多优化
参考代码:
n,m = map(int,input().split())
data = [list(map(int,input().split())) for i in range(m)]
sums = sum([sum(data[i]) for i in range(m)])
bools = [[0 for i in range(n)] for j in range(m)]
res = 10000
def search(now,x,y,count,sign):
global res
if now > half or res <= count or bools[x][y]:
return
elif now == half:
res = count
now += data[x][y]
bools[x][y] = 1
count += 1
if sign != "D" and x < m-1:
search(now,x+1,y,count,"U")
if sign != "R" and y < n-1:
search(now,x,y+1,count,"L")
if sign != "L" and y > 0:
search(now,x,y-1,count,"R")
if sign != "U" and x > 0:
search(now,x-1,y,count,"D")
if x < m-1 and y > 0:
search(now,x+1,y-1,count,"LD")
bools[x][y] = 0
if sums%2 != 0:
print(0)
else:
half = sums//2
search(0,0,0,0,"U")
if res == 10000:
print(0)
else:
print(res)
0.0分
2 人评分
逆反的01串 (C++代码)(依旧推荐switch)浏览:933 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:593 |
C语言训练-谁家孩子跑最慢* (C语言代码)浏览:1507 |
C语言训练-阶乘和数* (C语言代码)浏览:976 |
【回文数(二)】 (C语言代码)浏览:850 |
C语言训练-大、小写问题 (C语言代码)浏览:2349 |
C语言训练-数字母 (C语言代码)浏览:582 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:581 |
C语言程序设计教程(第三版)课后习题10.1 (Java代码)浏览:1435 |
【明明的随机数】 (C++代码)浏览:779 |