最最最基础题应知应会题目_1_排序_下载图片

最最最基础题应知应会题目_1_排序_下载图片

 

1、一组数,挑出第二大的数字

 

import re

import requests


def t1(l_, x):
    n = set(l_)
    r = sorted(n, reverse=True)
    return r[x]
print(t1([1, 4, 7, 902, 902], 1), )

  

快排

def quick_sort(li, start, end):
    # 分治 一分为二
    # start=end ,证明要处理的数据只有一个
    # start>end ,证明右边没有数据
    if start >= end:
        return
    # 定义两个游标,分别指向0和末尾位置
    left = start
    right = end
    # 把0位置的数据,认为是中间值
    mid = li[left]
    while left < right:
        # 让右边游标往左移动,目的是找到小于mid的值,放到left游标位置
        while left < right and li[right] >= mid:
            right -= 1
        li[left] = li[right]
        # 让左边游标往右移动,目的是找到大于mid的值,放到right游标位置
        while left < right and li[left] < mid:
            left += 1
        li[right] = li[left]
    # while结束后,把mid放到中间位置,left=right
    li[left] = mid
    # 递归处理左边的数据
    quick_sort(li, start, left - 1)
    # 递归处理右边的数据
    quick_sort(li, left + 1, end)


if __name__ == '__main__':
    l = [6, 5, 4, 3, 2, 1]
    # l = 3 [2,1,5,6,5,4]
    # [2, 1, 5, 6, 5, 4]
    quick_sort(l, 0, len(l) - 1)
    print(l)
    # 稳定性:不稳定
    # 最优时间复杂度:O(nlogn)
    # 最差时间复杂度:O(n**2)

  简化编写,效率低,空间复杂度高

  分治思想

def quick_sort(array):
    if len(array) < 2:
        return array
    else:
        pivot = array[0]
        less_than_pivot = [x for x in array if x <= pivot]
        more_than_pivot = [x for x in array if x > pivot]
        return quick_sort(less_than_pivot) + [pivot] + quick_sort(more_than_pivot)

  函数式编程

def quick_sort(L):
    return q_sort(L, 0, len(L) - 1)

def q_sort(L, left, right):
    if left < right:
        pivot = Partition(L, left, right)

        q_sort(L, left, pivot - 1)
        q_sort(L, pivot + 1, right)
    return L

def Partition(L, left, right):
    pivotkey = L[left]
  # 对指针的控制,所以占用空间少
    while left < right:
        while left < right and L[right] >= pivotkey:   # 右边比L[left]小的第一个复制给L[left]
            right -= 1
        L[left] = L[right]
        while left < right and L[left] <= pivotkey:  # ?? 再把原始的L[left]插回去
            left += 1
        L[right] = L[left]                 #   为什么这里是这样??????
    L[left] = pivotkey                       #    应该在循环中赋值????????
    return left

L = [5, 9, 1, 11, 6, 7, 2, 4]

print quick_sort(L)

  

def qw(al):
    return qs(al, 0, len(al)-1)

def qs(al,lf,rt):
    """if lf<rt:

        v = pv(al,lf,rt)
        qs(al,lf,v-1)
        qs(al,v+1,rt)
    return al"""

    # 这种写法为什么返回为None
    if lf>=rt:
        return al
    else:
        v = pv(al,lf,rt)
        qs(al,lf,v-1)
        qs(al,v+1,rt)
    
    

def pv(al,lf,rt):

    sv = al[lf]
    while lf<rt:
        while lf<rt and al[rt]>=sv:
            rt-=1
        al[lf]=al[rt]
        while lf<rt and al[lf]<=sv:
            lf+=1
        al[rt]=al[lf]
    al[lf]=sv
    return lf

L = [5, 9, 1, 6, 7, 2]
print(qw(L))

  3.10 理解一个中间值左右分开lf和rt,然后rt先与其附近比较再次做小范围排序,尽最大可能中间值的左右两边是大于小于这个值。

    先听讲解

    

    伪代码:

      1 获取一个中间点

      2 处理中间点左边部分

      3 处理中间点右边部分

      4 每个部分怎么处理

    步骤4 的基本操作为,起始点left值保存在 priv中,right>priv,直到右侧有小于priv,右侧值挪到左边即右侧值赋值左侧,

                          left<priv,直到左侧有大于priv,左侧值挪到右边right即左侧值赋值右侧。

                          这时left所处值有两个,一个是本身一个是right

                          用事先存储的分割点值priv赋值给left,这样就完成双指针替换,不占用更多内存

                          返回left索引

    1分治思想,2 先写伪代码 3 双指针操作必须熟练

        3的示意图

 

 

2、数据量很多采用什么方法?

  采用什么数据结构

  

3、下载一组图片

输入一个元素为字符串的列表

def get_url(u, m="POST"):
    for u_ in u:
        r = requests.request(m, u_)
        html = r.content
        print(html)
        with open('%s.png' % u_.split("/")[-1].split(".")[0], 'wb') as f:
            f.write(html)
        return
u1="https://up.ruyile.com/jy_img/cj/14/169/33520l91.jpg"
# u2="https://img.tupianzj.com/uploads/allimg/202007/9999/5f552d9fd7.jpg"
tu = [u1]
print(get_url(tu))

  下载的图片有问题

image not loaded  try to open it externally to fix format problem

 

4、采用什么方法测试

 

5、代码有哪些优化空间

  1 保护

  2 中断怎么办

  3 特别大的连接怎么办

  4 数量巨大怎么办

 

posted on 2020-07-26 00:05  lexn  阅读(178)  评论(0编辑  收藏  举报

导航