当前位置: 首页 > news >正文

经验丰富的网站制作公司申请网站的域名

经验丰富的网站制作公司,申请网站的域名,设计网站企业网站建设公司,群晖 wordpress 阿里云交换瓶子 原题目链接 题目描述 有 N 个瓶子,编号为 1 ~ N,放在架子上。 例如有 5 个瓶子,当前排列为: 2 1 3 5 4每次可以拿起 2 个瓶子,交换它们的位置。 要求通过若干次交换,使得瓶子的编号从小到大…

交换瓶子

原题目链接

题目描述

N 个瓶子,编号为 1 ~ N,放在架子上。

例如有 5 个瓶子,当前排列为:

2 1 3 5 4

每次可以拿起 2 个瓶子,交换它们的位置

要求通过若干次交换,使得瓶子的编号从小到大排列为:

1 2 3 4 5

对于简单情况,显然至少需要交换 2 次就能复位。

如果瓶子更多呢?请你编程解决这个问题,找出最少交换次数


输入描述

输入格式为两行:

  • 第一行:一个正整数 N (N < 10⁴),表示瓶子的数目;
  • 第二行:N 个正整数,空格分隔,表示当前瓶子的排列情况。

输出描述

输出一行一个正整数,表示至少交换多少次,才能完成排序。


输入输出样例

示例

输入

5
3 1 2 5 4

输出

3

c++代码

#include<bits/stdc++.h>using namespace std;int N, ans = 0;int main() {cin >> N;vector<int> root(N);for (int i = 0; i < N; i++) cin >> root[i];for (int i = 0; i < N; i++) {while(root[i] != i + 1) {swap(root[i], root[root[i] - 1]);ans++;}}cout << ans;return 0;
}//by wqs

题目解析

贪心算法

我们假设当前的值不对应

说明我们一定要交换

我们要交换次数最小,就要这次交换的利益最大。

如果我们交换一次刚好和可以让两个数同时对应,这样利益最大,贪心的做法也就是和对应值交换

为什么呢,因为这样既可以保证至少有一个可以对应,还有机会可以对应两个。

例如

3 1 2 5 4

1 2 3 4 5

3和1不同,第一个和第三个交换,至少3对应了。

2 1 3 5 4

1 2 3 4 5

2 1 不同,第二个和第一个交换,1和2都对应了。

1 2 3 5 4

1 2 3 4 5

http://www.dtcms.com/a/613055.html

相关文章:

  • 英文站 wordpress seo优化做企业平台的网站
  • 服装设计参考网站建站宝盒里的手机网站
  • 网站建设的关键词电子商务网站建设产品
  • 不关网站备案潍坊mip网站建设
  • seo怎么做自己的网站wordpress 主题 zuopin
  • 中卫市建设局网站买什么样的主机(用来建网站的)支持下载
  • 做企业网站建设公司哪家好网站怎么绑定织梦
  • 宠物医疗设计素材网站网站开发实训报告模板
  • 沈阳个人网站建设选择国内时事新闻
  • cdn网站网络加速器闵行区属于浦东还是浦西
  • 建立网站的服务器最牛餐饮营销手段
  • 可信赖的企业网站开发无锡所有网站设计制作
  • 开封建设局网站深圳创业补贴政策2021申请条件
  • 免费视频网站大全织梦品牌集团公司网站模板(精)
  • 爱站网备案查询长春建站软件
  • 网络平台怎么建立网站吗中山的网站建设公司
  • 网站建设人员工作计划网络安全软件有哪些
  • 怎么登陆建设u盾网站wordpress怎么使用
  • 常州网站建设案例网站运营工作计划
  • gate网站合约怎么做空成都六度网站建设
  • 永康网站定制什么是自适应网站
  • 网站权重怎么做新都区网站建设
  • 常熟做网站哪家好网站视觉元素
  • 鞍山公司做网站大淘客网站免费空间
  • 阿里云手机网站建设宜昌网站设计
  • 淮北市网站建设本地建wordpress
  • 网站js代码不显示潍坊注册公司流程和费用标准
  • 搜狐网站开发网站建设技术团队经验丰富
  • 桓台网站淮南网站建设服务
  • 做网站申请域名大概花费多少网站备案 取消