UVA 10570 Meeting with Aliens

题意:

  N个外星人围成一桌坐下,有序的排列指N在N-1与N+1中间,现在给出一个序列,问至少交换几次可以得到有序的序列。

分析:

  复制一遍输入序列,放在原序列之后。相当于环。通过枚举,可以把最小交换次数求出来。正向枚举后,将序列反过来再来一次。

代码:

  

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <cmath>
using namespace std;
int v[1010];
int vis[1010];
int n;
int solve(int l,int r)
{
memset(vis,0,sizeof(vis));
int cnt=0;
for(int i=l;i<=r;i++)
{
if(vis[i]==1)
continue;
cnt++;
int start=i,now=v[i]+l-1;
while(now!=start)
{
vis[now]=1;
now=v[now]+l-1;
}
}
return n-cnt;
}
int main()
{
while(scanf("%d",&n)&&n)
{
int i;
for(i=0;i<n;i++)
{
scanf("%d",&v[i]);
v[i+n]=v[i];
}
int ans=10000000;
for(i=0;i<n;i++)
ans=min(ans,solve(i,i+n-1));
reverse(v,v+n);
for(i=0;i<n;i++)
v[i+n]=v[i];
for(i=0;i<n;i++)
ans=min(ans,solve(i,i+n-1));
printf("%d\n",ans);
}
}

转载于:https://www.cnblogs.com/137033036-wjl/p/4929372.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/459590.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【转】Android 4.3源码的下载和编译环境的安装及编译

原文网址&#xff1a;http://jingyan.baidu.com/article/c85b7a641200e0003bac95a3.html 告诉windows用户一个不好的消息&#xff0c;windows环境下没法编译android源码。用cygwin&#xff1f;不行&#xff0c;因为cygwin模拟的环境太简单&#xff0c;编译android源码需要好多工…

android关机分区卸载,Android关机重启流程(二)

一、回顾先回顾下上部分得分析&#xff0c;从最开始的PM.reboot()&#xff0c;经过层层调用&#xff0c;最终调用SystemProperties.set(“sys.powerctl”, “reboot,” reason);二、重启流程aosp/system/core/init/property_service.cppaosp/system/core/init/reboot.cppaosp/…

每天一道算法题(39)——含有重复字符的全排列

思路 (1)对于含有重复字符的全排列必须使用isSwap函数 (2)整体思路 a,交换当前子字符串(i----n-1)字符与子字符串后面的每一个位置的字符&#xff08;满足交换条件下&#xff09; b,子字符串位置后移(i1-----n)。递归处理子字符串 c,将a中的交换复原。 代码 #in…

android 初始化语言,Android Init Language(安卓初始化语言)

android源码学习目录了解Android init进程的都知道&#xff0c;启动 init进程之前会解析init.rc文件&#xff0c;init.rc是Android的配置文件脚本&#xff0c;它由一种被称为"Android初始化语言"--Android init Language 编写。1. android init language(简称 AIL)组…

使用JetBrains dotMemory 4.0分析内存

安装下载地址&#xff1a;http://www.jetbrains.com/profiler/ 1.在本地启动web应用后&#xff0c;打开dotMemory,附加进程 2.附加后会看到集中颜色得粗条&#xff0c;不断往左边走动&#xff0c;这是内存运行情况&#xff0c; 3.Get snapshot,抓取两次快照&#xff0c;等自动信…

AutoHomeRefreshListView仿汽车之家下拉刷新 《IT蓝豹》

2019独角兽企业重金招聘Python工程师标准>>> AutoHomeRefreshListView仿汽车之家下拉刷新 AutoHomeRefreshListView 高仿汽车之家下拉刷新 &#xff0c;下拉的时候出现很不错的效果。本项目来自&#xff1a;https://github.com/nugongshou110/AutoHomeRefreshListVi…

html字体整体偏移,CSS自定义字体垂直偏移(错误?)

ScottS..5你可能没有做错任何事情.以下是一些可能适用的要点,有些可以由您控制,有些则不可以.只是为了确定,明确设置vertical-align: baseline.不同的文件(.eof,.woff,.ttf)本身可以不定义是相同的,并且因此不同的浏览器使用不同的文件并显示差异.不确定是否有两个src电话搞乱了…

随笔1

过来这几天身体一直不舒服&#xff0c;一直没有调整过来。转载于:https://www.cnblogs.com/zzyoucan/p/4314644.html

android pss内存,如何释放android系统中pss cache住的内存

通过dumpsys meminfo可以统计查看到android各进程内存使用情况&#xff1a;Total RAM: 463136 kBFree RAM: 170277 kB (48221 cached pss 68780 cached 53276 free)Used RAM: 173253 kB (152085 used pss 3160 buffers 176 shmem 17832 slab)Lost RAM: 119606 kBZRAM: 216…

排序第一天,回忆关键字

选择&#xff0c;插入&#xff0c;希尔&#xff0c;归并&#xff0c;快排&#xff08;包括三向快排&#xff09;&#xff0c;堆排序。 选择&#xff1a; 实现原理&#xff1a;内外循环&#xff0c;选择最小&#xff0c;比较。 关键点&#xff1a;for&#xff08;k i1 ,k<N,k…

android 软件盘弹回去的最好体验,Android 软键盘弹出 日常填坑

开发输入框的开发者都会遇到一个问题&#xff0c;那就是在登录界面时&#xff0c;当你点击输入框时&#xff0c;下边的按钮有时会被输入框挡住&#xff0c;这个不利于用户的体验&#xff0c;所以很多人希望软键盘弹出时&#xff0c;也能把按钮挤上去。这样的交互更人性化&#…

Java JVM、JNI、Native Function Interface、Create New Process Native Function API Analysis

目录 1. JAVA JVM 2. Java JNI: Java Native Interface 3. Java Create New Process Native Function API Analysis In Linux 4. Java Create New Process Native Function API Analysis In Windows 1. JAVA JVM 0x1: JVM架构简介 JVM是Java Virtual Machine(Java虚拟机)的缩写…

php 输入汉字自动带出拼音和英文

需求就是添加一个字段的时候&#xff0c;自动带出中文和英文&#xff0c;方便数据索引。这里只贴下代码&#xff0c;英文用在线api&#xff0c;中文用类库。我觉得这个拼音类库比较好&#xff0c;不会出现重庆是zhongqing之类的问题&#xff0c;因为可以自定义添加维护。 要说明…

小android模拟器,小姚Android模拟器工作室版本v6.2.7.0正式版

逍遥Android Emulator Studio Edition是高质量的Android模拟器. 此版本是特殊版本&#xff0c;支持无限的多打开&#xff0c;智能管理和组控制模式. 它是专门为需要商业营销的用户设计的. Xiaoyao Android Emulator Studio Edition具有强大的引擎和良好的兼容性全能营销王 安卓…

判断 iframe 是否加载完成的完美方法(转)

般来说&#xff0c;我们判断 iframe 是否加载完成其实与 判断 JavaScript 文件是否加载完成 采用的方法很类似&#xff1a; var iframe document.createElement("iframe"); iframe.src "http://www.planabc.net"; if (!/*cc_on!*/0) { //if not IE if…

【原创】注意析构函数的使用

清单&#xff1a;虚析构函数使用 1 class X { 2 public: 3 virtual ~X() default; // 编译器自动生成 defaulted 函数定义体4 private: 5 int x; 6 }; 7 class Y: public X { 8 private: 9 int y; 10 }; 11 int main(){ 12 X* x new Y; 13 delete x; 清单…

html5调用手机摄像头和相册,h5 调用手机摄像头/相册

html 部分js 部分getBase64: function (file, callback) {var maxWidth 640if (file.files && file.files[0]) {var thisFile file.files[0]// if (thisFile.size > 524288) {// this.showToast("图片不能超过512k&#xff01;");// return;// }var…

hadoop中实现定制Writable类

Hadoop中有一套Writable实现可以满足大部分需求&#xff0c;但是在有些情况下&#xff0c;我们需要根据自己的需要构造一个新的实现&#xff0c;有了定制的Writable&#xff0c;我们就可以完全控制二进制表示和排序顺序。 为了演示如何新建一个定制的writable类型&#xff0c;我…

html5carousel图片轮播,jQuery响应式轮播图插件VM Carousel

插件描述&#xff1a;VM Carousel是一款jQuery响应式轮播图插件。该jquery轮播图插件支持自动播放模式&#xff0c;支持动态改变图片尺寸&#xff0c;支持居中模式&#xff0c;以及无限循环等。使用方法在页面中引入jquery.vm-carousel.css&#xff0c;jquery和jquery.vm-carou…

tableview或scrollview Y轴发生变化解决方案

在viewDidLoad中加入 self.automaticallyAdjustsScrollViewInsets NO; 转载于:https://www.cnblogs.com/mo-shou/p/4335163.html