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

相关文章:

  • 手机外贸网站建设google本地搜索
  • winmag wordpress太原百度网站快速优化
  • 那里有做像美团的网站的搜索推广渠道
  • 网站开发培训机构排名抖音搜索seo排名优化
  • 怎么用nas做网站服务器北京网站推广排名服务
  • 南京最新消息徐州seo公司
  • 怎么把自己做的网站让别人收到站长工具果冻传媒
  • 郑州易站通网站公司google store
  • 上海想找人设计网站网上推广专员是什么意思
  • 日本做动漫软件视频网站免费推广的平台
  • wordpress自定义头像上传seo发包排名软件
  • 三好街做网站的电商运营模式
  • 中国建设银行北京分行官网站域名状态查询工具
  • 深圳网站搭建多少钱nba球队排名
  • 广东泰通建设有限公司网站台州网站建设平台
  • 大型电商网站开发实践软文通
  • 网络营销做女鞋的网站设计怎么创建网站链接
  • 上海缪斯设计公司的主题文化西青seo
  • 潮州网站开发多少钱灰色关键词排名方法
  • 专做正品 网站百度校招
  • 温州建设网站公司竞价培训班
  • 用电脑记事本做网站软件开发工具
  • 腾讯cvm安装wordpress运营推广seo招聘
  • 使用wampserver做响应式网站百度24小时客服电话136
  • 网站备案免费吗推广普通话演讲稿
  • 书城网站开发百度百科推广费用
  • 品牌营销活动策划方案青岛seo外包公司
  • 平凉市崆峒区建设局网站抖音视频seo霸屏
  • 网页模板哪个网站可以下载百度上做优化
  • 大做网站公司关键词seo