25.2.9总结

(思维题还是太超标了,建议削一削)

a,b为t在s中左上角坐标,一一对比即可(大胆点数据量比较小,直接四层循环也能做,但是我是胆小鬼)

cpp 复制代码
#include<iostream>
using namespace std;
char a[10000][10000];
char b[10000][10000];
int n, m;
void find(int i, int j) {
    for (int p = 1; p <= m; p++) {
        for (int q= 1; q <= m; q++) {
            if (a[i + p - 1][j + q - 1] != b[p][q])           
            return;
        }
    }
    cout << i << " " << j;
    return;
}
int main() {
    cin >> n >> m;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= n; j++) {
            cin >> a[i][j];
        }
    }
    for (int i = 1; i <= m; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> b[i][j];
        }
    }
    for (int i = 1; i <= n-m+1; i++) {
        for (int j = 1; j <= n-m+1; j++) {
            if (a[i][j] == b[1][1])find(i, j);
        }
    }
    return 0;
}

(不会,学长的思路)

把有朋友关系的人连上边,一个连通块内的所有人都可以通过若干次操作来互相成为朋友。求出每个连通块的大小,人数和已有的朋友关系,就可以求出连通块内未有的朋友关系,也就是答案。这个过程可以用并查集维护

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
int n, m;
const int pp = 100000;
int sz[pp], lsz[pp], f[pp];
bool vis[pp];
long long ans = 0;
int find(int x) {
    if (x == f[x]) return x;
    return f[x] = find(f[x]);
}
int main() {
    for (int i = 0; i < pp; i++) {
        sz[i] = 0;
        lsz[i] = 1;
        f[i] = i;
    }
    cin >> n >> m;
    for (int i = 1; i <= m; i++) {
        int x, y;
        cin >> x >> y;
        int xx = find(x);
        int yy = find(y);
        if (xx == yy) {
            sz[xx]++;
        }
        else {
            f[xx] = yy;
            lsz[yy] += lsz[xx];
            sz[yy] = sz[yy] + sz[xx] + 1;
        }
    }
    for (int i = 1; i <= n; i++) {
        int fx = find(i);
        if (vis[fx]) continue;
        vis[fx] = true;
        ans += (long long)lsz[fx] * (lsz[fx] - 1) / 2 - sz[fx];
    }
    cout << ans;
    return 0;
}

(ok准备下播)

相关推荐
方传旺14 分钟前
C++17 std::optional 深拷贝 vs 引用:unordered_map 查询大对象性能对比
c++
Dontla29 分钟前
Makefile介绍(Makefile教程)(C/C++编译构建、自动化构建工具)
c语言·c++·自动化
Xの哲學34 分钟前
Perf使用详解
linux·网络·网络协议·算法·架构
奶黄小甜包39 分钟前
C语言零基础第18讲:自定义类型—结构体
c语言·数据结构·笔记·学习
想不明白的过度思考者44 分钟前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法
小七rrrrr1 小时前
动态规划法 - 53. 最大子数组和
java·算法·动态规划
code小毛孩1 小时前
leetcodehot100 矩阵置零
算法
一支闲人1 小时前
C语言相关简单数据结构:双向链表
c语言·数据结构·链表·基础知识·适用于新手小白
何妨重温wdys1 小时前
矩阵链相乘的最少乘法次数(动态规划解法)
c++·算法·矩阵·动态规划
重启的码农1 小时前
ggml 介绍 (6) 后端 (ggml_backend)
c++·人工智能·神经网络