当前位置: 首页 > news >正文

C++ | Leetcode C++题解之第433题最小基因变化

题目:

题解:

class Solution {
public:int minMutation(string start, string end, vector<string>& bank) {int m = start.size();int n = bank.size();vector<vector<int>> adj(n);int endIndex = -1;for (int i = 0; i < n; i++) {if (end == bank[i]) {endIndex = i;}for (int j = i + 1; j < n; j++) {int mutations = 0;for (int k = 0; k < m; k++) {if (bank[i][k] != bank[j][k]) {mutations++;}if (mutations > 1) {break;}}if (mutations == 1) {adj[i].emplace_back(j);adj[j].emplace_back(i);}}}if (endIndex == -1) {return -1;}queue<int> qu;vector<bool> visited(n, false);int step = 1;for (int i = 0; i < n; i++) {int mutations = 0;for (int k = 0; k < m; k++) {if (start[k] != bank[i][k]) {mutations++;}if (mutations > 1) {break;}}if (mutations == 1) {qu.emplace(i);visited[i] = true;}}        while (!qu.empty()) {int sz = qu.size();for (int i = 0; i < sz; i++) {int curr = qu.front();qu.pop();if (curr == endIndex) {return step;}for (auto & next : adj[curr]) {if (visited[next]) {continue;}visited[next] = true;qu.emplace(next);}}step++;}return -1;}
};
http://www.lryc.cn/news/445607.html

相关文章:

  • Qt窗口——QMenuBar
  • python网站创建001:内容概览
  • 代码随想录第22天|
  • WPF-基础-02 DispatcherObject类
  • STM32与51单片机的区别:是否应该直接学习STM32?
  • 【网络底层原理】I/O多路复用技术select、poll和epoll详解与比较
  • 【JavaScript】LeetCode:51-55
  • Spring MVC 拦截器总结
  • Linux——创建编写并编译一个C程序
  • window下idea中scala的配置
  • Qt C++设计模式->享元模式
  • 前端实用技能
  • Android LiveData 数据倒灌
  • umi项目中使用mockj生成数据模拟请求调用
  • 事件【JavaScript】
  • 【Linux】Linux基本命令
  • 微软宣称其新工具可纠正人工智能幻觉 但专家依然对此表示怀疑
  • 实战OpenCV之图像滤波
  • AI学习指南深度学习篇-Adadelta的Python实践
  • go webapi上传文件 部属到linux
  • 接口加解密及数据加解密
  • 开创远程就可以监测宠物健康新篇章
  • 二叉树的基本概念(上)
  • aws s3 存储桶 前端组件上传简单案例
  • 【开源免费】基于SpringBoot+Vue.JS墙绘产品展示交易平台(JAVA毕业设计)
  • python爬虫初体验(四)—— 百度文库PPT的爬取
  • 下水道内缺陷识别检测数据集 yolo数据集 共2300张
  • 年轻用户对Facebook的使用趋势分析
  • EasyCVR全方位安全守护智慧电厂:构建高效视频监控系统优势分析
  • 基于深度学习的情感生成与交互