翻转列表 python

太难啦,!!!昨天晚上,不,昨天上午开始看,一直到今天下午,,,终于在参考别人图解的基础上,调出来了!!感谢这个图

下面是我的代码,和参考答案大同小异吧,包括了链表定义和赋值

class ListNode:
    def __init__(self, x=None, next=None):
        self.val = x
        self.next = None

l1 = ListNode(1)
head = l1
for i in range(2, 10):
    head.next = ListNode(i)
    head = head.next
head = l1

def change(pre, cur):
    if cur == None: return pre
    cu = cur.next
    cur.next = pre
    return change(cur, cu)

k = 2
dunmmy = ListNode(0)
pre = dunmmy
end = dunmmy
dunmmy.next = head
while (end.next != None):
    start = pre.next
    for i in range(k):
        end = end.next
        if end == None: break
    if end == None: break
    next1 = end.next
    end.next = None
    pre.next = change(end.next, start)
    start.next = next1
    pre = start
    end = pre
head = dunmmy.next
while head != None:
    print(head.val)
    head = head.next

 

### Python 字典翻转 示例代码教程 #### 使用字典推导式进行简单翻转 当处理简单的键值对且这些值都是独一无二的时候,可以利用字典推导式轻松完成字典的反转操作。这种方式简洁明了。 ```python original_dict = {'apple': 'fruit', 'carrot': 'vegetable', 'banana': 'fruit'} inverted_dict = {value: key for key, value in original_dict.items()} print(inverted_dict) # 输出:{'fruit': 'banana', 'vegetable': 'carrot'} ``` 注意,在这个例子中最后的结果只保留了一个`'fruit'`对应的键 `'banana'`,因为字典不允许重复的键[^3]。 #### 处理非唯一值的情况 如果原字典中有多个相同的值,则上述方法会导致部分数据丢失。为了保存所有的映射关系,可以创建一个多值字典,即让新的字典中的每一个键对应一个列表形式的值。 ```python def invert_dictionary_with_duplicates(dict_input): inverted = {} for key, value in dict_input.items(): if value not in inverted: inverted[value] = [key] else: inverted[value].append(key) return inverted example_dict = {'a': 1, 'b': 2, 'c': 1} result = invert_dictionary_with_duplicates(example_dict) print(result) # 输出:{1: ['a', 'c'], 2: ['b']} ``` 此函数遍历给定字典的所有项,并构建一个新的字典,其中每个新加入的条目都会被检查是否存在相同值;如果有则追加到现有列表里而不是覆盖原有记录[^5]。 #### 输入验证与异常处理 考虑到实际应用环境中可能遇到的各种情况,比如用户输入错误等问题,应该增加必要的输入校验逻辑以及异常捕获机制来提高程序健壮性。 ```python try: user_input = eval(input("请输入要翻转的字典(格式如:{'name':'张三','age':20}): ")) if isinstance(user_input, dict): result = {v: k for k, v in user_input.items()} print(f"翻转后的字典为:\n{result}") else: raise ValueError("输入不是一个有效的字典") except Exception as e: print(f"发生错误: {e}") ``` 这段脚本首先尝试评估用户的输入是否是一个合法的Python表达式(这里假设是以字符串形式给出),接着判断其类型是不是字典,如果不是就抛出异常提示用户重新输入正确的格式[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值