QQ登录

只需要一步,快速开始

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

python 解决八数码问题

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-20 11:44 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
题目描述】) e/ a8 t- G+ m$ F
! u$ w/ i9 V9 l
        在一个 3×3 的网格中,1∼8这 8 个数字和一个 x 恰好不重不漏地分布在这 3×3的网格中。
. Z7 y! o* d1 z, \9 ~3 L: P$ C  }( u% @7 d
例如:
* @4 B+ m) c) V! N  [6 x" V& p! ~/ d7 v# w# R! ~, v& E' B
1 2 3
. r0 V' c' Q; _- Y6 t9 M/ U- ~x 4 6" m: m7 \7 I! S$ r) W  K8 c4 x) b
7 5 8
) X$ A& H# M. }+ ?9 Z5 L        在游戏过程中,可以把 x 与其上、下、左、右四个方向之一的数字交换(如果存在)。我们的目的是通过交换,使得网格变为如下排列(称为正确排列):8 k0 H# [7 O1 r+ G3 K5 ?+ s7 q8 b
! |5 h1 g. b( w2 B* Z- p
1 2 3
% n: ~+ ^( {0 A8 U  w- k4 5 6
% q# \% B( O7 m3 Z+ b* g5 [* b7 8 x' b8 e% b- ]. c2 z) H$ T0 T1 Y
        例如,示例中图形就可以通过让 x 先后与右、下、右三个方向的数字交换成功得到正确排列。交换过程如下4 {! `& z( {; a5 V& w5 u' L: b. X
5 z% _/ t- B7 B) v' e1 a
1 2 3   1 2 3   1 2 3   1 2 3
0 \7 }6 R$ ~: @. m; Y; Px 4 6   4 x 6   4 5 6   4 5 6
6 x* Z% U4 o5 [7 O7 5 8   7 5 8   7 x 8   7 8 x
3 @" V& p8 u( R1 F         把 x 与上下左右方向数字交换的行动记录为 u、d、l、r。现在,给你一个初始网格,请你通过最少的移动次数,得到正确排列。' J- s$ c2 j# w! i( }1 W! W9 ?6 `

7 @0 v4 ^2 G) F1 h* Q3 p0 V( D) s% L5 x【输入格式】
& ?  t. K, o6 a, @# v# z+ V/ g: r" |0 w& n- \
        输入占一行,将 3×3 的初始网格描绘出来。例如,如果初始网格如下所示:
1 f5 v( a  W( E3 P# f/ w4 U5 }$ \- R3 ]# K( t
1 2 3
* x! v7 b7 X/ ^$ O3 Ex 4 6
  a! f4 C* p$ p5 ?! x7 5 8
! Z: w5 J5 ?1 X3 R+ k: K# B        则输入为:1 2 3 x 4 6 7 5 8
$ H" q/ h# ?% t$ Z  e1 y; F& S$ @/ S8 ]& s- C! F
【输出格式】
  d+ [5 a1 F' ?5 [# ?8 z1 ]$ X: Y( y6 j  z8 Q" B. Y+ c* Z
        输出占一行,包含一个整数,表示最少交换次数。# f/ P  R0 s& u0 j$ u, I$ i
! z7 R( v  T+ l' I" G2 \* t' K2 k" d
        如果不存在解决方案,则输出 −1。
+ f% L1 l5 N  ]( ~  C( f3 b
9 F( y5 D. d  o& S2 X2 A【输入样例】
: s% `; J) N8 i
( i2 y, E/ q3 T: ]. s) ~& p2 3 4 1 5 x 7 6 89 l  X7 T1 @4 i# Z7 x: m; Q* s
【输出样例】- U) k" q" M+ k; T) _: U5 U: f: X
- e5 [1 f# o( S4 F+ I$ s0 ^# v0 p6 C% M
19
" |3 ~( H# e; \2 \" D【解题思路】0 }* a* x3 K* ~& T1 E

; C$ ?- F0 L* S' q" x& ~        简答题,用BFS遍历查找即可。
7 ~! P. m* ~& A
: |  ^1 H! [5 N+ D  q9 F) g' f* X+ R【Python程序代码】
9 p- `' x) d8 `
: j9 E' \% T; B7 |$ _( afrom collections import *' k4 F7 D) M8 p2 M$ A: z7 j
pd = ['0','1','2','3','4','5','6','7','8','x']# b8 m7 j/ T) ~+ o+ s; O2 T
norm = "".join(pd)
) V7 b+ Z' {8 c* F1 M; Rdir = [1,-1,3,-3]
* K8 b, a% ?' ~* P, Is = ['0'] + list(map(str,input().split()))
" ^4 v4 s5 w# }% }idx = s.index('x')
+ J6 T# O" g! y; Mmp = defaultdict(int)7 j$ x6 ~) y6 [  I# [; F, o
def bfs():
8 V) H# P: Q. i* l  I  X4 h  Y( p    q = deque()- J( S7 `8 ~5 ^& U, R
    step = 0
; C5 u6 z0 s" @  s! R9 U    q.append( [s,idx,step] )5 L9 e0 q+ ^0 ]$ v3 B
    ns = "".join(s)
! P1 q& r8 R' z: p" k: d    mp[ns]=1
4 w+ X/ ]% B0 }% ~3 E! w5 D    flag,res = 0,-1$ h. s% u9 N6 B7 U( w: I4 ~% I; s, I; c
    while q:6 G, X6 E* Z% a# ]9 E. i3 {6 @- E
        ss,sidx,step = q.popleft()& I2 D" ^! L6 G! t# [' \
        if "".join(ss)==norm:- A* Y5 t2 i5 n7 z
            res = step: J% ^( h7 s( [0 h
            break/ c" b6 z9 o1 }* P- n0 @1 }, h
        for i in dir:5 X1 V( U* O3 v
            teps = ss.copy()1 V; z2 [5 X- D8 J
            nidx = sidx + i
2 Z# ]5 s( ]! ]! b4 z            if nidx<1 or nidx>9:continue* ^! L2 `2 R' p6 j7 ^1 Z
            if (sidx==3 or sidx==6) and i==1:continue
  }$ w, H7 _$ U            if (sidx==4 or sidx==7) and i==-1:continue
: r* i- L3 @2 M, W            teps[sidx],teps[nidx] = teps[nidx], teps[sidx]5 Q  |- k' y) b2 n& Q; W9 E& X4 Q
            nteps = "".join(teps)( O9 C5 g6 p8 W6 s
            if  mp[nteps]:continue
: X% @, M3 I7 k5 j            mp[nteps]=1/ D2 a1 R0 d+ ]7 {
            q.append( [teps,nidx,step+1] )
/ J& ~/ N$ K* e# b    print(res)
3 Q2 `, M7 _) r) e0 X2 ^bfs()
! T4 V/ o, W# j3 p& [
  j- W. u# A4 K$ `  V) h& ~7 U6 L
" }: l. q) p' H, B
7 U8 M0 z( c1 \; D# M9 J" B7 ?* l; k; n# a/ l

; b* c8 M) _: p# q% w

代码.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 17:06 , Processed in 0.411449 second(s), 55 queries .

回顶部