解题思路:
注意事项:
多多优化
参考代码:
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 人评分
简单的a+b (C语言代码)浏览:528 |
C语言程序设计教程(第三版)课后习题8.9 (C语言代码)浏览:596 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:543 |
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:932 |
简单的a+b (C语言代码)浏览:564 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1334 |
简单的a+b (C语言代码)浏览:618 |
数组与指针的问题浏览:760 |
C二级辅导-同因查找 (C语言代码)浏览:618 |
矩阵的对角线之和 (C语言代码)浏览:1401 |