python求解非递减排序的数组的一个旋转的最小元素

320 篇文章 88 订阅
151 篇文章 4 订阅

    题目很简单,对一个非递减数列进行一次旋转,对得到的旋转后的数组输出最小的元素

    分析一下:如果原始非递减序列没有发生旋转那么返回第一个元素就行了,如果发生了旋转那么返回第一次出现A[i]>A[[i+1]位置的A[i+1]即可

    下面是具体实现:


#!usr/bin/env python
#encoding:utf-8

'''
__Author__:沂水寒城
功能:python求解非递减排序的数组的一个旋转的最小元素
'''

def test_func(num_list):
    '''
    '''
    if len(num_list)==0:
        return 0
    for i in range(len(num_list)-1):
        if num_list[i]>num_list[i+1]:
            return num_list[i+1]
    return num_list[0]


if __name__ == '__main__':
    num_list=[[3,4,5,1,2],[1,2,3,4,5],[34,56,78,1,2,3]]
    for one_list in num_list:
        print 'one_list最小元素为:',one_list,  test_func(one_list)


结果如下:

one_list最小元素为: [3, 4, 5, 1, 2] 1
one_list最小元素为: [1, 2, 3, 4, 5] 1
one_list最小元素为: [34, 56, 78, 1, 2, 3] 1
[Finished in 0.3s]



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Together_CZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值