回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>假设我有以下清单</p>
<pre><code>[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18]
</code></pre>
<p>我想找到一段时间内所有可能的子列表,它们不包含一个特定的数字,并且不丢失数字的顺序。</p>
<p>例如,所有长度为6但没有12的可能子列表是:</p>
<pre><code>[1,2,3,4,5,6]
[2,3,4,5,6,7]
[3,4,5,6,7,8]
[4,5,6,7,8,9]
[5,6,7,8,9,10]
[6,7,8,9,10,11]
[13,14,15,16,17,18]
</code></pre>
<p>问题是我想把它列在一个很大的单子里,我想用最快的方法。</p>
<p>使用我的方法更新:</p>
<pre><code>oldlist = [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18]
newlist = []
length = 6
exclude = 12
for i in oldlist:
if length+i>len(oldlist):
break
else:
mylist.<a href="https://www.cnpython.com/list/append" class="inner-link">append</a>(oldlist[i:(i+length)]
for i in newlist:
if exclude in i:
newlist.remove(i)
</code></pre>
<p>我知道这不是最好的方法,所以我需要一个更好的方法。</p>