python符号格式化设置区间_在python代码中如何将一个序列号分割成区间?

博客围绕Python符号格式化设置区间展开,原算法使用多个if、for、else语句,作者认为不够简洁清晰。作者给出新代码,解决了原始数据中数字等于极限序列最后一个值的计算问题,使用生成器替代原算法,代码更简短清晰,且在Python 3中可执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我提议制定以下准则:raw_data='''

82 68 86 94 89 63 77 76 84 89

75 78 81 82 76 99 80 84 89 88

60 83 72 83 85 56 86 68 75 100

90 84 75 86 74 77 95 63 80 76

100 43 76 81 79 74 96 52 69 86'''

tu = (0,60,70,80,90,100)

print raw_data

print tu

from collections import OrderedDict

tu0 = tu[0]

tuL = tu[-1]

tuF = tu[1:]

d = OrderedDict((tu[i], [tu[i-1:i+1]])

for i in xrange(1,len(tu)))

for x in map(int,raw_data.split()):

if x>=tu0:

if x==tuL:

d[tuL].append(x)

else:

for lim in tuF:

if x

d[lim].append(x)

break

print

print '\n'.join('%-15s%s' % (d[k][0],len(d[k])-1) for k in d)

结果

^{pr2}$

一。在

编辑

我对算法中的这些if、for、else和{}都不满意。

所以我给出了一个新的代码,我认为这是一个改进,因为它更简短、更清晰。我觉得它也更快,但我没有测试速度。在

困难在于,当原始数据中的一个数字等于极限序列tu = (0,60,70,80,90,100)的最后一个值(样本中为100),这个数字必须被计算为属于最后一个跨度,这里是样本中的[90,100](数学表示法),而前面的跨度如[0,60[,[60,70[。。。不包括上限。

但是我最终找到了正确的测试x==tuLast==lim来保存这个特定的情况,然后能够使用一个生成器来代替以前可怕的算法,它有几个测试if和一个循环。在

以下代码在Python3中是可执行的。在raw_data='''

82 68 86 94 89 63 77 76 84 89

75 78 81 82 76 99 80 84 89 88

60 83 72 83 85 56 86 68 75 100

90 84 75 86 74 77 95 63 80 76

100 43 76 81 79 74 96 52 69 86'''

tu = [0,60,70,80,90,100]

print( 'raw_data :%s\n\ntu :\n%s' % (raw_data,tu),'\n' )

tu0, tuLast = tu[0], tu[-1]

tu_from1 = tu[1:]

from collections import OrderedDict

d = OrderedDict( (two[1],[two]) for two in zip(tu, tu_from1) )

print ('OrderedDictionary , before:\n%s'

% '\n'.join('key:%3s value:%s' % item for item in d.items()))

# the core of the code is here:

for x in (x for x in map(int,raw_data.split()) if x>=tu0):

d[next(lim for lim in tu_from1

if x

print ('\nOrderedDictionary , after:\n%s'

% '\n'.join('key:%3s value:%s' % item for item in d.items()),'\n')

print( '\n'.join('%-15s%s' % (v[0],len(v)-1) for v in d.values()) )

结果raw_data :

82 68 86 94 89 63 77 76 84 89

75 78 81 82 76 99 80 84 89 88

60 83 72 83 85 56 86 68 75 100

90 84 75 86 74 77 95 63 80 76

100 43 76 81 79 74 96 52 69 86

tu :

[0, 60, 70, 80, 90, 100]

OrderedDictionary , before:

key: 60 value:[(0, 60)]

key: 70 value:[(60, 70)]

key: 80 value:[(70, 80)]

key: 90 value:[(80, 90)]

key:100 value:[(90, 100)]

OrderedDictionary , after:

key: 60 value:[(0, 60), 56, 43, 52]

key: 70 value:[(60, 70), 68, 63, 60, 68, 63, 69]

key: 80 value:[(70, 80), 77, 76, 75, 78, 76, 72, 75, 75, 74, 77, 76, 76, 79, 74]

key: 90 value:[(80, 90), 82, 86, 89, 84, 89, 81, 82, 80, 84, 89, 88, 83, 83, 85, 86, 84, 86, 80, 81, 86]

key:100 value:[(90, 100), 94, 99, 100, 90, 95, 100, 96]

(0, 60) 3

(60, 70) 6

(70, 80) 14

(80, 90) 20

(90, 100) 7

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值