数字可输入

时间: 2023-11-18 20:05:18 浏览: 34
好的,下面是带数字输入的八数码问题的 C++ 代码: ```c++ #include <bits/stdc++.h> using namespace std; const int N = 3; // 8数码问题的规模为3 const int dx[] = {0, 0, 1, -1}; // 四个方向的x坐标变化 const int dy[] = {1, -1, 0, 0}; // 四个方向的y坐标变化 struct Node { int state[N][N]; // 当前状态 int x, y; // 空格的位置 int step; // 当前步数 Node() {} Node(int s[][N], int _x, int _y, int _step) { memcpy(state, s, sizeof(state)); x = _x, y = _y, step = _step; } }; int st[N][N]; // 初始状态 int ed[N][N]; // 目标状态 int bfs() { queue<Node> q; unordered_set<string> vis; // 判重 q.push(Node(st, 0, 0, 0)); vis.insert(string((char*)st, (char*)st + N * N)); // 将初始状态加入到visit中 while (q.size()) { auto t = q.front(); q.pop(); if (!memcmp(t.state, ed, sizeof(ed))) return t.step; // 判断是否到达目标状态 for (int i = 0; i < 4; i ++ ) { int a = t.x + dx[i], b = t.y + dy[i]; if (a < 0 || a >= N || b < 0 || b >= N) continue; // 判断是否越界 auto c = t.state; swap(c[t.x][t.y], c[a][b]); // 交换空格和相邻位置的数 if (vis.count(string((char*)c, (char*)c + N * N))) continue; // 判断是否重复 q.push(Node(c, a, b, t.step + 1)); // 将新状态加入队列 vis.insert(string((char*)c, (char*)c + N * N)); // 将新状态加入到visit中 } } return -1; } int main() { cout << "请输入初始状态:" << endl; for (int i = 0; i < N; i ++ ) for (int j = 0; j < N; j ++ ) cin >> st[i][j]; cout << "请输入目标状态:" << endl; for (int i = 0; i < N; i ++ ) for (int j = 0; j < N; j ++ ) cin >> ed[i][j]; cout << bfs() << endl; return 0; } ``` 在该代码中,我们在 `main` 函数中先输出提示信息,让用户输入初始状态和目标状态。在输入过程中,我们使用两个嵌套循环来读入每个数字。在 `bfs` 函数中,我们在搜索过程中,每次将新状态加入到哈希表中进行判重。

相关推荐

最新推荐

recommend-type

V90数字量输入输出接线

V90 PTI数字量输入接线 V90脉冲版的数字量输入支持 PNP 和 NPN 两种接线方式,接线方式如下
recommend-type

vue实现输入一位数字转汉字功能

主要介绍了vue实现输入一位数字转汉字功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

python2练习题——编写函数,输入数字,判断是否是素数

定义 素数又称质数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数。 性质 质数具有许多独特的性质: (1)质数p的约数只有两个:1和p。 (2)初等数学基本定理:任一大于1...
recommend-type

C++实现对输入数字组进行排序

里给大家介绍的是通过某个方法实现判断命令行中输入的数字是几个,这样再用冒泡法排序的时候就不用担心输入的是几个数字,用到的知识主要是冒泡法排序
recommend-type

python逆序打印各位数字的方法

今天小编就为大家分享一篇python逆序打印各位数字的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

HSV转为RGB的计算公式

HSV (Hue, Saturation, Value) 和 RGB (Red, Green, Blue) 是两种表示颜色的方式。下面是将 HSV 转换为 RGB 的计算公式: 1. 将 HSV 中的 S 和 V 值除以 100,得到范围在 0~1 之间的值。 2. 计算色相 H 在 RGB 中的值。如果 H 的范围在 0~60 或者 300~360 之间,则 R = V,G = (H/60)×V,B = 0。如果 H 的范围在 60~120 之间,则 R = ((120-H)/60)×V,G = V,B = 0。如果 H 的范围在 120~180 之间,则 R = 0,G = V,B =
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。