BFS算法(下)

紧接着上文,我们继续学习BFS算法的剩下的内容

class Solution {

public:

vector<vector<int>> updateMatrix(vector<vector<int>>& mat) {

int m=mat.size(),n=mat0.size();

vector<vector<int>> nums(m,vector<int>(n,-1));

queue<pair<int,int>> q;

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

if(matij==0){

numsij=0;

q.push({i,j});

}

}

}

int dx4={0,0,1,-1};

int dy4={1,-1,0,0};

while(q.size())

{

auto a,b=q.front();

q.pop();

for(int k=0;k<4;k++){

int x=a+dxk,y=b+dyk;

if(x>=0&&x<m&&y>=0&&y<n&&numsxy==-1){

numsxy=numsab+1;

q.push({x,y});

}

}

}

return nums;

}

};

class Solution {

public:

int numEnclaves(vector<vector<int>>& nums) {

int m=nums.size(),n=nums0.size();

vector<vector<bool>> vis(m,vector<bool>(n));

queue<pair<int,int>> q;

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

if(i==0||i==m-1||j==0||j==n-1){

if(numsij==1){

q.push({i,j});

visij=true;

}

}

}

}

int dx4={0,0,1,-1};

int dy4={1,-1,0,0};

while(q.size()){

auto a,b=q.front();

q.pop();

for(int k=0;k<4;k++){

int x=a+dxk,y=b+dyk;

if(x>=0&&x<m&&y>=0&&y<n&&numsxy==1&&!visxy){

q.push({x,y});

visxy=true;

}

}

}

int ret=0;

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

if(!visij&&numsij==1) ret++;

}

}

return ret;

}

};

class Solution {

public:

vector<vector<int>> highestPeak(vector<vector<int>>& is) {

int m=is.size(),n=is0.size();

queue<pair<int,int>> q;

vector<vector<int>> nums(m,vector(n,-1));

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

if(isij==1){

numsij=0;

q.push({i,j});

}

}

}

int dx4={0,0,1,-1};

int dy4={1,-1,0,0};

while(q.size()){

auto a,b=q.front();

q.pop();

for(int k=0;k<4;k++){

int x=a+dxk,y=b+dyk;

if(x>=0&&x<m&&y>=0&&y<n&&numsxy==-1){

numsxy=numsab+1;

q.push({x,y});

}

}

}

return nums;

}

};

class Solution {

public:

int maxDistance(vector<vector<int>>& nums) {

int m=nums.size(),n=nums0.size();

queue<pair<int,int>> q;

vector<vector<int>> an(m,vector<int>(n,-1));

for(int i=0;i<m;i++){

for(int j=0;j<n;j++){

if(numsij==1){

anij=0;

q.push({i,j});

}

}

}

int ret=-1;

int dx4={0,0,1,-1};

int dy4={1,-1,0,0};

while(q.size()){

auto a,b=q.front();

q.pop();

for(int k=0;k<4;k++){

int x=a+dxk,y=b+dyk;

if(x>=0&&x<m&&y>=0&&y<n&&anxy==-1){

anxy=anab+1;

q.push({x,y});

ret=max(ret,anxy);

}

}

}

return ret;

}

};

我们下面将要对扩朴排序进行使用哈!

class Solution {

public:

bool canFinish(int n, vector<vector<int>>& p) {

unordered_map<int,vector<int>> edges;

vector<int> in(n);

for(auto e: p){

int a=e0,b=e1;

edgesb.push_back(a);

ina++;

}

queue<int> q;

for(int i=0;i<n;i++){

if(ini==0) q.push(i);

}

while(!q.empty()){

int t=q.front();

q.pop();

for(int e:edgest){

ine--;

if(ine==0) q.push(e);

}

}

for(int i:in)

if(i) return false;

return true;

}

};

class Solution {

public:

vector<int> findOrder(int n, vector<vector<int>>&nums) {

unordered_map<int,vector<int>> edges;

vector<int> in(n);

for(auto e: nums){

int a=e0,b=e1;

edgesb.push_back(a);

ina++;

}

queue<int> q;

for(int i=0;i<n;i++){

if(ini==0) q.push(i);

}

vector<int> ret;

while(q.size()){

int t=q.front();

q.pop();

ret.push_back(t);

for(auto e:edgest){

ine--;

if(ine==0) q.push(e);

}

}

if(ret.size()==n) return ret;

else return {};

}

};

class Solution {

public:

unordered_map<char,unordered_set<char>> edges;

unordered_map<char,int> in;

bool check;

string alienOrder(vector<string>& words) {

for(auto& s:words){

for(auto ch:s){

inch=0;

}

}

int n=words.size();

for(int i=0;i<n;i++){

for(int j=i+1;j<n;j++){

add(wordsi,wordsj);

if(check) return "";

}

}

queue<char> q;

for(auto&a,b: in){

if(b==0) q.push(a);

}

string ret;

while(q.size()){

char t=q.front();

q.pop();

ret+=t;

for(auto ch: edgest){

inch--;

if(inch==0) q.push(ch);

}

}

for(auto &a,b: in){

if(b!=0) return "";

}

return ret;

}

void add(string& s1,string& s2){

int n=min(s1.size(),s2.size());

int i=0;

for(;i<n;i++){

if(s1i!=s2i){

char a=s1i,b=s2i;

if(!edges.count(a)||!edgesa.count(b)){

edgesa.insert(b);

inb++;

}

break;

}

}

if(i==s2.size()&&i<s1.size()) check=true;

}

};

相关推荐
Momo__zz11 分钟前
零代码平台设计
算法·深度优先
cpp_250119 分钟前
P2947 [USACO09MAR] Look Up S
数据结构·c++·算法·题解·单调栈·洛谷
水木流年追梦1 小时前
大模型入门-大模型优化方法13- MTP 多 token 输出、DCA 双块注意力
人工智能·分布式·算法·正则表达式·prompt
数据皮皮侠1 小时前
全国消协智慧 315 平台投诉信息数据库
大数据·人工智能·算法·百度·制造
8Qi81 小时前
LeetCode 115 & 392:不同子序列 / 判断子序列
算法·leetcode·职场和发展·动态规划
小蒋学算法1 小时前
算法-乘法表中第K小的数-二分
数据结构·算法
智者知已应修善业2 小时前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机
Evand J2 小时前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制
插件开发2 小时前
矢量路径运算如何选GPU技术?——适用算法对比及OpenGL/Direct3D/CUDA选型指南
算法·3d
8Qi82 小时前
LeetCode 72:编辑距离(Edit Distance)—— 题解
算法·leetcode·职场和发展·动态规划