C. Bertown Subway

题目解析

通过分析题目得到,车站之间回形成环。题目要求的是通过改变两个数p[i],使得车站到其他车站的可达数量最大化(便利最大化)。因为每一个i对应的pi值都是不同的,所以只能通过交换两个数来实现。

将车站到车站之间的路径可以构成环,环中的每个车站都可以到达其他的车站,若环的长度是a,则车站可达的数量为a的2次方

题目要求可达的数量最大化,则只需要让两个长度最大的环连接到一起即可。若这两个环的长度分别为a和b,则两个连接在一起形成的大环的可达数量(便利度)为(a + b)^ 2。

利用上述思路编写的代码如下:

cpp 复制代码
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
#define MAXN 100000 + 5
#define ll long long

int p[MAXN];//存储站信息
bool visited[MAXN];//用于判断当前站是否被访问了,避免重复访问环
int main()
{
    vector<ll> v;//存储所有环的长度
    int n;
    ll r = 0;//结果

    cin >> n;
    for(int i = 1; i <= n; i++)cin >> p[i];

    for(int i = 1; i <= n; i++)//i表示的是本站
    {
        if(visited[i] == true)continue;

        //利用后续的代码求环的长度,这一部分是最重要的
        ll cnt = 1;
        int x = p[i];//x是本站的目的站
        visited[x] = true;
        while(x != i)//如果说没有形成环继续执行
        {
            x = p[x];
            visited[x] = true;
            cnt++;//这个cnt是环的长度
        }

        v.push_back(cnt);//将这个环的长度放进数组中
    }
    sort(v.begin(), v.end());//从小到大进行排序
    if(v.size() >= 2)//其中有大于等于2的环数
    {
        r = v[v.size() - 2] + v[v.size() - 1];
        //现在r的值是最大的两个环长度之和
        r = r * r;//现在r的值是将两个环组合在一起的数对总和
        //(从一个站到另一个站的所有方式之和)
        for(int i = 0; i < v.size() - 2; i++)
        {
            r += v[i] * v[i];
        }
    }else//只有一个环,直接是长度的平方
    {
        r = v[0] * v[0];
    }
    cout << r;
    return 0;
}
相关推荐
生成论实验室8 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
风筝在晴天搁浅37 分钟前
字节高频题 小于n的最大数
算法
LabVIEW开发39 分钟前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星1 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅1 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
V搜xhliang02461 小时前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师2 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠2 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
WL_Aurora2 小时前
Python 算法基础篇之链表
python·算法·链表