算法训练营day67

题目1:

复制代码
#include <iostream>
#include <vector>
#include <string>
#include <unordered_set>
#include <unordered_map>
#include <queue>

using namespace std;

int main() {
    string beginStr, endStr;
    int n;
    cin >> n;
    cin >> beginStr >> endStr;
    unordered_set<string> set;
    for(int i = 0;i < n;i++) {
        string str;
        cin >> str;
        set.insert(str);
    }
    unordered_map<string, int> visitedmp;
    visitedmp.insert(pair<string, int>(beginStr, 1));
    queue<string> qu;
    qu.push(beginStr);
    while(!qu.empty()) {
        string word = qu.front();
        qu.pop();
        int path = visitedmp[word];
        for(int i = 0;i < word.size();i++) {
            string newword = word;
            for(int j = 0;j < 26;j++) {
                newword[i] = j + 'a';
                if(newword == endStr) {
                    cout << path + 1 << endl;
                    return 0;
                }
                if(visitedmp.find(newword) == visitedmp.end() && 
                    set.find(newword) != set.end()) {
                        visitedmp.insert(pair<string, int>(newword, path + 1));
                        qu.push(newword);
                }
            }
        }
    }
    cout << 0 << endl;
    return 0;
}

题目2:105. 有向图的完全可达性 (kamacoder.com)

复制代码
#include<bits/stdc++.h>

using namespace std;

int n, m;

void dfs(vector<vector<int>>& map, int key, vector<bool>& visited) {
    if(visited[key]) {
        return;
    }
    visited[key] = true;
    for(int i = 1;i <= n;i++) {
        if(map[key][i] == 1) {
            dfs(map, i, visited);
        }
    }
}


int main() {

    cin >> n >> m;
    vector<vector<int>> map(n + 1, vector<int>(n + 1, 0));
    while(m--) {
        int i,j;
        cin >> i >> j;
        map[i][j] = 1;
    }
    
    vector<bool> visited(n + 1, false);
    dfs(map, 1, visited);
    for(int i = 1;i <= n;i++) {
        if(!visited[i]) {
            cout << -1 << endl;
            return 0;
        }
    }
    cout << 1 << endl;
    return 0;
}

题目3:106. 岛屿的周长 (kamacoder.com)

复制代码
// 其实可以不用dfs因为题目说了中间岛屿是联通的
#include<iostream>
#include<vector>

using namespace std;
int dir[4][2] = {0, -1, -1, 0, 0, 1, 1, 0};
int n, m;
vector<pair<int, int>> result;
int count = 0;

void dfs(vector<vector<int>>& map, vector<vector<bool>>& visited, int x, int y) {
    if(map[x][y] == 0 || visited[x][y]) {
        return;
    }
    result.push_back(pair<int, int>(x, y));
    visited[x][y] = true;
    for(int i = 0;i < 4;i++) {
        int nextx = x + dir[i][0];
        int nexty = y + dir[i][1];
        if(nextx < 0 || nextx >= n || nexty < 0 || nexty >= m) continue;
        dfs(map, visited, nextx, nexty);
    }
}

int main() {
    cin >> n >> m;
    vector<vector<int>> map(n, vector<int>(m));
    for(int i = 0;i < n;i++) {
        for(int j = 0;j < m;j++) {
            cin >> map[i][j];
        }
    }
    vector<vector<bool>> visited(n, vector<bool>(m, false));
    for(int i = 0;i < n;i++) {
        for(int j= 0;j < m;j++) {
            if(map[i][j] != 0 && !visited[i][j]) {
                dfs(map, visited, i, j);
            }
        }
    }
    for(int i = 0;i < result.size();i++) {
        int x = result[i].first;
        int y = result[i].second;
        for(int j = 0;j < 4;j++) {
            int nextx = x + dir[j][0];
            int nexty = y + dir[j][1];
            if(nextx < 0 || nextx >= n || nexty < 0 || nexty >= m) 
            {
                if(nextx == -1 || nextx == n || nexty == -1 || nexty == m) count++;
                continue;
            }
            if(map[nextx][nexty] == 0) count++;
        }
    }
    cout << count << endl;
    return 0;
}
相关推荐
副露のmagic几秒前
更弱智的算法学习 day18
学习·算法
byzh_rc2 分钟前
[数字信号处理-入门] 采样定理
算法·matlab·信号处理
想进个大厂2 分钟前
代码随想录day6哈希表
算法·leetcode·散列表
less is more_093016 分钟前
文献学习——计及分时电价的电缆配电网多时段二阶段有功与无功协调快速鲁棒优化调度方法
笔记·学习·算法
进击的小头18 分钟前
18_C语言算法面试与进阶:高频算法题实战与学习路线规划
c语言·算法·面试
im_AMBER23 分钟前
Leetcode 97 移除链表元素
c++·笔记·学习·算法·leetcode·链表
海奥华226 分钟前
Golang Channel 原理深度解析
服务器·开发语言·网络·数据结构·算法·golang
Jasmine_llq26 分钟前
《P3200 [HNOI2009] 有趣的数列》
java·前端·算法·线性筛法(欧拉筛)·快速幂算法(二进制幂)·勒让德定理(质因子次数统计)·组合数的质因子分解取模法
Hcoco_me35 分钟前
大模型面试题49:从白话到进阶详解SFT 微调的 Loss 计算
人工智能·深度学习·神经网络·算法·机器学习·transformer·word2vec
修炼地37 分钟前
代码随想录算法训练营第五十三天 | 卡码网97. 小明逛公园(Floyd 算法)、卡码网127. 骑士的攻击(A * 算法)、最短路算法总结、图论总结
c++·算法·图论