QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】
, f9 c% z7 P+ [0 Q; A
  S* g( d+ j5 D1 {+ x3 O6 p7 e        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。( z7 l6 F5 X) L) T& ~* U  h

! x' W2 \0 ~# P# \5 V例如:
' z  X) Z# z" V6 |; M
" A1 p3 ]% r  @$ z0 }$ `7 d1 2 3& ]  T' b, J  M2 j: u$ ?# @7 e
x 4 6
) l8 Q' W4 X1 a! j6 M7 5 8/ w$ |0 x, c- u
        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):6 M, ]$ t# B5 v( S' O* ?

, r' R" X/ u" m6 p- H- ]1 2 39 C' q: B* [* W! l8 U
4 5 6; J( l& {+ E& K9 L3 n' h5 E
7 8 x
: d8 \6 [& X; e( x# [$ E        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
$ }9 C: ]; F- I0 U
7 n! B- a& ]2 g9 D1 2 3   1 2 3   1 2 3   1 2 3# [, m6 D+ K  b( G+ _) C, f
x 4 6   4 x 6   4 5 6   4 5 6* f6 i& ~* m' [
7 5 8   7 5 8   7 x 8   7 8 x/ ^+ m$ n+ B# g  F9 m7 E
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。) D  {1 e4 T$ I; r* Q) }- A

+ W1 Q1 \& h. V/ ?【输入格式】
. J  \7 S# N, |* e
- y2 M0 _( F& ^( C& A        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
" P4 N2 {% g/ H6 M/ K3 x
5 c1 o( s+ \* v6 ?+ B1 2 3
3 L* R, Y% q+ e8 [/ Nx 4 6
4 ~; N# v5 u+ \! f7 5 8 0 N0 u0 d8 q% t% [$ s
        则输入为:1 2 3 x 4 6 7 5 8
. j" B, c! U1 G, P+ f2 \% u" ~& I8 q' R
【输出格式】
2 o7 ]  s- ^7 [, r0 a5 |" m" c5 z0 `8 f1 u
        输出占一行,包含一个整数,表示最少交换次数。
  h' [2 A# R% t  g2 V! W$ c+ m4 W1 \- w3 `
        如果不存在解决方案,则输出 −1。
9 z- i! X$ X- D( P& x
" t# i" E8 H1 X1 _; k- U8 U) s: ^0 m6 v【输入样例】. }7 k" y; Q/ N) C

) L8 ~& z% R' S/ J8 O2 3 4 1 5 x 7 6 8
( B8 A$ Z# {9 N7 E【输出样例】% l; E  Y) ^+ U( G( {1 N
  I1 H0 q% U! S  A( \7 [
19; X( `- E# U- B" e+ t4 T$ {
【解题思路】
4 ]5 D  X, r0 t) q1 X8 k, `) u) O: E- I$ ~
        简答题,用BFS遍历查找即可。" N, c; {1 ^$ r
$ i3 \8 l" `' ^9 t! O
【Python程序代码】
' m+ m# m0 i2 Z) k& u* N( ^( G1 x9 r8 `# _# e* p# U% @
from collections import *0 L! W# @5 y7 d/ b2 W- Y
pd = ['0','1','2','3','4','5','6','7','8','x']
# q' c5 P( V2 @' P; ^norm = "".join(pd)
* Q* B  M& l. [. ]' t- tdir = [1,-1,3,-3]
( r7 g+ ?8 o9 b2 r8 ks = ['0'] + list(map(str,input().split()))* A; \  \+ L8 F( h8 W
idx = s.index('x')
4 u' N3 S! M1 {, |5 Q) J2 z* r. Ump = defaultdict(int)) u; }) u2 j& Y  w, x, q8 V, {' O" M
def bfs():
) C$ k4 u# h( B1 \7 I    q = deque()  z0 E: S& b1 u7 p: A! L9 [8 D
    step = 0  z: R. w! z+ R) {  I( D; n
    q.append( [s,idx,step] )
: f$ J6 j8 }" h: E4 R    ns = "".join(s)$ S9 I) E" @- d
    mp[ns]=1
* _7 d& B  ^+ `3 Y6 u    flag,res = 0,-1
& C- M5 I1 }+ g' M    while q:
6 B0 X8 ?0 F5 [        ss,sidx,step = q.popleft()9 x$ s8 p3 x. y% v  o2 r
        if "".join(ss)==norm:
3 z* Q! E0 Y' b3 X            res = step
9 v1 B3 [) o' }' A& j# X            break
. t- I5 a; O* z' f' h3 K# z, A        for i in dir:
* |0 u" _, }) d            teps = ss.copy()
& u7 P. A, Z$ F: j            nidx = sidx + i- ^9 B9 m( J$ J! q
            if nidx<1 or nidx>9:continue4 Q! h4 o& K" Z- X" y+ i
            if (sidx==3 or sidx==6) and i==1:continue) Y: [/ S0 z* W" f
            if (sidx==4 or sidx==7) and i==-1:continue# c% b( K9 B' {" M
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]2 z7 ^7 z3 ~: r1 L4 C, e! B5 ]
            nteps = "".join(teps)9 {# o6 ^! \$ H3 N9 c: g$ M
            if  mp[nteps]:continue5 j3 S" v7 V# y0 O( _, D; ]9 T
            mp[nteps]=1
; d/ b9 m1 j: |- u! ^1 w            q.append( [teps,nidx,step+1] )6 Q5 }0 W% {: B0 o' p; A7 a
    print(res)  e. d* ~* v% _* G
bfs()* l$ ~9 {7 U, v- X' |) ~6 V9 r9 E. c

& F8 A! W3 C, b  s; e" S5 B' Y' ~: d; B! d2 \# o

9 K5 K2 |$ P, L. G' f! y( A/ d2 a- a# O* t3 W) G4 c3 F' C9 j
9 t0 G& Q) B5 F4 E4 h

代码.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 00:10 , Processed in 0.326867 second(s), 55 queries .

回顶部