从1开始,求出所有的和为21的连续正整数数列。比如1+2+3+4+5+6 和为 21, 6+7+8和为21。
解法:该题目仍然需要首尾两个指针,一个为start,一个为end。sum=start+end。 如果sum大于21,start后移,如果等于21,打印start到end的数列。start,end全部后移。如果小于21,end后移。指针移动时。注意,sum的值也要相应变化。
defaddSeq(n):start,end=1,2stop=(n+1)/2mysum=start+endwhilestart<stop:ifmysum==n:printrange(start,end+1)mysum-=startstart+=1end+=1mysum+=endelifmysum<n:end+=1mysum+=endelse:mysum-=startstart+=1if__name__=='__main__':addSeq(21)
答案:
C:\Python27\python.exe E:/cyou-/test/test.py
[1, 2, 3, 4, 5, 6]
[6, 7, 8]
[10, 11]