hjbhkjsjhd 发表于 2022-11-24 22:00:11

python第44讲函数IV动动手0题求助

import random

def fy_shuffle(x, n=1):
    for i in range(n):
      target = list(x)
      result = []
      while target:
            r = random.randint(0, len(target)-1) # 步骤2
            result.append(target.pop(r)) # 步骤3

      print(f"第{i+1}次打乱后的结果:{''.join(result)}")
      
    return "".join(result)

x = input("请输入需要打乱的序列:")
n = int(input("请输入需要打乱的次数:"))

print(f"最终的结果是:{fy_shuffle(x, n)}")

小甲鱼的这个答案不是每次打乱都是从用户输入的正序开始打乱的吗,而不是一个序列连续打乱n次。新手提问下,问问大佬们
https://xxx.ilovefishc.com/forum/202205/28/031653ziddi6q11kk1rhuh.png

tommyyu 发表于 2022-11-24 22:25:01

可以看一下这一篇帖子的最佳答案https://fishc.com.cn/thread-220622-1-1.html

hjbhkjsjhd 发表于 2022-11-24 22:37:58

tommyyu 发表于 2022-11-24 22:25
可以看一下这一篇帖子的最佳答案https://fishc.com.cn/thread-220622-1-1.html

def fy_shuffle1(x,n=1):
    target = list(x)
    import random
    for i in range(n):
      result = []
      while target:
            k = random.randint(0,len(target)-1)
            result.append(target.pop(k))
      target = result.copy()
      print(f'第{i+1}次打乱后的结果:{"".join(result)}')

    return "".join(target)
x = input("请输入需要打乱的序列:")
n = int(input("请输入需要打乱的次数:"))
print(f"最终的结果是:{fy_shuffle1(x,n)}")

我增加了一句target = result.copy(),应该是实现了连续打乱n次吧,大佬

tommyyu 发表于 2022-11-25 07:08:28

hjbhkjsjhd 发表于 2022-11-24 22:37
def fy_shuffle1(x,n=1):
    target = list(x)
    import random


确实满足了题目打乱 n 次的题目要求,但实际上我们不需要这么严谨,不一定非要打乱 3 次,只要让用户看到三次就可以了
页: [1]
查看完整版本: python第44讲函数IV动动手0题求助