QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2770|回复: 0
打印 上一主题 下一主题

python 解决八数码问题

[复制链接]
字体大小: 正常 放大

1186

主题

4

听众

2923

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】2 X, M+ ~: X# s% Y2 b0 T$ F- J

. A$ R+ i' Q0 A/ T' w" A        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。. A7 z- M5 D" O% O4 z" l  s  c, h
8 ^; T1 a8 q* s; S# u7 z
例如:
8 z  G; z9 h; C0 D% z/ h' |! ^/ Q5 @
1 2 3
7 _8 B% a$ f! L9 {/ U8 G7 Ax 4 6/ N& U) p: a/ P  b" `  \2 c
7 5 8& L- h/ s6 Y; ]
        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):( z- ^% w  k: _& K/ X# n# E3 L
# }8 t9 l+ m. b, a$ k; O; J
1 2 3* G3 g$ b3 F6 E) g+ |: s
4 5 61 N9 O3 k; C1 [2 b" t# X' T1 _
7 8 x
9 }0 Y) E# M! G& U- ^        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
1 E+ f% m) ?2 l7 P5 N6 J  c: r; s0 n- o* o- v
1 2 3   1 2 3   1 2 3   1 2 3$ Z+ U7 f0 e+ g  l' `
x 4 6   4 x 6   4 5 6   4 5 6
3 w) t9 p. S4 u7 5 8   7 5 8   7 x 8   7 8 x1 T6 @/ r2 c- T0 e
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。
( _" f3 Q0 x, K- h$ t4 Y' P  z1 h$ y( V/ |4 [: W! {3 ~4 ~
【输入格式】
+ v" ^  F! Z/ L! H3 H; j
5 r% Z% _9 r" z1 c        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
5 A3 v6 K% y0 Q+ |0 Z; j3 s
  G' u4 f$ Y" Y- {& y6 d# o1 2 3 8 Z' e) C4 V* J( B! \2 L, [! C
x 4 6 ; L0 m: Y' S1 S
7 5 8 + M& ^$ D# {4 Q' G
        则输入为:1 2 3 x 4 6 7 5 87 `# _0 L3 x* T( B4 q) Z$ R
. V  Y, F$ W; I/ ^1 C! e
【输出格式】# O$ k$ \' A% O* t" g' z. x: [9 n

( P$ }  b. o0 m5 b) _, r        输出占一行,包含一个整数,表示最少交换次数。/ H$ Z- M5 k% M: z

4 d  V; p$ p1 F) E0 R) U# @        如果不存在解决方案,则输出 −1。$ |, a6 d* U3 ]& Q

! M" I# x: N5 s. t" ?【输入样例】
! ^% Y1 N  ?" t" e0 P2 b4 t% a4 M/ j: `- I% H' E7 ^
2 3 4 1 5 x 7 6 87 z6 Y6 F5 X* @6 K
【输出样例】3 {# Z( E4 I& H2 p* y

2 c7 U6 z. h# ?" e19
* ^8 t) S, d3 s5 ]6 [8 p' e【解题思路】
+ S8 F0 J( l5 s) A7 P# V& M; L3 @0 a/ W4 q
        简答题,用BFS遍历查找即可。1 _# f% |1 Q3 G

4 o2 V4 z6 \- \# M! M5 c+ k; Y【Python程序代码】! _: L2 v6 |, _/ L5 r$ j; V" E
4 Q8 Z2 L$ W  J! T! o/ x
from collections import *
  k3 L) O- w1 ~, rpd = ['0','1','2','3','4','5','6','7','8','x']8 B/ {# R1 W7 `
norm = "".join(pd)1 |/ x- H" u% G3 M" q
dir = [1,-1,3,-3]- u: Q8 Q1 i) X; M
s = ['0'] + list(map(str,input().split()))
: ^+ H) m8 o9 Uidx = s.index('x')/ N  f6 N  s1 k' E9 @6 W; Q
mp = defaultdict(int)% x. I: @- V/ g& {& g/ ~- p# J
def bfs():
. E* f: o3 O# P# k    q = deque(): c( y: p* `( q$ F2 K" ]
    step = 0- i( b  n. J7 B8 d( m6 K+ m- b
    q.append( [s,idx,step] )
3 P, ?8 F# V9 |& U8 _5 Y( k    ns = "".join(s)
  e7 D- ], I0 j4 A/ H    mp[ns]=1
# Q  u. E- H# }5 x    flag,res = 0,-1
; f6 C' x2 l2 }( [! D; |    while q:
* U/ {  s1 }# i1 \6 r) F% e9 S& e        ss,sidx,step = q.popleft()
# b/ e% \8 G# [5 z4 {        if "".join(ss)==norm:% D& a* v' c* r" z3 Q4 t& O; N" V
            res = step' m  k# G! K; H$ I
            break& C2 [. U5 ]9 J* ^
        for i in dir:; A. e# ?% b* ]
            teps = ss.copy()
# @  K8 a8 t1 T/ k" V, `- @: K% ?            nidx = sidx + i
9 u1 w: h9 l* ^            if nidx<1 or nidx>9:continue
* c1 A0 Y' R2 ~: h5 G  t/ Z6 f            if (sidx==3 or sidx==6) and i==1:continue
: Z- J6 D# S" t' h8 u" K4 k6 O/ o            if (sidx==4 or sidx==7) and i==-1:continue! M2 m: M( P, P- [* t: d7 c
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]
! s  Q- w5 z5 B/ D" [4 T  F7 ?            nteps = "".join(teps)
9 g% |" N2 h6 R1 J% h0 l            if  mp[nteps]:continue
( j3 I! t4 C4 w, |# J( C! @6 ^            mp[nteps]=1
% J5 G0 O0 U8 [5 u            q.append( [teps,nidx,step+1] )
# i" x) T$ @# y- l$ F6 x    print(res)
9 z+ |: d5 @8 s* d8 x, Cbfs()
" [4 K( u+ n4 N; q; l
. N4 V- A2 \: I* ]% h- {8 B  s( m3 ]8 B# e9 h2 }; W$ c

" u$ _+ ^% q8 S, }2 ]; J' G" j+ T* \8 G

3 Z( l! {( B1 ~# ~, u! ]

代码.txt

2.23 KB, 下载次数: 0, 下载积分: 体力 -2 点

售价: 2 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-20 15:09 , Processed in 0.446385 second(s), 55 queries .

回顶部