鱼C论坛

 找回密码
 立即注册
楼主: zltzlt

[已解决]Python:每日一题 347

[复制链接]
发表于 2020-3-9 19:16:25 | 显示全部楼层
a = [1, 3, 15, 11, 2]
b = [23, 127, 235, 19, 8]
result_a_b=[]

list = [abs(a[1]-b[1])]
for eachi in a:
        for eachj in b:
                abs_i_j=abs(eachi-eachj)
                if min(list)>(abs_i_j):
                        list=[abs_i_j]
                        result_a_b=[eachi,eachj]
print("差值绝对值最小的两个数分别是:%d,%d。二者之差值是%d"%(result_a_b[0],result_a_b[1],list[0]))

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 19:51:33 | 显示全部楼层
  1. def func347(a,b):
  2.     a.sort()
  3.     b.sort()
  4.     p=q=0
  5.     ret=abs(a[0]-b[0])
  6.     while p<len(a) and q<len(b):
  7.         if a[p]>b[q]:
  8.             ret=min(ret,a[p]-b[q])
  9.             q+=1
  10.         elif a[p]<b[q]:
  11.             ret=min(ret,b[q]-a[p])
  12.             p+=1
  13.         else:
  14.             return 0
  15.     return ret
复制代码

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 20:08:26 | 显示全部楼层
  1. def f(a,b):
  2.     n = abs(a[0] - b[0])
  3.     for each in a:
  4.         for value in b:
  5.             if abs(each-value) < n:
  6.                 n = abs(each-value)
  7.     return n
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 20:09:33 | 显示全部楼层

怎么错了,我觉得没这么简单,但是不知道错在哪里
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 20:23:11 | 显示全部楼层
本帖最后由 kinkon 于 2020-3-9 21:21 编辑
风魔孤行者 发表于 2020-3-9 20:09
怎么错了,我觉得没这么简单,但是不知道错在哪里


没说你呢,在说我自己编的不对,重新编写...
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 20:31:12 | 显示全部楼层
  1. def solve(a, b):
  2.     for d in a:
  3.         if d in b:
  4.             return 0
  5.     a = list(zip(a, [0]*len(a)))
  6.     b = list(zip(b, [1]*len(b)))
  7.     c = sorted(a+b)
  8.     i = 0
  9.     m = 0xff
  10.     while i < len(c)-1:
  11.         if c[i][1] != c[i+1][1] and c[i+1][0] - c[i][0] < m:
  12.             m = c[i+1][0] -c[i][0]
  13.         i += 1
  14.     return m
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 20:55:58 | 显示全部楼层
。。。

评分

参与人数 1荣誉 -1 鱼币 -1 收起 理由
蒋博文 -1 -1 请不要无意义灌水!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-9 21:32:40 | 显示全部楼层
def func347(a,b):
    a=sorted(a)
    b = sorted(b)
    flag = 0;
    result = []
    minx = abs(a[0]-b[0])
    for i in range(len(a)):
        if flag == 1:
            if minend < miny:
                break
            else:
                minend = miny
        minx = abs(a[i] - b[0])
        for j in range(len(b)):
            if minx < abs(a[i] - b[j]):
                miny = abs(a[i]-b[j-1])
                if flag==0:
                    flag=1
                    minend = miny
                break
    return minend

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2020-3-10 02:19:44 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 09:26:23 | 显示全部楼层

如果a有好几千个数或者上万 电脑能开这么多线程吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 11:01:40 | 显示全部楼层
xiaofan1228 发表于 2020-3-9 13:50
刚看楼上几位学了个abs函数,改了一下

喜欢你这个版本
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 11:58:26 | 显示全部楼层
先来个暴力解
  1. a = [1,3,15,11,2]
  2. b = [23,127,235,19,8]
  3. c=[]
  4. for i in a:
  5.     for j in b:
  6.         c.append(abs(i-j))
  7. c.sort()
  8. print(c[0])
复制代码

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
zltzlt + 3 + 3

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2020-3-10 12:21:38 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-10 12:45:45 | 显示全部楼层
840613937 发表于 2020-3-10 12:21
刚才做了一下实验,在同样环境下a, b的数量同时为一万,我首先使用了楼上一个比较常见的方式去运算

...

不错,重在参与,你说的多线程在小甲鱼的课程里没看见。你这一用,也挺醒我还有没看的内容。你的锻炼是值得的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:07:04 | 显示全部楼层
TJBEST 发表于 2020-3-9 13:33
数组a或者b有重复元素吗?

可能有
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:08:47 | 显示全部楼层
kinkon 发表于 2020-3-9 13:42
先传一个没什么效率的,应该超时了

嗯,输入超长数组会超时
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:09:05 | 显示全部楼层
kinkon 发表于 2020-3-9 13:50
两个数组是不是一样长?

不一定
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:09:26 | 显示全部楼层
TJBEST 发表于 2020-3-9 15:03
哎,刚才就编好了,有个错误找了半天,拿不了第一了

212 ms
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:10:01 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-10 13:10:06 | 显示全部楼层
xiaofan1228 发表于 2020-3-9 13:48
小白暴力破解版来了!!!

会超时
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-3 03:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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