当前位置: 首页 > 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/110994.html

相关文章:

  • 怎么在百度上做网站推广网站流量查询站长之家
  • 网站服务器租用4t多少钱一年啊知乎长沙网络营销顾问
  • 怎么做阿里国际网站的数据分析淘宝关键词搜索量排名
  • 金牌网站设计网站建设惠州seo关键字排名
  • wordpress设置静态页seo搜索引擎优化业务
  • 设计个网站多少钱百度搜索浏览器
  • wordpress+禁用feed免费培训seo网站
  • 老网站改版seo简单优化
  • 乌兰浩特网站制作信息流广告优化
  • 武汉企业建站公司可以搜任何网站的浏览器
  • 阿里云建站视频教程百度在线使用网页版
  • wordpress上传音频 http错误天津seo诊断技术
  • 网站建设团队管理模板推广费用一般多少钱
  • 手机版商城网站都有哪 些功能想卖产品怎么推广宣传
  • 如何修改网站联系人seo优化神器
  • 一级a做爰片就在线手机看韩国网站灰色关键词排名优化
  • 做外贸阿里巴巴有哪些网站关联词有哪些关系
  • 深圳做商城网站建设知名的建站公司
  • 济南做网站建设免费创建自己的网站
  • 个人做网站要缴税网络新闻发布平台
  • 做网站wordpress大连企业网站建站模板
  • 网站管理员登陆不了百度推广获客方法
  • 佛山南海网站开发软文广告有哪些
  • 广州建网站加备案软文推广服务
  • Wordpress主题禁用水平滚动seo简单优化
  • 南京做网站优化的公司小程序开发平台官网
  • 进口跨境电商网站制作自己的产品怎么推广
  • 美食网站 怎么做成都seo的方法
  • 开发app的资金需求如何做好搜索引擎优化工作
  • 网站网页设计多少钱5118关键词查询工具