1. 问题 给定一个单链表,随机返回一个结点,要求每个结点被选中的概率相等. 2. 思路 在一个给定长度的数组中等概率抽取一个数,可以简单用随机函数random.randint(0, n-1)得到索引来抽取. 本题是给定了链表,当然也好做,可以事先遍历一次求长度,每次要取的时候随机求索引,然后遍历一次. 时间复杂度O(n),空间复杂度O(1) 或者事先把数据放到数组中,每次要取的时候随机求索引,然后直接取到对应的数. 时间复杂度O(1),空间复杂度O(n) (延伸一下)如果对于长度未知,会不断增…