城市 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

这道题真没想到会超时呢

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n;
  4. int a[];
  5. bool flag[];
  6. int xfindy(int x,int y,int depth){//返回走的步数
  7. if(depth>n) return -;//边界
  8. if(flag[]) flag[x]=;//标记服务
  9. if(x==y&&depth!=) return depth;//成功条件
  10. else return xfindy(a[x],y,depth+);//继续找
  11. }
  12. int count(int start){
  13. return xfindy(start,start,);
  14. }
  15. int main(){
  16. freopen("city.in","r",stdin);
  17. freopen("city.out","w",stdout);
  18. cin>>n;
  19. for(int i=;i<=n;i++)
  20. {
  21. cin>>a[i];
  22.  
  23. }
  24. //特判:完美的环
  25. if(count(n-)==n) {cout<<n*n; return ;}
  26. //把两个最大的环合并
  27. // for(int i=1;i<=n;i++){
  28. //如果a[i],a[j]在不同的环内,且
  29. // for(int j=1;j<=n;j++)
  30. // }
  31. long long ans=,max1=-0x3f3f3f,max2=max1,city1=-,city2=-;
  32. for(int i=;i<=n;i++)
  33. {
  34. int huani=count(i);
  35. if(huani>max1) {
  36. max1=huani;
  37. city1=i;
  38. }
  39. }
  40. for(int i=;i<=n;i++)
  41. {
  42. if(xfindy(i,city1,)!=-) continue;
  43. int huani=count(i);
  44. if(huani>max2) {
  45. max2=huani;
  46. city2=i;
  47. }
  48. }
  49. memset(flag,,sizeof(flag));
  50. flag[]=;
  51. for(int i=;i<=n;i++){
  52. //如果从i出发,找不到那两个最大环中的城市,ans+=count(i)^2
  53. if(flag[i]) continue;
  54. if(xfindy(i,city1,)==-&&xfindy(i,city2,)==-) ans+=pow(count(i),);
  55. //如果找的到,说明i在两个最大环内,下一个循环再看
  56. }
  57. ans+=pow(max1+max2,);
  58. cout<<ans;
  59. return ;
  60. }

把互相连着的城市分开一条边,而形成一个环

连通性问题?

如果形成了一个完整的环,那么ans=n^2

如果没有呢?

如果两步之内,不能够形成完美的环呢?

两步,可以把两个环合并!

优先把本身环大的city指向另一个有大环的city,而不是指向少数city围成的环

检测有没有指向自己的环

再检测环city小的环

嵊州D6T2 城市 city的更多相关文章

  1. 建设城市(city):组合数,容斥原理

    想模一大堆人呢.考场上AC的大仙. 估计没人想给这题好好写一个题解吧,因为它的确挺简单的... 但是它对我来说一点都不简单啊!!! 至少出题人用脚写题解的时候肯定认为这道题是送分题了 容斥,枚举至少有 ...

  2. NOIP模拟测试15「建造城市city(插板法)·轰炸·石头剪刀布」

    建造城市 题解 先思考一个简单问题 10个$toot$ 放进5间房屋,每个房屋至少有1个$toot$,方案数 思考:插板法,$10$个$toot$有$9$个缝隙,$5$间房屋转化为$4$个挡板,放在t ...

  3. XML:使用DOM技术解析xML文件中的城市,实现select级联选择

    中国的城市xml格式:cities.xml <?xml version="1.0" encoding="utf-8"?> <china> ...

  4. 微信小程序实现按首字母检索城市列表

    不说废话,上效果图 因为我有多处要用到,所以我这里是写成自定义组件的,你也可以直接改成在page页面编写: 布局左边一个scroll-view,显示城市列表,右边一个view显示字母列表,城市列表这边 ...

  5. Python-定时爬取指定城市天气(二)-邮件提醒

    目录 一.概述 二.模块重新划分 三.优化定时任务 四.发送邮件 五.源代码 一.概述 上一篇文章python-定时爬取指定城市天气(一)-发送给关心的微信好友中我们讲述了怎么定时爬取城市天气,并发送 ...

  6. YII+DWZ三级城市联动挂件

    挂件PHP文件 class CountryCityCombox extends RXWidget { public $provinceId = 2; public $cityId = 3687; pu ...

  7. IOS UIPickView+sqlite 选择中国全部城市案例

    1.案例简单介绍 通过读取文件.将中国全部城市写入sqlite数据库中,现通过UIPickView实现中国全部城市的选择,效果图例如以下所看到的 2.城市对象模型 中国全部城市数据请看http://b ...

  8. 省份-城市-区域三级联动【struts2 + ajax +非数据库版】

    package loaderman; /** * 实体,封装省份和城市 */ public class Bean { private String province;//省份 private Stri ...

  9. Vue 通过调用百度API获取地理位置-经度纬度省份城市

    一.首先在百度api注册获得ak密钥 二.新建js文件,我命名为loadBMap.js,里面创建script,代码如下: /** * 加载地图 * @param {Function} callback ...

随机推荐

  1. 用EFCore的 FluentAPI 方式生成MySql 带注释的数据库表结构

    采用的是net Core 3.1框架下的 的WebAPI项目. 1.  创建ASP.NET Core Web项目  2. 添加NuGet引用包,包如下 Microsoft.EntityFramewor ...

  2. 2020-02-19Linux学习日记,第一天

    今天是2020-02-19第一次写博客.每天更新学习Linux的一些笔记. 主要是为了方便日后自己复习,也是为了督促自己学习.记录自己的学习轨迹! -------------------------- ...

  3. 基于CentOS-7 部署open

    一.OpenVPN概述 OpenVPN是一个用于创建专用网络加密通道的源软件.可在公司和家庭之间.部署类似于局域网的专用网络通道 而且OpenVPN使用起来也非常方便.几乎可以运行在任何平台.同时也采 ...

  4. 深入了解MySQL,一篇简短的总结

    MySQL的基本语法 这里作为MySQL部分模块的深入了解,大部分都是理论方面的笔记,不会写具体用法. 具体用法会记录在下面这个随笔分类下,不过暂时还没更新完,等过段时间会更新下事务.存储过程.索引等 ...

  5. python学习Day27--time模块、sys模块、os模块和序列化模块

    [知识点] 1.时间模块: (1)时间戳时间,格林威治时间,float数据类型 英国伦敦的时间:1970.1.1     0:0:0 北京时间:1970.1.1     8:0:0 (2)结构化时间, ...

  6. NR / 5G - MAC Overview

  7. Linux的那些事-系统启动(增加开机启动项)

    1   /etc/init.d 2   /etc/inittab 3   /etc/rc.d/init.d  1.   /etc/init.d 是一般开机的启动服务存放在这个目录下,至于实现机制,其实 ...

  8. Solr系列2-Solr服务安装

    1: Solr简介 1.1 简介: 1.2 下载: 2:Solr 安装 2.1 安装 2.2 目录结构 3 :启动Solr 3.1 启动 3.2使用Solr提供的测试数据 3.5 Solr配置文集 3 ...

  9. 本地与github建立连接,本地代码上传到github

    1,已有github账号 2,本地已经安装git 3,本地创建ssh-key 在git bash中输入后直接回车. $ ssh-keygen -t rsa -C "your_email@yo ...

  10. (四)开源C# WPF控件库《AduSkin – UI》

    微信公众号:[Dotnet9的博客],网站:[Dotnet9],问题或建议:[请网站留言], 如果对您有所帮助:[欢迎赞赏]. 开源C# WPF控件库系列: (一)开源C# WPF控件库<Mat ...