QQ登录

只需一步,快速开始

搜索
【活动】边做笔记边学习,还能赢取奖学金!
查看: 1107|回复: 82

[技术交流] Python:每日一题 72(答题领鱼币)

[复制链接]
累计签到:170 天
连续签到:7 天
最佳答案
166 
发表于 2017-8-6 12:05:35 | 显示全部楼层 |阅读模式

马上注册加入鱼C,享用更多服务吧^_^

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
本帖最后由 新手·ing 于 2017-8-6 12:06 编辑

今天给大家带来一道算法题~




Given an unsorted array of integers, find the smallest number in the array, the largest number in the array, and the smallest number between the two array bounds that is not in the array.

For instance, given the array [-1, 4, 5, -23, 24], the smallest number is -23, the largest number is 24, and the smallest number between the array bounds is -22. You may assume the input is well-formed.

You solution should return an array [smallest, minimumAbsent, largest]

The smallest integer should be the integer from the array with the lowest value.

The largest integer should be the integer from the array with the highest value.

The minimumAbsent is the smallest number between the largest and the smallest number that is not in the array.

  1. minMinMax([-1, 4, 5, -23, 24]); //[-23, -22, 24]
  2. minMinMax([1, 3, -3, -2, 8, -1]); //[-3, 0, 8]
  3. minMinMax([2, -4, 8, -5, 9, 7]); //[-5, -3,9]
复制代码


英文看不懂?
回复给你中文版!

游客,如果您要查看本帖隐藏内容请回复


为了方便理解,下面是例子:

  1. minMinMax([-1, 4, 5, -23, 24]); //[-23, -22, 24]
  2. minMinMax([1, 3, -3, -2, 8, -1]); //[-3, 0, 8]
  3. minMinMax([2, -4, 8, -5, 9, 7]); //[-5, -3,9]
复制代码





大家一起来啊

解决方案:

游客,如果您要查看本帖隐藏内容请回复

评分

参与人数 1荣誉 +6 鱼币 +6 贡献 +6 收起 理由
hldh214 + 6 + 6 + 6 666

查看全部评分

本帖被以下淘专辑推荐:

1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:625 天
连续签到:49 天
最佳答案
361 
发表于 2017-8-8 10:08:22 | 显示全部楼层
  1. def minMinMax(lst):
  2.     Max1 = max(lst)
  3.     min1 = min(lst)
  4.     Min1 = min1 + 1
  5.     while Min1 < Max1:
  6.         if not Min1 in lst:
  7.             break
  8.         Min1 += 1
  9.     else:
  10.         Min1 = 'None'
  11.     return [min1, Min1, Max1]
复制代码

点评

我很赞同!: 5.0
我很赞同!: 5
厉害  发表于 2017-8-8 16:50
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:170 天
连续签到:7 天
最佳答案
166 
 楼主| 发表于 2017-8-6 12:07:30 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:73 天
连续签到:70 天
最佳答案
261 
发表于 2017-8-6 12:59:02 | 显示全部楼层
  1. def largest(array):
  2.         array.sort(reverse=True) #从大到小排序
  3.         return array[0] #返回0号元素,最大值

  4. def smallest(array):
  5.         array.sort() #从小到大排序
  6.         return array[0] #返回0号元素,最小值

  7. def minimumAbsent(array, smallest, largest):
  8.         minilist=list(range(smallest, largest))
  9.         lastlist=[]
  10.         for each in minilist:
  11.                 if each not in array:
  12.                         lastlist.append(each)
  13.         lastlist.sort() ##从小到大排序
  14.         return lastlist[0] #返回0号元素,最小值

  15. def minMinMax(array):
  16.         le = largest(array)
  17.         se = smallest(array)
  18.         mma = minimumAbsent(array, se, le)
  19.         
  20.         newarray=[]
  21.         newarray.append(se)
  22.         newarray.append(mma)
  23.         newarray.append(le)

  24.         return newarray
  25.         
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
新手·ing + 3 + 3

查看全部评分

1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:111 天
连续签到:30 天
最佳答案
24 
发表于 2017-8-6 13:28:02 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:170 天
连续签到:7 天
最佳答案
166 
 楼主| 发表于 2017-8-6 15:09:25 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:170 天
连续签到:7 天
最佳答案
166 
 楼主| 发表于 2017-8-6 15:09:54 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:170 天
连续签到:7 天
最佳答案
166 
 楼主| 发表于 2017-8-6 15:10:12 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!

尚未签到

最佳答案
0 
发表于 2017-8-6 15:41:42 | 显示全部楼层
# _*_ coding: utf-8 _*_

import math

def minMinMax(array):
    newarray = []
    Minnum = 0
    array.sort()
    length = len(array)
    newarray.append(array[0])
    for i in range(array[0], array[length-1]):
        if i not in array:
            Minnum = i
            break
    newarray.append(Minnum)
    newarray.append(array[length-1])
    print(newarray)

minMinMax([1,-3,3,-1,-2,8,-1])

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
新手·ing + 3 + 3

查看全部评分

1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:13 天
连续签到:8 天
最佳答案
0 
发表于 2017-8-6 15:45:10 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:126 天
连续签到:1 天
最佳答案
0 
发表于 2017-8-6 16:29:36 | 显示全部楼层
我是来大打酱油的。。。
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:10 天
连续签到:5 天
最佳答案
0 
发表于 2017-8-6 16:37:55 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:2 天
连续签到:1 天
最佳答案
0 
发表于 2017-8-6 16:42:44 From FishC Mobile | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:58 天
连续签到:11 天
最佳答案
0 
发表于 2017-8-6 17:42:36 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:41 天
连续签到:40 天
最佳答案
5 
发表于 2017-8-6 18:03:33 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!

尚未签到

最佳答案
0 
发表于 2017-8-6 18:10:46 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:3 天
连续签到:3 天
最佳答案
0 
发表于 2017-8-6 18:34:11 | 显示全部楼层
  1. def minMinMax(list1):
  2.     b = []
  3.     list1.sort()
  4.     b.append(list1[0])
  5.     for i in range(list1[0],list1[len(list1)-1]):
  6.         if i not in list1:
  7.             b.append(i)
  8.             break
  9.     b.append(list1.pop())
  10.     print(b)


  11. a =input("请输入你的数据(例:1 2 3 4):")
  12. b = []
  13. for i in a.split(' '):
  14.     b.append(int(i))

  15. minMinMax(b)
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
新手·ing + 5 + 5

查看全部评分

1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:3 天
连续签到:3 天
最佳答案
0 
发表于 2017-8-6 18:45:20 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:73 天
连续签到:70 天
最佳答案
261 
发表于 2017-8-6 19:12:06 | 显示全部楼层
新手·ing 发表于 2017-8-6 15:09
最大和最小用内置函数就行

没考虑到。直接就上代码了
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:67 天
连续签到:4 天
最佳答案
0 
发表于 2017-8-6 20:06:56 | 显示全部楼层
1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
累计签到:56 天
连续签到:5 天
最佳答案
0 
发表于 2017-8-6 20:14:39 | 显示全部楼层
本帖最后由 chunchun2017 于 2017-8-6 20:47 编辑

def minMinMax(list2):
        list1=sorted(list2)
        minnum=list1[0]
        Maxnum=list1[-1]
        flag=0
        Minnum=minnum
        for each in list1:
                if(Minnum==each):
                        Minnum+=1
                        if(Minnum>=Maxnum):
                                flag=1;
                                break;
                else:
                        break;
               
        if flag==1:
                return [minnum,'*',Maxnum] #*表示中间值不存在
        else:
                return [minnum,Minnum,Maxnum]

str0=input("请按[*,*]格式输入一个列表:")
list1=list(eval(str0))
print(minMinMax(list1))
       

=======================
运算结果:
请按[*,*]格式输入一个列表:[1, 3, -3, -2, 8, -1]
[-3, 0, 8]


请按[*,*]格式输入一个列表:[2, -4, 8, -5, 9, 7]
[-5, -3, 9]


请按[*,*]格式输入一个列表:[-3,-2,-1]
[-3, '*', -1]

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
新手·ing + 5 + 5

查看全部评分

1. 如果您的提问得到满意的答案,请务必选择【最佳答案】;2. 如果想鼓励一下楼主或帮助到您的朋友,可以给他们【评分】作为奖励;
3. 善用【论坛搜索】功能,那里可能有您想要的答案;4. 粘贴代码请点击编辑框上的 <> 按钮,否则您的代码可能会被“吃掉”!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

小甲鱼强烈推荐上一条 /1 下一条

小黑屋手机版Archiver( 粤公网安备 44051102000370号 | 粤ICP备11014136号

© 2010-2017 FishC.com GMT+8, 2017-8-20 21:25 Powered by Discuz! X2.5 Theme by dreambred

快速回复 返回顶部 返回列表