Python实现迪马克序列(TD)序列 , 最少代码

# 对于给定列表 , 用下标4与下标0比较 , 5与1比较 , 6与2比较, 依次后移.所以样本前四个是没有TD数字的
list1 = (1, 2, 3, 4, 5, 8, 7, 6, 69, 2, 3, 4, 5, 6, 7, 8, 12, 123, 233, 445, 446, 6, 5, 4, 3)  #list1是测试样本
list2 = [0, 0, 0, 0]  # list2是存储TD结果用的,前4个无效用0占位置.因为TD定义是下标第n和n-4比较
top = 0  # 初始化上标
bot = 0  # 初始化下标
for i in range(4, len(list1)):   #为何会从4开始,因为要用index n与index n-4 作比较,比他大才算TD上标1
    if list1[i] > list1[i - 4]:  #由于i本身就是从4开始, 所以就是由4与0比较,i的最后一个循环到列表的最后一个数字,能够遍历完
        top += 1
        bot *= 0
        list2.append(top)
    else:
        top *= 0
        bot += 1
        list2.append(-bot)
for c in list2:
    print(c)

  

  说明. list1是样本列表 , list2是为了存储TD结果而创建的, 两个表的长度是一样的

  这里面最关键的是,

  每次出现上TD连续, 则上TD累加1 , 下TD乘以0以便归零 , 

  当某一次出现上TD断了之后, 上TD乘以0,下TD加1 ,  任何数乘以0依然是0

  所以,断了就会重新来过,

  下面是代码运行结果! ! !

  

 

posted @ 2021-12-18 01:52  挪威森林猫Zzz  阅读(1533)  评论(0编辑  收藏  举报