博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
平安夜杀手 (科大讯飞笔试题)
阅读量:4047 次
发布时间:2019-05-25

本文共 888 字,大约阅读时间需要 2 分钟。

描述

有n个杀手排成一行,每个杀手都有一个不同的编号(编号为1-n),在每个夜晚,杀手都会行动,如果某个杀手编号大于他右边的杀手的编号,他就会杀死他右边的杀手,杀手是的行动是瞬间的,因此一个人可能某一个夜晚既杀死了别人又被别人杀死,例如3,2,1这个顺序,在第一个夜晚2会杀死1,同时3也会杀死2。

显而易见,一段时间之后,就不会有人杀或被杀,平安夜也就到来了,请问在平安夜之前有多少个夜晚。

输入

输入第一行是一个整数n(1≤n≤100000),表示杀手的数量。

接下来一行有n个数,是一个1-n的全排列。

输出

输出包含一个整数,表示平安夜之前经历了多少个夜晚。

输入样例 1 

10

10 9 7 8 6 5 3 4 2 1

输出样例 1

2

输入样例 2 

6

1 2 3 4 5 6

输出样例 2

0                                                                                                                                                                                                  

题意:

在每个夜晚,杀手都会行动,如果某个杀手编号大于他右边的杀手的编号,他就会杀死他右边的杀手。

这说明如果n个数不是从小到大排序的,那么就会有人死亡。

所以不断地从右向左遍历这n个数,如果右边的数小于左边的数,那么删掉右边的数,直到这些数的顺序是从小到大排列的为止。

每次遍历完,都记录此时还剩下的个数,直到此时的个数与上次遍历完的个数相同,就停止遍历,已经满足条件,然后输出共遍历了多少次即可。

实现代码:

import java.util.ArrayList;import java.util.List;import java.util.Scanner;public class Main {	public static void main(String[] args) {		Scanner in=new Scanner(System.in);		int n=in.nextInt();		List
list=new ArrayList
(); for(int i=0;i
1) { for(int i=list.size()-1;i>=1;i--) { if(list.get(i)

 

转载地址:http://vszci.baihongyu.com/

你可能感兴趣的文章
poj 1860 Currency Exchange 3259 Wormholes bellman 判环
查看>>
poj 1062 昂贵的聘礼 最短路bellman
查看>>
linux环境变量(转载)
查看>>
C语言中strlen与sizeof的区别(`$~新年快乐~$`!)
查看>>
struct msghdr与struct iovec
查看>>
编译和解释的区别是什么?
查看>>
unpv1 Makefile 文件 简略分析
查看>>
linux网络编程 UDP聊天程序 包括群聊和私聊
查看>>
linux 网络编程 Tcp文件服务器
查看>>
有关send() / recv()函数的理解
查看>>
ping在类unix下的实现
查看>>
python下操作数据库
查看>>
python下对数据库的操作(2) 图片的存取
查看>>
常用排序算法总结(一) 比较算法总结
查看>>
剖析 Linux hypervisor
查看>>
常用排序算法总结(二)
查看>>
基于redhat的发行版本的linux系统 下 扩展Swap分区
查看>>
Fedora下安装Fcitx
查看>>
SSH原理与运用
查看>>
libvirt LXC driver --pass-fds
查看>>