QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】
' Z, R! ?# T* D- [3 W/ J" H+ [+ a4 `6 K8 r
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。/ u1 I; U, T0 \: v/ a
' `1 y/ C; J6 V! a0 {# l4 Z0 ]
例如:
- D& t/ Y+ J; J
  e4 g* T0 |& ~" z2 X4 y1 2 3
3 I/ [' V; N4 x' G9 }# u2 Vx 4 61 M4 k. X4 n9 c! G$ s9 `7 O& k5 c& y
7 5 8  d! D) y# F( S3 ^% f4 S& Q! }  s
        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):
6 `$ P( E$ `! K% \; V$ i
! _$ |& _0 {+ @) D  x1 2 3
$ `) j5 y$ a+ L  y. G2 D4 5 6: Q7 s9 {* k; k! h
7 8 x
( C1 u1 u$ o/ ~, r6 m$ r        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下
: c2 N+ M/ }7 X4 w# E# s- g7 Z, P+ K/ l9 s5 j
1 2 3   1 2 3   1 2 3   1 2 39 K9 C$ B+ z, O, K
x 4 6   4 x 6   4 5 6   4 5 6
0 y, A0 Y: a: V* x7 5 8   7 5 8   7 x 8   7 8 x
: K7 L4 L% N5 M% G         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。9 e0 a) o7 Z) L& z$ D

4 b/ F- x, ^1 A1 N% `1 A【输入格式】6 c! H* b( o+ s4 t2 m
+ R  N+ A) \! z
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
7 s4 _# N- v$ w7 b
# _; ^1 n# R- _1 2 3
* r& K# j& d& a: N7 f& Fx 4 6 3 L) L* N+ O: L* q
7 5 8
+ X, n  I# _/ m" S( R/ R* S  M        则输入为:1 2 3 x 4 6 7 5 8
& k2 C% u1 M* P. u. b
4 W- Y$ P5 t; M( i6 O【输出格式】- b& R- D6 e8 t! x
5 n" O; V% N' n
        输出占一行,包含一个整数,表示最少交换次数。& `8 m1 G" P! ]% C; o8 x# v

. C% \% m2 ]) e5 v, T2 g, F        如果不存在解决方案,则输出 −1。, _% d3 s' }7 x% b& _4 e5 g
- ^4 U7 p0 }! |/ l" Z
【输入样例】3 }4 t5 }1 `& p3 d1 g+ {" Y

# ^, l1 o0 P% O8 ~' `8 v2 3 4 1 5 x 7 6 8
3 ~* S( b3 q. c; W' u【输出样例】
& I0 f" b0 _1 T
+ V, M4 L2 N4 v" P- P; b19. ]. ?+ a8 {2 }* i* h/ G4 n
【解题思路】& N* X% u2 S6 V

, @4 |* x% K7 P: d. ]        简答题,用BFS遍历查找即可。4 n2 Q! m" g+ t: D
$ L9 U, `. j6 M0 h8 [' D5 d/ T/ |% v
【Python程序代码】5 S* J4 y6 U: v4 q
; r+ X* u. l, L2 q8 G
from collections import *
- _) Q; @3 A/ h7 Y3 c! o* O- hpd = ['0','1','2','3','4','5','6','7','8','x']
$ o8 v1 H3 p2 ~" e) `norm = "".join(pd)
! |0 O0 F4 I- f: Q$ Q1 S6 |dir = [1,-1,3,-3]
: e+ |0 @2 Q9 {# T; f) V% B; ?8 ns = ['0'] + list(map(str,input().split()))
/ s4 J; ^& [* y1 u1 Lidx = s.index('x')8 K3 l* G! P/ W/ q3 x' [$ G0 Q
mp = defaultdict(int)2 p3 Z# k, k' k2 m% [; s
def bfs():+ S! P5 O. {8 R' ^( \& T
    q = deque()
" T# h% @% }( [) U( X+ X    step = 0, J3 m6 u; v3 l$ Q- X5 O+ _
    q.append( [s,idx,step] )
  M: l5 ~" @, Q- W- |    ns = "".join(s)& t% o. A1 P3 P" B5 C9 \* E- t
    mp[ns]=1. S& J# O7 w* S0 F4 l/ W
    flag,res = 0,-1
$ N& _2 U* K3 U$ _  d# g, W# z    while q:3 O& p( ^2 x# c3 `/ A
        ss,sidx,step = q.popleft()
; @# P# N) c* l; u& g  b- J        if "".join(ss)==norm:
' n2 T) T8 Z+ d# Z  Q* ^9 Z            res = step4 |$ P6 g* ]3 \% E5 @4 M2 B
            break
6 _, a1 A+ G9 j5 l& a3 `        for i in dir:
& B$ [! u; s+ u) ^# v            teps = ss.copy()# Q* c0 {- @$ N
            nidx = sidx + i# }" |% x; v+ S8 ^; u3 e
            if nidx<1 or nidx>9:continue
% g5 ]% V' g; B7 S) x! @            if (sidx==3 or sidx==6) and i==1:continue9 |+ m+ y/ g0 s
            if (sidx==4 or sidx==7) and i==-1:continue0 G4 v/ U: [) Q5 z
            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]
( t, `* Z& V' V% k; J" {: {2 b  f            nteps = "".join(teps)6 Z  i; Q3 E, k# p; N( [. {6 H
            if  mp[nteps]:continue
+ r3 f& ~; |# v8 c0 Y            mp[nteps]=14 _% I5 L2 W0 c, S5 ]8 i
            q.append( [teps,nidx,step+1] )
+ j3 n' M$ ]+ n2 U    print(res)
% `) W) _7 T. G, y. y2 Y3 Zbfs()
1 R; o$ Q5 ?2 D  u9 F6 i
: E$ c, k( W! {3 p7 f1 {8 B/ l
. G' w! ?! ]; p. _- M+ ]9 B% H. \# J7 b* J# ^8 C
6 z4 M6 h' ~0 ~' E

# n1 d# W# p# b, c

代码.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-13 09:47 , Processed in 0.440988 second(s), 55 queries .

回顶部