QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】$ B5 H; K' H+ B
+ o' Q8 t( K$ v+ b8 X
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。
' a1 y3 J% f. D$ J& E
* V2 w: r( e. D4 [例如:: e! ]. v+ |2 S5 x9 b5 ^8 y

8 S: j5 ?6 O" U  K* S1 2 3/ D9 S" ^) a" S; @: C2 I
x 4 6
) B0 K: N* ]; O, L$ {9 |4 A7 5 8
# }" O! g. m& B! B' ^) K6 f        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
: _4 N2 R* ^6 g
" B5 E) U) O4 t1 2 3
) s. R+ N) v( n+ a9 }" g3 ?" `4 5 6. v+ t2 S) F/ \7 ^. a$ F
7 8 x
. q- B' F+ x7 J$ }/ `        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下# f% v" l6 F" w6 x( S8 ?% @6 C$ ?3 z
3 m5 L- E! y4 n. ^9 ?# z5 E
1 2 3   1 2 3   1 2 3   1 2 37 _4 a( a- m- }' ?! D0 d0 J' i
x 4 6   4 x 6   4 5 6   4 5 62 u% R& c* \9 q5 A
7 5 8   7 5 8   7 x 8   7 8 x
* [* t+ o, Y/ x, J         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。8 b; k) ^/ G4 m9 e$ }1 _' k

* J4 Y$ r2 f" M; w, u0 j  Q【输入格式】- v: W- k% U% [) b% e2 Y
1 H% K" v5 R: n3 `5 Z6 Q$ s
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
' u! e' k3 ~# S2 i2 ]& ?" g4 I2 d: R- v& P/ ]5 M% j6 y
1 2 3 % }- t. R2 @( `3 q7 X
x 4 6 + u2 ?  `/ n) E) z0 l
7 5 8
' E$ C7 y0 T/ ]6 x9 X6 G: R        则输入为:1 2 3 x 4 6 7 5 8
. G3 Q8 ]* D' Y& L$ e/ v- |, T. G$ O% `4 M8 T
【输出格式】/ z/ P3 Q# w' [; d% a" x
, ]) I" C$ |; b3 C: T0 b' f" n: k- m
        输出占一行,包含一个整数,表示最少交换次数。+ }. f( g" r0 s$ t4 v$ k
4 Q" X* H6 e; N) S% }
        如果不存在解决方案,则输出 −1。
; L7 b5 X; H) y+ x5 f9 H/ h/ `$ c# A& {
【输入样例】1 |3 K6 M2 M. z; f. T
! u9 `( S" s) c' Y( P
2 3 4 1 5 x 7 6 8
  v/ I- F" `5 Z【输出样例】
8 Y$ v1 f! D0 A
, @" W( X& ^5 U+ s& e/ t1 ~* ?19
2 V' h1 @. n' O) R- T【解题思路】
: ^  l4 u% T1 F0 ~% D; X/ s; c4 b# c1 ^$ g/ L1 V
        简答题,用BFS遍历查找即可。
, W: `5 [& K5 q" V: ?8 `/ k/ j! _/ D+ ]3 a+ B! {
【Python程序代码】* J* j1 y& T, k4 V6 z* @9 p; G
% |4 A0 f( O0 b8 m/ h6 S
from collections import *
8 U# }+ R) Q+ a% q0 q6 Y+ Z% ?pd = ['0','1','2','3','4','5','6','7','8','x']  {& n* C& ?" `# s
norm = "".join(pd)% V3 ]! e' f' H
dir = [1,-1,3,-3]+ i+ W- M. O7 o1 |* l6 M
s = ['0'] + list(map(str,input().split()))  D7 v3 Z  u% Q0 G0 m8 y
idx = s.index('x')- ?3 _6 i$ F% [0 j! u
mp = defaultdict(int)
1 F" l1 W3 t" G( G$ ]- u' sdef bfs():
' _: s- M- L6 {2 S    q = deque()
: H3 R* h7 p, ^$ p' M) d    step = 06 _( y( q: E* e- d
    q.append( [s,idx,step] )% w" [1 n* n2 {, N
    ns = "".join(s)
; E7 r6 \4 }2 u8 g! U* |- y    mp[ns]=1
8 [  \, H+ j, W; M2 F: i' d& u    flag,res = 0,-1& e( v  K0 I" `( {7 _; Z9 }* x
    while q:! O& U( W0 L" n4 X3 c% k: V: O
        ss,sidx,step = q.popleft()5 b: p7 o3 V3 O% U# I# }0 R
        if "".join(ss)==norm:) |" C4 E' U8 `5 y
            res = step
* B. w* D% k) D5 d            break( C; Z5 {* B. p
        for i in dir:( t" n$ ?7 [+ r+ K( q0 w& m0 _
            teps = ss.copy()$ V  N$ T) o/ Q1 u# L* \8 ?5 l
            nidx = sidx + i
! a9 g3 m, m. d& R9 a- ^# ?1 v            if nidx<1 or nidx>9:continue2 q6 k$ F/ d4 N$ g5 A7 m
            if (sidx==3 or sidx==6) and i==1:continue6 \) i3 E, e  T, M7 Y9 v" [
            if (sidx==4 or sidx==7) and i==-1:continue' M4 O( A3 i6 m4 P4 i5 O6 y
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]* ~9 A- b2 G4 z0 @' l2 m
            nteps = "".join(teps)* a9 j/ J, S8 N
            if  mp[nteps]:continue
  i( q" d  |1 |* L2 `            mp[nteps]=13 r) ^4 ]; D! _; R
            q.append( [teps,nidx,step+1] )
6 I+ C" |/ n+ X4 K+ T) J1 z+ b; @    print(res)3 j; g  n% l. i1 x3 G
bfs()
( D. f  j$ I( g7 e
7 a& k  _3 }0 b+ Y6 V  {9 u3 @5 z& I: l, C* B
6 m. _% H- }$ [! N1 c9 W6 O

+ \# w% L: o, x8 m: M; |
: k: K; P3 ~# t. w3 Q. M

代码.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-6-11 22:47 , Processed in 0.634480 second(s), 54 queries .

回顶部