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

游戏怎么做充值网站简单公司网站

游戏怎么做充值网站,简单公司网站,建设公司的网站制作,南昌网站建设工作室交换瓶子 原题目链接 题目描述 有 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/wzjs/816971.html

相关文章:

  • 网站建设人员培训网站关键词提取工具
  • 营销型网站建设哪里有怎么做seo
  • 南通网站建设公司哪家好优秀企业
  • 网站脚本怎么做多语言 网站源码
  • 昆明网站制作计划淘宝客网站开发 猪八戒
  • 深圳博纳网站建设建筑公司企业使命和愿景大全
  • 北京房山网站建设开发公司网签补充合同
  • 建企业网站步骤深圳市建设工程质量检测中心官网
  • 深圳网站优化广东省城乡建设厅网站
  • 网站开发哪个工具网站建设公司的优势
  • 阜新网站建设单位网络推广的优化服务
  • app 展示网站wordpress主题阁
  • 云南网站建设效果好吗手机维护 Wordpress
  • vue.js和vs做网站比较河南省做网站的企业
  • 兴华建设集团有限公司网站建设网站需要的ftp资源
  • 建站大师阙梅娇简介番禺建设网站公司
  • 专业做网站优化排名wordpress添加自定义字段面板
  • 浙江网站建设费用wordpress编辑器可视化调用
  • 义安区住房和城乡建设局建网站微网官方网站
  • 建设项目竣工验收公示网站人工智能营销网站开发
  • 宁波市江东区地块建设网站wordpress域名修改
  • 怎么找网站站长专业开发小程序公司
  • xp系统中做网站服务器吗吉安建站公司
  • 咸阳网站建设方案研发网站建设报价
  • 网站建设一般预付比例多少专门做app的网站
  • wordpress淘口令插件网站seo设计方案案例
  • 做网站的市场前景seo技术培训教程视频
  • 专业制作网站费用网站使用条款模板
  • 网站联系我们页面设计汶上1500元网站建设
  • 怎样将自己做的网站发布到外网上备案域名购买腾讯云