【八数码】

news2024/11/26 20:31:27

题目

错误代码

#include<bits/stdc++.h>
using namespace std;
typedef pair<string, int> PII;
#define x first
#define y second

string aim = "12345678x";
int ans = 0x3f3f3f3f;
unordered_map<string, int> m;
void bfs(string s, int pos)
{
    queue<PII> q;
    q.push({s, pos});
    m[s] = 0;
    while(q.size())
    {
        auto u = q.front();
        if(u.x == aim)
        {
            ans = m[u.x];
            return;
        }
        q.pop();
        
        if(u.y - 3 > 0)
        {
            string t = u.x;
            swap(t[u.y], t[u.y-3]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y-3});
        }
        if(u.y + 3 < 9)
        {
            string t = u.x;
            swap(t[u.y], t[u.y+3]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y+3});
        }
        if(u.y/3 == (u.y-1)/3)
        {
            string t = u.x;
            swap(t[u.y], t[u.y-1]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y-1});
        }
        if(u.y/3 == (u.y+1)/3)
        {
            string t = u.x;
            swap(t[u.y], t[u.y+1]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y+1});
        }
    }
    
}
int main()
{
    string s = "";
    int pos;
    for(int i = 0; i < 9; i++)
    {
        char c;
        cin >> c;
        if(c == 'x') pos = i;
        s = s + c;
    }
    bfs(s, pos);
    if(ans == 0x3f3f3f3f) ans = -1;
    cout << ans;
    
    return 0;
}

思考

11个样例过5个TLE,我怀疑是复杂度太高了,枚举的速度太慢了。

不能够用字符串操作吗?但是不用字符串用矩阵进行状态存储也不现实啊。

原因

u.y - 3 >= 0少了=号导致WA

第三个少u.y > 0 导致 TLE

正确代码

#include<bits/stdc++.h>
using namespace std;
typedef pair<string, int> PII;
#define x first
#define y second

string aim = "12345678x";
int ans = 0x3f3f3f3f;
unordered_map<string, int> m;
void bfs(string s, int pos)
{
    queue<PII> q;
    q.push({s, pos});
    m[s] = 0;
    while(q.size())
    {
        auto u = q.front();
        if(u.x == aim)
        {
            ans = m[u.x];
            return;
        }
        q.pop();
        
        if(u.y - 3 >= 0)
        {
            string t = u.x;
            swap(t[u.y], t[u.y-3]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y-3});
        }
        if(u.y + 3 < 9)
        {
            string t = u.x;
            swap(t[u.y], t[u.y+3]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y+3});
        }
        if(u.y > 0 && u.y/3 == (u.y-1)/3)
        {
            string t = u.x;
            swap(t[u.y], t[u.y-1]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y-1});
        }
        if(u.y/3 == (u.y+1)/3)
        {
            string t = u.x;
            swap(t[u.y], t[u.y+1]);
            if(!m.count(t)) m[t] = m[u.x]+1, q.push({t, u.y+1});
        }
    }
    
}
int main()
{
    string s = "";
    int pos;
    for(int i = 0; i < 9; i++)
    {
        char c;
        cin >> c;
        if(c == 'x') pos = i;
        s = s + c;
    }
    bfs(s, pos);
    if(ans == 0x3f3f3f3f) ans = -1;
    cout << ans;
    
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2035383.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《花100块做个摸鱼小网站! 》第二篇—后端应用搭建和完成第一个爬虫

一、前言 大家好呀&#xff0c;我是summo&#xff0c;前面已经教会大家怎么去阿里云买服务器&#xff08;链接在这&#xff0c;需要自取&#xff1a;https://developer.aliyun.com/huodong/dashiblogger?userCodemtbtcjr1&#xff09;&#xff0c;以及怎么搭建JDK、Redis、My…

R 语言学习教程,从入门到精通,R 数据类型(6)

1、R 数据类型 数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。 变量的类型决定了变量存储占用的空间&#xff0c;以及如何解释存储的位模式。 R 语言中的最基本数据类型主要有三种&#xff1a; 数字 逻辑 文本 数字常量主要有两种&#xff1a; 逻辑类型在许多…

vscode配置xdebug断点调试详细教程

注&#xff1a;环境为本地windows开发环境&#xff0c;编辑器为vscode&#xff0c;PHP集成环境工具为EServer vscode安装扩展并配置 安装PHP Debug 扩展中搜索 PHP Debug 并安装&#xff1a; 配置PHP Debug 1、点击扩展设置 2、在设置中&#xff0c;点击 setting.json 3、编…

【C++】从零实现一个高并发内存池

目录 项目简介 技术栈 内存池 内存池解决的主要问题 效率问题 内存碎片问题 整体框架设计 Thread Cache 代码框架 Central Cache 代码框架 Page Cache 代码框架 申请内存流程 Thread Cache Central Cache Page Cache 释放内存流程 Thread Cache Central Cac…

P4213 【模板】杜教筛、P3768 简单的数学题、P3803 【模板】多项式乘法(FFT)

P4213 【模板】杜教筛 题目描述 P4213 【模板】杜教筛 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 运行代码 #include <iostream> #include <map>using namespace std;const int N 2000010; long long vis[N], pm[N], mu[N], phi[N], cnt; map<long lon…

解决手机按键失灵!全新检测方案了解一下!

手机按键在手机设备中起着至关重要的作用&#xff0c;手机按键用于执行各种操作&#xff0c;如接听电话、挂断电话、调节音量、开关机等&#xff0c;方便用户进行基本操作。在生产过程中视觉检测需要确保按键的尺寸、形状和表面光滑度符合设计要求&#xff0c;以保证按键的正常…

寒武纪提出视觉AI新高度:不再依赖LLM, Cambrian-1模型让世界看见多模态的力量!

论文标题: Cambrian-1: A Fully Open, Vision-Centric Exploration of Multimodal LLMs 作者团队&#xff1a;纽约大学谢赛宁, Yann LeCun等人 导读&#xff1a; 寒武纪1号(Cambrian-1)&#xff0c;一种以视觉为核心设计的多模态大语言模型&#xff08;MLLMs&#xff09;&…

技术速递|使用 Native Library Interop 为 .NET MAUI 创建绑定

作者&#xff1a;Rachel Kang 排版&#xff1a;Alan Wang 在当今的应用开发领域&#xff0c;通过利用本机功能来扩展 .NET 应用程序的能力非常宝贵。.NET MAUI 处理程序架构使开发人员能够使用 .NET 代码直接操作本机控件&#xff0c;甚至允许无缝创建跨平台自定义控件。然而&a…

【星闪开发连载】WS63E开发板Windows环境的构建

目录 HiSpark Studio安装 Python环境配置 SDK代码下载 新建工程 海思官方在gitee仓库中提供了一个文档介绍fbb_ws63: fbb_ws63代码仓为支持ws63和ws63e解决方案SDK。技术论坛&#xff1a;https://developer.hisilicon.com/forum/0133146886267870001 - Gitee.comhttps://gi…

WPF 数据模板DataTemplate、控件模板ControlTemplate、Style、ItemsPreseter

一言蔽之&#xff0c;Template就是“外衣”—— ControlTemplate是控件的外衣&#xff0c; DataTemplate是数据的外衣。 DataTemplate 它定义了一个数据对象的可视化结构 DataTemplate常用的地方有3处&#xff0c;分别是&#xff1a; ContentControl的ContentTemplate属性&…

提升体验:UI设计的可用性原则

在中国&#xff0c;每年都有数十万设计专业毕业生涌入市场&#xff0c;但只有少数能够进入顶尖企业。尽管如此&#xff0c;所有设计师都怀揣着成长和提升的愿望。在评价产品的用户体验时&#xff0c;我们可能会依赖直觉来决定设计方案&#xff0c;或者在寻找改善产品体验的切入…

八股总结----计算机网络

0.OSI七层模型 自己的理解&#xff1a;应用层&#xff1a;生成HTTP请求报文-----表示层&#xff1a;将请求报文转换成适合网络传输的数据格式&#xff0c;加密压缩编码等-----会话层&#xff1a;管理两个应用程序之间的会话&#xff0c;包括连接中断等------传输层&#xff1a…

HAProxy 效能飞跃先锋队

目录 一 负载均衡 1.1 四层负载 1.2 七层负载 1.3 四层负载和七层负载的区别 二 Haproxy简介 2.1 概念和内容 2.2 haproxy的基本配置信息 2.2.1 global 配置 2.2.2 proxies 配置 三 Haproxy的算法 3.1 静态算法 3.2 动态算法 3.3 其他算法 四 高级功能及配置 4.…

进程编程及其函数的使用

1. 创建进程 创建进程的核心操作是使用 fork() 系统调用。 1.1 fork() 系统调用 fork() 创建一个新进程&#xff08;子进程&#xff09;&#xff0c;新进程几乎是父进程的完整拷贝。fork() 返回两次&#xff1a; 在父进程中&#xff0c;返回子进程的 PID。在子进程中&#…

Typescript在AI产品中应用越来越广泛

AI产品中的应用 TypeScript 在 AI 产品中的应用逐渐增多&#xff0c;主要得益于其提供的类型安全、面向对象编程和模块化等特性&#xff0c;这些特性使得开发者能够构建可维护、可扩展和高性能的应用程序。 首先&#xff0c;TypeScript 作为 JavaScript 的超集&#xff0c;通…

C++类和对象(2)——取地址运算符重载

一、const成员函数 const放在成员函数参数列表后面进行修饰&#xff0c;那么这个成员函数就是const成员函数&#xff1b;const实际修饰的是成员函数形参中包含的this指针的形参&#xff0c;表明在这个成员函数内部不能对成员进行修改。 例如日期类里面的Print成员函数&#x…

【HarmonyOS NEXT星河版开发学习】综合测试案例-拼夕夕首页

个人主页→VON 收录专栏→鸿蒙开发小型案例总结​​​​​ 基础语法部分会发布于github 和 gitee上面&#xff08;暂未发布&#xff09; 前言 该实战案例并没有用到太多的知识点&#xff0c;只不过用到的一些新东西&#xff0c;要多花时间去熟悉手机app的一些页面&#xff0c;对…

【Python】Python单元测试基础

文章目录 01-单元测试基础什么是单元测试常用的文件结构运行单元测试 01-单元测试基础 什么是单元测试常用的文件结构编写第一个单元测试运行单元测试 什么是单元测试 单元测试是指一个自动化的测试&#xff1a; 用来验证一小段代码&#xff08;单元&#xff09;的正确性&#…

【LLM】医疗大语言模型:CareGPT

向AI转型的程序员都关注公众号 机器学习AI算法工程 CareGPT (关怀GPT)是一个医疗大语言模型&#xff0c;同时它集合了数十个公开可用的医疗微调数据集和开放可用的医疗大语言模型&#xff0c;包含LLM的训练、测评、部署等以促进医疗LLM快速发展。 特性&#xff1a; 添加ChatG…

【Datawhale AI 夏令营】动手学大模型应用开发Task1 Baseline 精读

【Datawhale AI 夏令营】动手学大模型应用开发Task1 Baseline 精读 开源大模型文件预览 Baseline 1.导入库 # 导入所需的库 from transformers import AutoTokenizer, AutoModelForCausalLM import torch import streamlit as st2.模型下载 # 源大模型下载 from modelscope…