QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】
0 X1 N; ~- w. |4 G0 u8 p5 f! R' f1 F4 S$ y1 L5 e# v* L
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。/ a0 f) x4 l/ D+ D; {
6 B' P" \3 s& I  S7 i0 @
例如:& h0 G+ _$ u# z/ L- V/ u* [6 ?

) B/ y8 B" e1 w7 K" B9 d1 2 3& ?6 C, |( U! B2 e+ W3 a
x 4 6
( S; W  T+ h3 j7 5 84 p0 b: F0 y4 R
        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
! U2 p; U3 S! j6 `% O3 m
- Z! j' }9 o6 m0 T- e8 n$ _$ W1 2 3
# t' u6 B8 X; ^; g; b" t4 5 6
/ e, R1 B5 I: ]  R) Y2 t" D3 d7 8 x
! n& i6 T" w8 x' q( h  L1 [5 b        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下; @! B$ K( n1 w: ~( }% s4 Y

; U( W. N& D: Z/ i: V( A& t, u. V1 2 3   1 2 3   1 2 3   1 2 3
; J& v; K& U% P, K3 A" I6 kx 4 6   4 x 6   4 5 6   4 5 6
' H5 H& Y  x% l; B; e; e# D. n$ p7 5 8   7 5 8   7 x 8   7 8 x6 N2 ~; @2 Z# L- q" g7 V) c( V
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。+ u8 g( s1 ]( G

! }1 g& l/ s( n1 w【输入格式】
* n- Z" G6 ?6 q" U# a( B
" j& R+ u- J7 {+ b+ @$ f, D        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:0 e; z1 ]# b+ G* G
0 h! N1 t& g  R8 v8 E3 m" x
1 2 3
- R1 G9 ]6 [: }4 L7 b3 [0 r2 _x 4 6
% M9 h! H5 L# ^( o3 P: c2 |7 \7 X7 5 8
5 d/ R5 H% Z# P) ]0 r        则输入为:1 2 3 x 4 6 7 5 8
. k. G1 h  x  m# T7 ^" n: V
: x$ }/ O4 |+ @5 n9 U【输出格式】. @. F9 b1 D$ A) ^" f+ z2 z7 R
4 A5 O5 p0 {4 L3 k6 y2 D4 ^7 K
        输出占一行,包含一个整数,表示最少交换次数。  E0 V6 Y# r  g4 |! T

) n8 I% T  q1 r        如果不存在解决方案,则输出 −1。
/ R; C& B9 m# e2 b5 ~: s) M* c8 i, B! d% b* _, R7 v
【输入样例】1 h8 q) @, Q9 w( ~! a- A0 c  M
+ o6 l- |- w1 I$ x4 }, `
2 3 4 1 5 x 7 6 8* N( e/ T4 R$ ]$ p2 D
【输出样例】" J8 V8 I* b0 M  `3 Q! [9 f( k

  g3 O( V% B; e+ |7 B3 t4 W19
* y  a2 H' f; R【解题思路】
6 R7 h" D  i# ^7 I2 w9 X: T" T! @( ?9 n6 {4 ?/ N6 ?
        简答题,用BFS遍历查找即可。. ~% u0 l" E* g( O4 f2 A9 L0 C
8 M" q5 G) u3 e, B0 m8 U# D5 M0 [
【Python程序代码】
! g( v' ~- e0 R7 z0 F
8 C9 s+ C7 {: {9 g! i- \0 [6 p5 |from collections import *2 S1 `! @% L/ C& o5 `+ H% x
pd = ['0','1','2','3','4','5','6','7','8','x']
# h4 ~" T' N0 H, knorm = "".join(pd)
- c% H5 @) q& edir = [1,-1,3,-3]& T6 Y; F# G5 E4 T
s = ['0'] + list(map(str,input().split()))
- F' X+ J+ u* D/ W( o# C% W- _idx = s.index('x')
  i: T2 ?5 k, i8 D% v4 Gmp = defaultdict(int)
0 i5 p/ ^. x" j8 c/ h1 I5 Mdef bfs():
0 j3 t) C- v1 f$ i    q = deque()  C1 Z5 Q- ^+ R) U/ a6 C% Z
    step = 0$ U  x' o% [) e
    q.append( [s,idx,step] )) P0 w- _% L8 C: I# w9 I9 s. c
    ns = "".join(s)
8 G% |1 W' M; j* l3 @/ \- Q9 p    mp[ns]=14 B; ^% @/ x, G2 w
    flag,res = 0,-1% {7 h/ z) f2 m' ?+ v
    while q:
  m; n7 w( P& T' a        ss,sidx,step = q.popleft()4 [0 f/ a/ }3 x
        if "".join(ss)==norm:
. H0 u9 A4 H9 A+ r0 m! S3 d            res = step2 ]8 {7 c, c2 A! W  i" ]  s
            break8 ], [* H$ x  D/ e- z( k! s
        for i in dir:2 l. E/ `- U6 d* m8 I/ J3 v3 A
            teps = ss.copy()
' M$ F3 z% C, S: h            nidx = sidx + i1 y  g. q: R- ^4 c* R
            if nidx<1 or nidx>9:continue
! S) Q+ K7 i/ V$ q6 z4 m            if (sidx==3 or sidx==6) and i==1:continue' F$ m, ^+ X$ e
            if (sidx==4 or sidx==7) and i==-1:continue
7 e/ O/ k4 P* d9 `& W- ]            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]1 w1 J4 G' P1 ^  K, ?: {) y" A4 b
            nteps = "".join(teps)
+ k* B$ d" i  o/ k6 [# p            if  mp[nteps]:continue3 a' U  m. E! x$ k7 e
            mp[nteps]=1# L, r5 K! r7 K) }6 X7 v2 E6 }
            q.append( [teps,nidx,step+1] )
' E, Q* w4 I' B0 U+ x    print(res)
: `6 ?# ^7 y: ^# D* }' ~bfs()
9 {' e( _$ r; E  L# D3 d9 B7 j5 U& Z4 o; H( q+ M* q1 y

9 S$ w1 ~/ m! W; c$ U: G. n9 E4 b/ I9 D: N6 y: T+ o

' r0 J# {) N, b3 [2 t" I1 h& j9 r1 E. C# f1 P, H3 ~0 p

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

回顶部