题目 3230: 蓝桥杯2024年第十五届省赛真题-星际旅行

题目 3230: 蓝桥杯2024年第十五届省赛真题-星际旅行

时间限制: 2s 内存限制: 512MB 提交: 1290 解决: 149

题目描述

小明国庆节准备去某星系进行星际旅行,这个星系里一共有 n 个星球,其中布置了 m 道双向传送门,第 i 道传送门可以连接 ai,bi 两颗星球(ai , bi 且任意两颗星球之间最多只有一个传送门)。

他看中了一款 "旅游盲盒",一共有 Q 个盲盒,第 i 个盲盒里的旅行方案规定了旅行的起始星球 xi 和最多可以使用传送门的次数 yi。只要从起始星球出发,使用传送门不超过规定次数能到达的所有星球都可以去旅行。

小明关心在每个方案中有多少个星球可以旅行到。小明只能在这些盲盒里随机选一个购买,他想知道能旅行到的不同星球的数量的期望是多少。

输入格式

输入共 m + Q + 1 行。

第一行为三个正整数 n,m,Q。

后面 m 行,每行两个正整数 ai,bi。

后面 Q 行,每行两个整数 xi,yi。

输出格式

输出共一行,一个浮点数(四舍五入保留两位小数)。

样例输入复制

3 2 3

1 2

2 3

2 1

2 0

1 1

样例输出复制

2.00

提示

【样例说明】

第一个盲盒可以旅行到 1, 2, 3。

第二个盲盒可以旅行到 2。

第三个盲盒可以旅行到 1, 2。

所以期望是 (3 + 1 + 2)/3 = 2.00。

【评测用例规模与约定】

对于 20% 的评测用例,保证 n ≤ 300。

对于 100% 的评测用例,保证 n ≤ 1000,m ≤ min{n(n−1)/2, 5n},Q ≤ 50000,0 ≤ yi ≤ n。

1.分析

这里用宽搜找到每个起点的距离,坑点在四舍五入保留2位小数。

2.代码

cpp 复制代码
#include<iostream>
#include<vector>
#include<algorithm>
#include<queue>
#include<cmath>
#include<cstring>
using namespace std;
const int MAX = 1010;
typedef long long LL;
int n, m, q;
int s, num,idx[MAX],dis[MAX][MAX], sum;
vector<int> v[MAX];
void bfs(int x) {
    memset(idx, 0, sizeof idx);
    idx[x] = 1;
    dis[x][x] = 0;
    queue<int> q;
    q.push(x);
    while (!q.empty()) {
        int t = q.front();
        q.pop();
        for (int i = 0; i < v[t].size(); i++) {
            int to = v[t][i];
            if (!idx[to]) {
                idx[to] = 1;
                q.push(to);
                dis[x][to] = dis[x][t] + 1;
            }
        }
    }
}
int main() {
    cin >> n >> m >> q;
    while (m--) {
        int x, y;
        cin >> x >> y;
        v[x].push_back(y);
        v[y].push_back(x);
    }
    memset(dis, 0x3f, sizeof dis);
    for (int i = 1; i <= n; i++) {
        bfs(i);
    }
    for (int k = 0; k < q;k++) {
        cin >> s >> num;
        for (int i = 1; i <= n; i++) {
            if (dis[s][i] <= num) {
                sum++;
            }
        }
    }
    double re = sum*1.0/ q;
    re = round(re * 100) / 100;
    printf("%.2f", re);
    return 0;
}
相关推荐
无敌昊哥战神25 分钟前
深入理解 C 语言:巧妙利用“0地址”手写 offsetof 宏与内存对齐机制
c语言·数据结构·算法
小白菜又菜32 分钟前
Leetcode 2075. Decode the Slanted Ciphertext
算法·leetcode·职场和发展
Proxy_ZZ01 小时前
用Matlab绘制BER曲线对比SPA与Min-Sum性能
人工智能·算法·机器学习
黎阳之光1 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
小李子呢02111 小时前
前端八股6---v-model双向绑定
前端·javascript·算法
前端大波2 小时前
前端面试通关包(2026版,完整版)
前端·面试·职场和发展
2301_822703202 小时前
Flutter 框架跨平台鸿蒙开发 - 创意声音合成器应用
算法·flutter·华为·harmonyos·鸿蒙
zhaoshuzhaoshu2 小时前
人工智能(AI)发展史:详细里程碑
人工智能·职场和发展
cmpxr_2 小时前
【C】数组名、函数名的特殊
c语言·算法
KAU的云实验台3 小时前
【算法精解】AIR期刊算法IAGWO:引入速度概念与逆多元二次权重,可应对高维/工程问题(附Matlab源码)
开发语言·算法·matlab