这篇文章主要介绍了 Python 实现翻转数组功能, 涉及 Python 针对数组的遍历, 判断, 排序等相关操作技巧, 需要的朋友可以参考下
本文实例讲述了 Python 实现翻转数组功能. 分享给大家供大家参考, 具体如下:
题目描述
给定一个长度为 n 的整数数组 a, 元素均不相同, 问数组是否存在这样一个片段, 只将该片段翻转就可以使整个数组升序排列. 其中数组片段 [l,r] 表示序列 a[l], a[l+1], ..., a[r]. 原始数组为
a[1], a[2], ..., a[l-2], a[l-1], a[l], a[l+1], ..., a[r-1], a[r], a[r+1], a[r+2], ..., a[n-1], a[n],
将片段 [l,r] 反序后的数组是
a[1], a[2], ..., a[l-2], a[l-1], a[r], a[r-1], ..., a[l+1], a[l], a[r+1], a[r+2], ..., a[n-1], a[n].
输入
第一行数据是一个整数: n (1≤n≤105), 表示数组长度.
第二行数据是 n 个整数 a[1], a[2], ..., a[n] (1≤a[i]≤109).
输出
输出 "yes", 如果存在; 否则输出 "no", 不用输出引号.
样例输出
yes
样例输入
4
2 1 3 4
实现代码:
while 1:
n = int(raw_input())
x = raw_input()
break
x = [int(i) for i in x.split()]
y = [i for i in x]
y.sort()
partx = [x[i] for i in range(n) if x[i]!=y[i]]
party = [y[i] for i in range(n) if x[i]!=y[i]]
party.reverse()
if partx == party:
print "yes"
else:
print "no"
希望本文所述对大家 Python 程序设计有所帮助.
来源: http://www.phperz.com/article/18/0130/362730.html