解题思路:
这题20分白给啊!我前面一题就5分呜呜呜!!!
注意事项:

参考代码:



n=eval(input())

s=input()

temp=list(["0"]*201 for i in range(201))

result1,result2=[],[]

x0,y0=100,100

temp[x0][y0]=" " # 起点是空格 标记

result1.append(x0)

result2.append(y0)

for i in s:

    if i=="U":

        x0-=1

    elif i=="L":

        y0-=1

    elif i=="D":

        x0+=1

    elif i=="R":

        y0+=1

    result1.append(x0)

    result2.append(y0)

    temp[x0][y0]=" "

    

# 确定矩阵

result1.sort()

result2.sort()

h1,h2=result1[0],result1[-1]

L1,L2=result2[0],result2[-1]


temp2=temp[h1-1:h2+2]

tt=[]

for i in temp2:

    tt.append(i[L1-1:L2+2])


# 和BFS有点像    

qu=[[0,1],[1,0],[0,-1],[-1,0]]

for i in range(len(tt)):

    for j in range(len(tt[0])):

        if tt[i][j]==" ":

            for k in qu:

                a,b=k

                if 0<=i+a<len(tt) and 0<=j+b<len(tt[0]) and tt[i+a][j+b]=="0":

                    tt[i+a][j+b]="*"


# 剩余部分

for i in range(len(tt)):

    for j in range(len(tt[0])):

        if tt[i][j]=="0":

            tt[i][j]=" "



# 最后排除一下

for i in range(len(tt)):

    for j in range(len(tt[0])):

        key=0

        if tt[i][j]==" ":

            for k in qu:

                a,b=k

                if 0<=i+a<len(tt) and 0<=j+b<len(tt[0]) and tt[i+a][j+b]=="*":

                    key+=1

                   

            if key==4:

                tt[i][j]="*"

for i in tt:

    print("".join(i))

    

 



def check(listx):

    def bfs(queue):

        for i in queue:

            x,y=i

            for j in qu:

                a,b=j

                if 0<=x+a<n and 0<=y+b<m and list1[x+a][y+b]!=1 and exist1[x+a][y+b]:

                    if m*(x+a)+y+b==z:

                        return 1

                    exist1[x+a][y+b]=0

                    queue.append([x+a,y+b])

        

    xx,z,r=listx[1:]

    x0,y0=xx//m,xx%m

    list1[x0][y0]=1

    x1,y1=r//m,r%m

    exist1=list([1]*m for i in range(n))

    exist1[x1][y1]=0

    qu=[[0,1],[1,0],[0,-1],[-1,0]]

    a=bfs([[x1,y1]])

    list1[x0][y0]=0

    if a:

        return 1

    return 0


def check2(nn):

    list2=[0,m-1,(n-1)*m,(n-1)*m+m-1]

    if nn in list2:

        return 1

    return 0

def check3(listx):

    xx,zz=listx[:2]

    listxx=[xx,zz]

    listxx.sort()

    aa,bb=listxx

    for i in range(aa+1,bb):

        x,y=i//m,i%m

        if list1[x][y]:

            return 0

    return 1

def dfs(step):

    if step-1==2 and check2(temp[2]):

        return 1

    if step-1==2:

        if temp[1]//m != temp[2]//m and  temp[1]%m != temp[2]%m:

            return 1

        if not check3(temp[1:]):

            return 1

    if step-1==3 and not check(temp):

        return 1

    if step-1==3:

        print(temp[1:])

        input()

        result[0]+=1

        return 1

    for i in range(n*m):

        if qq[i] and exist[i]:

            exist[i]=0

            temp[step]=i

            step+=1

            dfs(step)

            step-=1

            temp[step]=0

            exist[i]=1

n,m=map(int,input().split())

list1=[]

for i in range(n):

    list1.append(list(map(int,input().split())))


# qiang

qq=list(1 for i in range(n*m))

for i in range(n):

    for j in range(m):

        if list1[i][j]:

            qq[m*i+j]=0


temp=list(0 for i in range(4))

exist=list( 1 for i in range(n*m))

result=[0]

dfs(1)

print(result[0])


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论