QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |正序浏览
|招呼Ta 关注Ta
题目描述】
) Y2 x5 h+ k' p! ^. q) H" C! ?' y. _' z; x; k" y( J) j
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。6 N2 T& T0 V/ v8 s/ \
3 y6 p! ~. x& k; z) `0 @# T
例如:
( ]' d. E# t: S8 c! b! @6 Q
+ ~& |" q8 d; g0 P. L4 f' |5 \, c1 2 37 \, B( x, ]: o/ ?* x+ t3 o. x
x 4 6
# ]! k) J( ^% T  ]* w7 J5 x* J% R4 K7 5 8
; S+ E2 o5 C3 |        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
  ^; V  s! d1 S+ G
* {% q1 Z: e+ w) o7 N+ v" l1 2 3
7 v. [) S: S* U0 x4 5 6
& S( @" m) z/ U8 k7 8 x
+ S# B- j$ j- M        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
3 y- Q# w, H& R5 T5 Q2 u* ^: S% s, a/ r6 V3 F4 i6 r
1 2 3   1 2 3   1 2 3   1 2 3
( X/ Z0 v! H& z( s3 Wx 4 6   4 x 6   4 5 6   4 5 64 Y8 G3 e4 H3 y6 ~+ r. `; t! ^
7 5 8   7 5 8   7 x 8   7 8 x6 P! S6 u  n6 G
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。- ?! w9 ?% H& E
$ A, x" ?: j: Q# l2 W% |
【输入格式】  Q) S+ o& W9 v+ e1 N* l

4 F5 s. ^) U5 ^8 t/ U1 H        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
: a6 g# ?9 `0 V  N# Q) X& j" x7 [( R7 E# J( u( n
1 2 3 # w6 V: \/ D1 F
x 4 6 * d/ l4 q" _3 \, U: a, a/ x
7 5 8 ; O# E. d! t! |7 m/ q( y9 t
        则输入为:1 2 3 x 4 6 7 5 8
. [/ |4 A* X5 K! {0 _9 n% L; m/ a' z+ X8 _
【输出格式】
* {1 ~! ~- @( O2 s' B2 t2 F. ^! B' G0 o8 J: ]8 W. r
        输出占一行,包含一个整数,表示最少交换次数。' v1 k2 t5 F& q$ e4 A% P1 N: @3 p
4 ]% N3 z: x$ z! C7 R
        如果不存在解决方案,则输出 −1。. E2 F$ O7 K7 h
$ u6 o# l9 ~# C
【输入样例】
( A% c4 n1 m, g1 w- U7 `$ p1 q9 \! Q
2 3 4 1 5 x 7 6 85 x. E# |( G  X. N* U
【输出样例】
$ J+ o# ]3 I# A' [. l8 c! o( X5 x) A4 v- f% j8 G
196 `( q; b$ \5 d6 a' v
【解题思路】
6 |4 C* U( R! g' D9 q2 n1 O, L1 j; J- Q7 U/ R7 O
        简答题,用BFS遍历查找即可。& v6 _( o+ X% F- o; h+ N) E2 D
! j4 a0 k1 U% V/ n! k
【Python程序代码】
: E  V: \, U( S" Y. x1 Z! G# m, ]# ]& U5 H0 ^, M
from collections import *% r) ~6 F- E& q4 \$ O) D9 R9 z
pd = ['0','1','2','3','4','5','6','7','8','x']* o, X; G% T  Z, S( _3 A
norm = "".join(pd)* Y1 n7 {5 v. \( U# M, C
dir = [1,-1,3,-3]' S; a" v4 q( p. z" V4 ?
s = ['0'] + list(map(str,input().split()))# ?' X) o' [7 d. G8 G, `! f) s
idx = s.index('x')& H! U2 H) [" t  j
mp = defaultdict(int)% \( h5 z4 z: a, `2 A9 `
def bfs():
( g) d( U3 T- G1 ^% ^+ v' @    q = deque()
- y0 B: g/ a/ t. k: f# M    step = 0, }5 f; m! _- \" C3 d  r3 a
    q.append( [s,idx,step] )
% J2 A: P1 c8 \5 ]+ |3 W2 r    ns = "".join(s)
4 o' p( u: s* d' b    mp[ns]=1# |4 T" U2 H$ n4 ?0 d$ L  S
    flag,res = 0,-1
5 X& Y" q; ]2 ]* V# n    while q:" v: p9 C8 H7 o) w1 e
        ss,sidx,step = q.popleft()
; ~* H  g* ?( A( g" ~        if "".join(ss)==norm:4 y& r" k6 f+ m
            res = step
; C' n* d& L2 N4 t5 o! h            break/ N) X4 x, g$ U" j
        for i in dir:+ g( E9 z" m8 F7 ^1 p
            teps = ss.copy()
  ]/ r+ R! {: N$ ]" j5 W            nidx = sidx + i
, b# T5 z% V6 ?5 O" c            if nidx<1 or nidx>9:continue* u: F! S; U: B
            if (sidx==3 or sidx==6) and i==1:continue; a/ s) n4 I" f. I
            if (sidx==4 or sidx==7) and i==-1:continue- K& W+ a. a8 t/ p) g5 ]0 e
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]$ q) R( y5 N6 v' z( }7 X
            nteps = "".join(teps)
/ c! }/ X# n( n$ T& V- N  Q# r            if  mp[nteps]:continue3 {. S& D9 J9 f" m1 _7 d3 W
            mp[nteps]=16 ]- S- x, s& L
            q.append( [teps,nidx,step+1] )
% D! F( H& P9 r    print(res); n6 ~% B9 P: }/ V' r1 p2 h
bfs()8 u: b6 A  v# A$ }3 x

! }3 P8 H! Y& S, I$ h
* `# q. A' P3 I# K1 `
8 D7 k, t7 S; {& s
; C8 A3 c% @" D' O+ b0 Y8 C0 e" D% B) ]

代码.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-13 15:07 , Processed in 0.304167 second(s), 55 queries .

回顶部