QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】- X, b  H* Z/ I! q0 p, p

* v& M& g& E" i! V' h        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。; ~" J. H0 P3 I2 t0 E1 ?& E
( ^) O3 h- G( Y( n4 y* x! S
例如:! e1 h7 I$ s$ g( A( y+ L
7 |0 u0 t. P. _6 O2 E8 C; {$ Z* h  `+ K
1 2 3
: f* v0 ?3 G% ax 4 61 \. C: a& s+ N4 d
7 5 8
; L. F) L$ c+ h' f: S% s        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
) h/ ^( h8 k3 V" Z; k% R' S- H* f7 j8 r- @( D4 Z- z
1 2 35 r) V( M3 p; y0 t1 W' o* ]
4 5 6- f" P) M* H0 ?" ~/ Q+ S
7 8 x, @2 ^% ]2 w9 G: u7 R
        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
1 B% u. r, h( Q9 [; p: ?
1 g: r2 _  N4 m1 2 3   1 2 3   1 2 3   1 2 3. N5 u; t3 W  |; x/ }0 n
x 4 6   4 x 6   4 5 6   4 5 6
3 l; m: d' f5 Z% J& R  _7 5 8   7 5 8   7 x 8   7 8 x+ C  @' G8 [6 F
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。
0 O3 [, T" M2 y5 p% ~! l
% I2 z8 D, S7 H- Z' ]【输入格式】& f0 L5 |3 ]9 ]: C' D, s
" v: c3 i7 {& X3 q. D2 \$ g/ \2 R  h, H
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
) j8 ]2 ?) @5 Z  H% L- ^: o0 q, T: H1 Z' f  ^8 R
1 2 3
/ {# O- G% e( u' q- |; u( [5 Ix 4 6 6 k2 R' T5 g* {: X1 i5 Y" ~$ M1 C
7 5 8
2 K; T( F' g7 m1 C4 }        则输入为:1 2 3 x 4 6 7 5 8
8 v3 g' z+ _; B' F0 a+ ]  A7 {" A, I4 H, ^
【输出格式】
" J0 V. |' N- I8 F! l! H8 q% |) a# t  m1 k4 T( H
        输出占一行,包含一个整数,表示最少交换次数。
* p6 \2 G, l' t
5 H! i# }8 @. l. j; K3 g        如果不存在解决方案,则输出 −1。; j$ g$ E3 M$ L3 G

  O+ P/ P' D) p【输入样例】% c+ u( J' M3 Z" \2 W
* l3 g1 Z, L8 b  K6 V
2 3 4 1 5 x 7 6 82 v4 `+ R  N- e( c8 _+ i
【输出样例】! R" H6 O1 v* n  ~4 ?
3 W4 ~3 I# q+ G3 h
19$ V0 i6 f6 K& {/ S6 t- B- H
【解题思路】
# v4 c1 ^1 R. x/ E. Z( m9 j
  [  P' J$ {* y) T2 J        简答题,用BFS遍历查找即可。
5 a1 C1 F+ m8 u+ `1 h6 X; q3 L: H. {; E2 I8 U+ \3 c+ K8 l3 L6 }
【Python程序代码】* Q5 k- y, J* ^' p( E2 g

8 A4 t' r5 @, h4 g% q0 c2 Pfrom collections import *0 Q3 j3 Q0 u7 U6 G
pd = ['0','1','2','3','4','5','6','7','8','x']* O- l+ w2 ^! m9 c( p. B
norm = "".join(pd)1 A! g5 E/ \, {5 a( m9 [" H; u
dir = [1,-1,3,-3]
8 I# e  \1 x* H9 ]! ~% D5 C0 Ps = ['0'] + list(map(str,input().split()))
6 J$ L, ?$ m! d: ]idx = s.index('x')8 Z: _' M, u4 k7 t2 I
mp = defaultdict(int)
8 p) R3 j6 t6 ]def bfs():
4 D# f' K5 P# i5 a. g    q = deque()1 P4 r- d0 r) M. W
    step = 0
6 k; B. P4 E3 n+ B- y    q.append( [s,idx,step] )5 z) X. ~4 f( @- z% a5 L
    ns = "".join(s)
' e# g) y& F+ n& H    mp[ns]=1% f5 S$ f/ x, s6 j$ q! z7 k( b: F
    flag,res = 0,-16 E2 K+ n# G2 K5 r, R
    while q:
5 _; `2 f: r( p% m        ss,sidx,step = q.popleft()) s* A, |8 j# f+ a3 j: N8 ]2 D; C
        if "".join(ss)==norm:$ P/ t% f& i/ I) K% U* h' l4 r
            res = step7 r7 M) p/ \0 ~3 T$ [& a% P# G
            break/ ]5 h# A4 b4 R0 E0 U* c
        for i in dir:
3 I+ ?' ?* l6 }/ v' b! Q: G            teps = ss.copy()2 @" }) {" w2 s; f* Q2 n7 w( C
            nidx = sidx + i1 C: _4 K& d+ L9 _" n) t8 D& V) Y
            if nidx<1 or nidx>9:continue3 V3 }- S3 C* f3 u
            if (sidx==3 or sidx==6) and i==1:continue
9 s, H  @$ I2 i% A) f            if (sidx==4 or sidx==7) and i==-1:continue9 |, e7 z6 ^5 v+ M" s' a2 _
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]/ T: G3 G( \  C! [- o4 p4 b
            nteps = "".join(teps). v4 J* Q! y; F7 g% m) u. k& @
            if  mp[nteps]:continue( ^. y& w. t& E' l0 v, G2 C
            mp[nteps]=1+ ~4 l# u8 a' D9 K7 c
            q.append( [teps,nidx,step+1] )
2 w' W% S% ?8 ^: q  {    print(res)
1 v& l( {" h9 Rbfs()4 ~+ ^8 H5 d6 n9 |

5 v' ^  a8 f6 S! U7 a: d$ ^2 F5 y& S

" @; T! X  @) L2 k6 C3 o; X& V. `$ t' q1 `3 H3 h6 l# X/ Z
1 k9 b- @) W: E, d' `

代码.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-5-26 01:53 , Processed in 0.392867 second(s), 54 queries .

回顶部