每天一题:翻转链表 by python(19.9.10)

题目描述:

给一个链表,每k个节点一组进行翻转,请返回翻转后的链表;如果节点总数不是k的整数倍,那么请将最后剩余节点保持原有顺序

示例:

给定这个链表:1>2>3>4>5

当k=2,应该返回:2>1>4>3>5

当k=3,应该返回:3>2>1>4>5


输入描述:

第一行:依次输入链表中的各个元素,以“#”结束

第二行:每组数量k

输出描述:处理后的链表中的各个元素,以“->”连接


输入:1 2 3 4 5 

          2

输出:2>1>4>3>5 

代码:

def reverse_list(arr, k):
    count = 0
    s = []
    for i in range(len(arr)//k):
        count = (i+1)* k-1
        for j in range(k):
            s.append(arr[count-j])
    if len(arr) % k==0:
        return s
    else:
        for m in arr[count+1:]:
            s.append(m)
        return s
arr = [int(x) for x in input().split(' ')]
k = int(input())
s = reverse_list(arr, k)
out = ''
for num in range(len(s)-1):
    out += str(s[num])+ '->'
out += str(s[-1])
print(out)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值