QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】
0 p  l  C# `. S3 d9 o; Q6 D) S1 G" d% v1 w( {% e9 ^4 f8 S
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。
, L+ K+ q$ ?: F) O6 c1 H5 P
1 ?1 r0 Z6 m2 G, v# V  \' Z6 _0 G8 ~例如:
! D3 J# X" a' L; |' w; [' W$ H( Y4 Y9 I7 C$ F7 Q% W: K" o
1 2 3
- J# v* R. A: d) Qx 4 66 j+ w6 o" n* a4 y
7 5 8
( C( F5 L1 Q. m: ^  f        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):, Q8 e$ q9 `% w- Z( ^
1 q, T5 M+ ~: B3 }
1 2 3
8 l* x; }3 l7 m! J9 |4 5 6* ^/ u1 o1 V# s" z3 U( }6 P7 e
7 8 x% t4 D2 {6 L9 k7 X0 Q+ M
        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
, T, p& R: B" R- y7 A% `# y
" V- D4 S( r  l. Y1 2 3   1 2 3   1 2 3   1 2 3* @8 X  o+ R" F# y0 H" T. A+ A
x 4 6   4 x 6   4 5 6   4 5 6. |0 X/ \  Q1 w
7 5 8   7 5 8   7 x 8   7 8 x3 j0 @0 h# o& u7 M3 q* O3 e& |
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。$ z# H" X- U$ z3 j$ ~$ R# a
  F# w2 }; a6 s/ @5 q
【输入格式】% }& \! d3 g4 Q( H# @
8 i2 M5 m7 Q) g4 w3 I( I5 D
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
' v; y1 h- O* f$ J6 X) N" d" ]; N6 u' g
1 2 3 $ O6 j: \# k8 ?7 z3 v3 r0 v
x 4 6
, O7 u6 @( c6 P& ~3 @- Q7 5 8 ! X: H3 J% R: }
        则输入为:1 2 3 x 4 6 7 5 85 |3 f; s( m5 b' s+ T% x' t

6 {' B2 J6 _6 z+ b2 H【输出格式】, q; D$ T4 B! u/ `" E/ u
% ]! `0 O9 E3 U4 t
        输出占一行,包含一个整数,表示最少交换次数。
, Q, @' K3 v4 \5 v& V/ |' X
5 F8 X  W4 v# d! \/ A+ e        如果不存在解决方案,则输出 −1。
6 D6 O. c8 _  M3 j/ L* m& G) T4 U# T+ [
【输入样例】4 L' ]: K3 i* s9 Z# Z
% }1 R' S0 p+ x6 O' g, H; ?2 b
2 3 4 1 5 x 7 6 8
  K3 G' i8 ~! H0 |5 V【输出样例】
# M, c9 C2 Z" w+ l4 |- l5 o! W: q; o
, H/ F# a/ ~9 J( a2 R1 P199 ^1 |( ^8 ?1 t
【解题思路】
; C# t* d* c" S9 n
8 ]: {$ a- u3 @% v. c) Y  Y        简答题,用BFS遍历查找即可。
% e8 o7 G% K. Y
) W; v6 `% i8 q4 i+ J/ t【Python程序代码】
$ o- H* h! H# R) e- G! A7 F* d1 e, ~  M
from collections import *" x. K/ h5 O* e6 u9 Z: V' _
pd = ['0','1','2','3','4','5','6','7','8','x']& H) g5 v* C; \! Q! c7 |9 f( j
norm = "".join(pd)2 ~6 h8 [2 l7 v6 I/ |; z
dir = [1,-1,3,-3]( ?% Y) B  }9 _/ \4 C: s# E, j- x, N
s = ['0'] + list(map(str,input().split()))( m# q% D6 n4 O
idx = s.index('x')
! C: s$ D+ w3 t* q. ^% y) G& vmp = defaultdict(int)/ V4 t6 @6 W$ X% ]0 H, c8 e
def bfs():  m8 T& y' i  R( O1 x7 t" S: x! m( t0 K
    q = deque()  r/ U( @0 k  Y( u
    step = 0( w7 I4 F, }6 P+ |+ `0 Z
    q.append( [s,idx,step] )
7 I& V- G4 }6 b: i    ns = "".join(s)
: A( A3 i- T; C7 q, k6 b! a    mp[ns]=1
4 U: Y. G, S5 |: a% G    flag,res = 0,-1
. F5 p" F% O! e3 n7 l5 G3 b    while q:
* X9 P0 F7 Y$ N: q; j, w        ss,sidx,step = q.popleft()) m2 v3 h; P. X6 T
        if "".join(ss)==norm:# O' G( ?4 v; p1 U* x, E
            res = step8 ^  V- _9 u: c$ H: Z# W5 L) _
            break
! Y, S  t, o" |/ K        for i in dir:
8 E5 Z9 ]5 ~; C# l            teps = ss.copy(): o/ J5 b0 a6 ?0 m. i) z: i/ w0 M3 F
            nidx = sidx + i
# F0 i9 i4 L* P( [2 \( S" Z+ G1 ?            if nidx<1 or nidx>9:continue" W2 u, C: ?  w4 j8 I! u
            if (sidx==3 or sidx==6) and i==1:continue/ D  o* s3 C% |4 D: H/ A
            if (sidx==4 or sidx==7) and i==-1:continue
( ]& P  _1 z# o7 |            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]
) g& v: e' r5 y. w6 V1 S  C( G/ ]            nteps = "".join(teps)
% k$ L  w6 f0 W% u$ W" v, R" k            if  mp[nteps]:continue* C3 V) ]: C, C/ ^$ @
            mp[nteps]=1
# e9 S  u2 O- C, O# a6 c            q.append( [teps,nidx,step+1] ): X2 k$ g( M% G' \3 s' q8 N( z! k* s5 i
    print(res)" A! ]" W  z6 {2 [# J' e) V: I2 m
bfs()7 g# b* g3 ]5 n

0 m9 w9 G: A6 m; n  ~+ @- O
& L% O7 j7 I0 m2 i6 e2 Y, m; K4 B& F( |
6 G" g# c' Q, M& p& m+ ]

# S) }& y, P6 q6 w  Z: r5 |" E* w

代码.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-16 07:03 , Processed in 0.419786 second(s), 55 queries .

回顶部