QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1176

主题

4

听众

2884

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】$ h  D2 _. ]$ p  f5 ?  y
$ x5 B& d3 j- K' C1 U7 @8 ~7 }& u
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。% p: e* @5 X' p' s' ]9 G6 u9 z
( d! A! t! J$ \; I7 d3 g5 }
例如:& o3 B: J! y* n* |. a# G; [

9 ^, K4 P! s6 _, O! t1 2 3
' U- a' D2 E0 @1 A9 gx 4 65 r  y- G1 ]% j$ c0 F! f1 u3 j
7 5 8
  R! D9 A! j7 J1 Q  I9 K& A        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
2 R+ s- Y) H+ V7 R5 ?. U0 X. k2 q6 Z4 d- I- |
1 2 3; S& M6 h, K$ q% r  B
4 5 6
/ Y3 z2 h# `- w: |2 \7 Z7 8 x7 ?- o, r5 x. F
        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
( F8 c8 V7 r. y8 n3 Q, ?7 b4 |7 S7 k/ a6 k7 ]# T" ^
1 2 3   1 2 3   1 2 3   1 2 38 G9 I1 \1 o$ E5 m( [$ a
x 4 6   4 x 6   4 5 6   4 5 6* O0 ^( g- L/ b6 Q$ W5 v' h) \
7 5 8   7 5 8   7 x 8   7 8 x$ R0 r  a: a8 x
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。/ m# N" T9 o$ u! x
* \, S$ N/ ~- l0 v) J
【输入格式】0 T3 V1 D& b" T9 r
: q1 M+ Z7 \: J4 o9 y, g+ g4 t
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:. h6 E- {8 c" H* X1 k* p$ `
* O" n. K# j/ N
1 2 3
, M  r7 d) S5 K" m8 V. J8 Kx 4 6
' Q) t( h/ h+ f: U: V7 5 8 3 ~$ u3 M( x2 y3 D) F8 f
        则输入为:1 2 3 x 4 6 7 5 8, v- I+ W4 Q) v; o2 {% R2 M
: g) K. V4 w2 z- v: A) A, `
【输出格式】
% F2 i% i# y. p1 k0 p& u
% M0 n/ H) |/ q  R0 C  i2 D. w        输出占一行,包含一个整数,表示最少交换次数。
: w5 v' E2 m. _6 k
; ^4 j# d* v% j        如果不存在解决方案,则输出 −1。3 {2 [2 `3 o' \. K

$ j) n! {* V- @% U6 L- @+ d【输入样例】" H) Q4 r* S; S6 j9 }$ O
7 @1 `! `$ t, R% D6 r
2 3 4 1 5 x 7 6 86 S7 s) d& N- O$ u
【输出样例】& W& _0 s; n1 T# Y0 i6 F

- F& |! }, `# ], s19
1 ?9 O1 V0 L( i【解题思路】
! L' Q7 o" e7 k2 W; g
: v+ U1 ?* V) p; J- R        简答题,用BFS遍历查找即可。
" `( S' a, G! k2 F$ e' z0 {& r% s: Q& g. G6 T- `4 p
【Python程序代码】& o* u* d% _0 S, v" ]

0 [2 w5 b( \0 z6 E: E9 a9 Tfrom collections import *
" `% I2 K8 p9 A+ _6 R2 {9 rpd = ['0','1','2','3','4','5','6','7','8','x']
! \% M0 r& |7 ynorm = "".join(pd)1 L& W+ M' x5 F" q/ h
dir = [1,-1,3,-3]# _" R! k/ x: }5 P+ Z: T- D
s = ['0'] + list(map(str,input().split())). E- R1 _1 o5 R5 _
idx = s.index('x')
/ O# a* J0 X: ]4 w% u# o( E( Mmp = defaultdict(int)
$ Q0 k$ b! X3 E+ idef bfs():  v- V( I, D, |6 K$ v
    q = deque()
' U/ ?" x; y  Q; J8 k9 X    step = 09 k6 Q- X5 k1 S: u, j/ j
    q.append( [s,idx,step] )1 ]& B$ _) i0 X9 U
    ns = "".join(s)
; k$ i( i1 @. C9 Z; A7 S& C$ |( E" g    mp[ns]=1& {: j  w9 ]3 k' _6 ^8 ~: M
    flag,res = 0,-1( q6 r7 b8 n# V6 v
    while q:' f+ R2 }) V. [# S5 Z
        ss,sidx,step = q.popleft()
; S8 @3 W5 l1 Z% L        if "".join(ss)==norm:, Y5 d! Q, n4 c. m! X
            res = step
' f- ^9 V% `& |            break+ v7 E. z& H. M& X
        for i in dir:
( P. @* p/ l6 U% f) f/ ^5 q3 [5 X            teps = ss.copy()
6 U5 E. M7 C6 C. q  n$ A! ^            nidx = sidx + i' P. _9 P1 t2 v6 u, `
            if nidx<1 or nidx>9:continue* o! G! u0 e0 Q
            if (sidx==3 or sidx==6) and i==1:continue$ p* l' y( S$ R0 j- U" {
            if (sidx==4 or sidx==7) and i==-1:continue
- f! d* v) e! p+ r/ j% _" \            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]+ B. U0 H; q  J/ @5 u
            nteps = "".join(teps): {1 J' H. u+ E
            if  mp[nteps]:continue
3 T' J, K! r8 R" v            mp[nteps]=1
. L: T( w- V4 R1 y) s5 }7 l4 O            q.append( [teps,nidx,step+1] )
" S+ @- k+ q4 C3 m    print(res)" Y8 X# a4 k- J, O% m4 f
bfs()7 u/ D- g9 `% Y9 W& e

, G6 t. V) d! \% A
7 |5 @- r" T5 ]$ O: ]/ N
" p5 q# G5 R# {+ I2 y: a- k: v, j0 u5 F5 V% ?
% }! z5 I' b1 B: \  d; J

代码.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, 2025-9-22 20:38 , Processed in 1.083743 second(s), 54 queries .

回顶部