嵊州D6T2 城市 city
城市 city
【问题描述】
众所周知,why 是czyz 王国的国王。
czyz 王国一共有n 个城市,每个城市都有一条道路连向一个城市(可能连向这个城市自己)。
同时,对于每一个城市,也只有一条道路连向它。
如果一个人可以通过道路可以从城市x 走向城市y,那么我们称(x,y) 这
个数对是满足条件的。(x 可以等于y)
现在why 可以选择2 个城市改变他们连向的道路,且改变完成之后也要满足上述的条件。
why 想知道,经过这个操作后,最多能有多少满足条件的数对。
【输入格式】
第一行包括一个整数n, 表示城市数。
第二行包括n 个整数a[i],表示i 有一条道路连向a[i]。
【输出格式】
输出一行一个整数,表示最多能得到多少满足条件的数对。
【输入输出样例】
| Input1 | Input2 |
|
3 2 1 3 |
5 1 5 4 3 2 |
| Output1 | Output2 |
| 9 | 17 |
【样例解释】
对于样例1,不需要改变,每两个城市之间可以相互到达,ans=3*3=9。
对于样例2,change a[2] to 4, a[3] to 5。
【数据范围】
对于20% 的数据满足:n ≤ 10。
对于50% 的数据满足:n ≤ 100。
对于70% 的数据满足:n ≤ 1000。
对于100% 的数据满足:n ≤ 10^6, 1 ≤ a[i] ≤ n。
Solution
这道题真没想到会超时呢
#include<bits/stdc++.h>
using namespace std;
int n;
int a[];
bool flag[];
int xfindy(int x,int y,int depth){//返回走的步数
if(depth>n) return -;//边界
if(flag[]) flag[x]=;//标记服务
if(x==y&&depth!=) return depth;//成功条件
else return xfindy(a[x],y,depth+);//继续找
}
int count(int start){
return xfindy(start,start,);
}
int main(){
freopen("city.in","r",stdin);
freopen("city.out","w",stdout);
cin>>n;
for(int i=;i<=n;i++)
{
cin>>a[i]; }
//特判:完美的环
if(count(n-)==n) {cout<<n*n; return ;}
//把两个最大的环合并
// for(int i=1;i<=n;i++){
//如果a[i],a[j]在不同的环内,且
// for(int j=1;j<=n;j++)
// }
long long ans=,max1=-0x3f3f3f,max2=max1,city1=-,city2=-;
for(int i=;i<=n;i++)
{
int huani=count(i);
if(huani>max1) {
max1=huani;
city1=i;
}
}
for(int i=;i<=n;i++)
{
if(xfindy(i,city1,)!=-) continue;
int huani=count(i);
if(huani>max2) {
max2=huani;
city2=i;
}
}
memset(flag,,sizeof(flag));
flag[]=;
for(int i=;i<=n;i++){
//如果从i出发,找不到那两个最大环中的城市,ans+=count(i)^2
if(flag[i]) continue;
if(xfindy(i,city1,)==-&&xfindy(i,city2,)==-) ans+=pow(count(i),);
//如果找的到,说明i在两个最大环内,下一个循环再看
}
ans+=pow(max1+max2,);
cout<<ans;
return ;
}
把互相连着的城市分开一条边,而形成一个环
连通性问题?
如果形成了一个完整的环,那么ans=n^2
如果没有呢?
如果两步之内,不能够形成完美的环呢?
两步,可以把两个环合并!
优先把本身环大的city指向另一个有大环的city,而不是指向少数city围成的环
检测有没有指向自己的环
再检测环city小的环
嵊州D6T2 城市 city的更多相关文章
- 建设城市(city):组合数,容斥原理
想模一大堆人呢.考场上AC的大仙. 估计没人想给这题好好写一个题解吧,因为它的确挺简单的... 但是它对我来说一点都不简单啊!!! 至少出题人用脚写题解的时候肯定认为这道题是送分题了 容斥,枚举至少有 ...
- NOIP模拟测试15「建造城市city(插板法)·轰炸·石头剪刀布」
建造城市 题解 先思考一个简单问题 10个$toot$ 放进5间房屋,每个房屋至少有1个$toot$,方案数 思考:插板法,$10$个$toot$有$9$个缝隙,$5$间房屋转化为$4$个挡板,放在t ...
- XML:使用DOM技术解析xML文件中的城市,实现select级联选择
中国的城市xml格式:cities.xml <?xml version="1.0" encoding="utf-8"?> <china> ...
- 微信小程序实现按首字母检索城市列表
不说废话,上效果图 因为我有多处要用到,所以我这里是写成自定义组件的,你也可以直接改成在page页面编写: 布局左边一个scroll-view,显示城市列表,右边一个view显示字母列表,城市列表这边 ...
- Python-定时爬取指定城市天气(二)-邮件提醒
目录 一.概述 二.模块重新划分 三.优化定时任务 四.发送邮件 五.源代码 一.概述 上一篇文章python-定时爬取指定城市天气(一)-发送给关心的微信好友中我们讲述了怎么定时爬取城市天气,并发送 ...
- YII+DWZ三级城市联动挂件
挂件PHP文件 class CountryCityCombox extends RXWidget { public $provinceId = 2; public $cityId = 3687; pu ...
- IOS UIPickView+sqlite 选择中国全部城市案例
1.案例简单介绍 通过读取文件.将中国全部城市写入sqlite数据库中,现通过UIPickView实现中国全部城市的选择,效果图例如以下所看到的 2.城市对象模型 中国全部城市数据请看http://b ...
- 省份-城市-区域三级联动【struts2 + ajax +非数据库版】
package loaderman; /** * 实体,封装省份和城市 */ public class Bean { private String province;//省份 private Stri ...
- Vue 通过调用百度API获取地理位置-经度纬度省份城市
一.首先在百度api注册获得ak密钥 二.新建js文件,我命名为loadBMap.js,里面创建script,代码如下: /** * 加载地图 * @param {Function} callback ...
随机推荐
- 自定义属性的访问 - Customizing attribute access
自定义属性的访问 - Customizing attribute access 在 python 中, 下列方法可以实现类实例属性 instance.attribute 的 使用,设置,删除. obj ...
- Python编程:从入门到实践——【作业】——第六章(字典)
第六章作业 6-1 人 : 使用一个字典来存储一个熟人的信息, 包括名. 姓. 年龄和居住的城市. 该字典应包含键first_name . last_name . age 和city . 将存储在该字 ...
- redis系列-开篇
0x0 缘起 笔者所在的公司有一款大DAU(日活)的休闲游戏.这款游戏的后端架构很简单,可以简单理解为通讯-逻辑-存储三层结构.其中存储层大量使用了redis和mysql. 虽然存量用户的增加,red ...
- CVE-2020-0668-Windows服务跟踪中的普通特权升级错误
CVE-2020-0668-Windows服务跟踪中的普通特权升级错误 在这里中,我将讨论在Windows Service跟踪中发现的任意文件移动漏洞.从我的测试来看,它影响了从Vista到10的所有 ...
- Java的开发—面向对象的7大原则之开闭原则(一)
开闭原则(Open Close Principle) 一.定义: 软件中的(类.模块.函数等等)应该对于扩展是开放的,对于修改时关闭的.意味着一个实体允许在不改变它的源代码的前提变更它的行为 这里的软 ...
- SQL Server 2019 安装教程
SQL Server 2019 安装教程 下载安装SQL: 1.下载SQL Server 2019 Developer 官方网址:下载地址. 2.下拉选择免费版本,直接点击下载(别问,问就是家境贫寒
- Android事件分发与责任链模式
一.责任链模式 责任链模式是一种行为模式,为请求创建一个接收者的对象链.这样就避免,一个请求链接多个接收者的情况.进行外部解耦.类似于单向链表结构. 优点: 1. 降低耦合度.它将请求的发送者和接收者 ...
- 传智播客C++视频学习笔记(3)
#include<iostream> using namespace std; //内存分区模型 //代码区,存放二进制代码,由操作系统进行管理 //全局区,存放全局变量.静态变量.常量( ...
- pyinstaller打包报错: RecursionError: maximum recursion depth exceeded 已经解决
看上去似乎是某个库自己递归遍历超过了python的栈高度限制 搜索了一番,很快找到了解决办法: https://stackoverflow.com/questions/38977929/pyinsta ...
- #《Essential C++》读书笔记# 第六章 以template进行编程
练习题答案 练习6.1 试改写以下类,使它成为一个class template: class example { public: example(double min, double max); ex ...