QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】
3 T! P% Z, T4 ^6 _) l4 t( [3 r$ [2 x( I% i, ]  O4 J
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。7 D1 _: ?$ `7 s! J. T
& T7 m! ?# y' e
例如:" v0 U" h2 `* L& K3 z% o* L' R1 `

7 w; k, x  S+ L' j( d. M1 2 38 v5 z! K! V3 J+ i9 k& q
x 4 6  c! Q5 D. L: C9 a0 g$ U5 t4 Y
7 5 8$ F( b; \+ t6 I  o# I
        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):- K2 l' M' C: [
( x7 _' W# L! p3 z/ y  }
1 2 3
+ ?3 m% {, j" U' J2 I0 S4 5 6' K, z5 q+ n, }
7 8 x! z) s8 k; d# I, J0 d" E& i
        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
* P. a6 w1 y- s: c4 H7 J
. n9 _! s8 h) T5 Q1 2 3   1 2 3   1 2 3   1 2 3
* T, h5 @! U: a5 Y% D0 nx 4 6   4 x 6   4 5 6   4 5 60 S: A/ b: [3 C: _
7 5 8   7 5 8   7 x 8   7 8 x4 Z! o& S) F5 i, w9 |
         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。) g; n( }2 E7 Y0 ~4 H' M1 }1 T

6 U4 A2 L" f5 S2 Z% A, X1 C# s【输入格式】
6 G5 c& }( B5 o! Y2 u0 I* S$ [3 r
/ `' t% }5 O( F6 [6 K        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:# N, M. Y) `3 r  `
3 c1 V6 Z0 \8 f% \
1 2 3 9 V. P2 X& n. X: R& @2 ?- Q
x 4 6 / O, r$ @& O# T, E' A  _' ~8 T- q
7 5 8
, r( @6 h/ c7 O% Y        则输入为:1 2 3 x 4 6 7 5 8  ?$ L. V6 ^( r( Z$ f

4 ~2 @! x5 q' T8 x【输出格式】
0 Q% S: }: E4 R% z0 u
1 r5 M/ j/ I) j3 z8 l/ E( `' ]0 ]        输出占一行,包含一个整数,表示最少交换次数。
7 u4 C, T7 z, S' D8 G) B' l- O  R: `4 |. s% u! ]6 j. p
        如果不存在解决方案,则输出 −1。
% n. V! b' r$ V8 I6 P) f
3 s& e: m8 [' P【输入样例】
% b- r* l* K2 i9 P9 k( ^2 Z: ^9 {4 p5 R8 ^, O7 K" x
2 3 4 1 5 x 7 6 8% U6 Q1 f. U5 A5 h  r# T  K
【输出样例】
) Q" T; S6 q) r2 Q  ?6 Z$ c  M6 H9 Q' a5 y+ U
19
+ q6 J3 T' c+ V+ B0 v6 C【解题思路】
4 R8 c' A$ d  ~" }% X$ \) ~3 l+ u3 T% V' |+ g  z5 Z& b
        简答题,用BFS遍历查找即可。+ }6 l9 ^$ r% T4 W5 u4 K3 a
$ \  r  d: u4 M& F
【Python程序代码】
1 [) B7 ~/ P& `- M- B& C; P$ @' e7 u* {3 u' e+ X" Y+ s. H
from collections import *  ^) A% V/ j7 x' Z: @1 i. r
pd = ['0','1','2','3','4','5','6','7','8','x']
$ j2 {0 j0 P( Knorm = "".join(pd)
" a7 ?% v; U0 {5 z! f$ L, ldir = [1,-1,3,-3]
# A5 N. ]/ P( L  fs = ['0'] + list(map(str,input().split()))2 z3 H/ d, d& `
idx = s.index('x')
' w4 w6 X( E) s7 c& S. ?mp = defaultdict(int)
; g9 f$ o2 }$ V2 `! U3 Z) Q: kdef bfs():
" o+ r; v; A$ H( P2 Z    q = deque()
8 L1 u" p; Q5 u1 z3 N; s! [    step = 0) T8 R/ I; y, Q
    q.append( [s,idx,step] )
2 _7 l6 u, s4 O+ U8 M    ns = "".join(s)" g1 D( a3 ~; B( ?
    mp[ns]=1
% N- D! n& f& f! @: K    flag,res = 0,-1* Z1 x( s  h3 v* L$ ^
    while q:! h% D' V7 X( M" |6 W3 f
        ss,sidx,step = q.popleft()1 z0 L, k# G- m' R( S
        if "".join(ss)==norm:
* u1 q0 Z( [% Z+ a. P# p5 [* O/ i            res = step
# }2 D3 F% H0 n& N- J            break
+ T& }& G! F3 j# V        for i in dir:) O; [6 y- k/ t8 O
            teps = ss.copy()+ A" S; U9 X" b6 }1 e0 ?6 G7 x7 |
            nidx = sidx + i
; s. c0 b  b% b  p; Z            if nidx<1 or nidx>9:continue
1 b7 x! ]& l5 f/ [3 T8 P            if (sidx==3 or sidx==6) and i==1:continue
8 [, j$ _) F! O+ _% }            if (sidx==4 or sidx==7) and i==-1:continue1 @" r+ J3 F# z1 s7 \
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]
$ Y" O) b' z! c( H# t$ b5 M            nteps = "".join(teps). q0 f& h3 V: i: G2 b
            if  mp[nteps]:continue$ V. {3 V2 r1 s) D0 e, A' y
            mp[nteps]=1; Q3 w/ r3 s" F6 q: y
            q.append( [teps,nidx,step+1] )
. n( }9 S. [" C, @5 o    print(res)( ]2 N. L3 u6 r
bfs()$ a4 E- q  l7 }/ P" N: }
( x. |, R/ L' b# R- u& H* l' Q. w
0 K+ |. b/ _; v5 ]0 A# i9 E, y

$ l4 Z, W  f1 O4 n: L0 t
4 v4 ~/ l! x3 k7 g3 }6 O' l  C. x$ U& v1 U8 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, 2026-4-10 11:43 , Processed in 0.300444 second(s), 55 queries .

回顶部