题库 Python题库 题目列表 在编写抽奖程序时,为了保证一个人只有一次中奖机会,...
问答题

在编写抽奖程序时,为了保证一个人只有一次中奖机会,要检查新抽出来的数字是不是已经被抽中过了。  

 一种办法是将已经中过奖的人员编号存放在test_list里面,然后每抽出一个新的人员编号,判断它是否在中奖人员列表中。  

如果没有在中奖人员列表中,说明中奖号码有效,并将它保存进中奖人员列表;如果已经在里面了,就再生成一个新的人员编号。  

请你补全下面的代码,实现判断一个数字是否在列表中的功能。   

#子问题算法(子问题规模为1)  
      def is_in_list(init_list,num):  
        if init_list[0] == num:  
          return True  
        else:  
          return False  
      
  
      #分治法  
      def find_out(init_list,num):  
        n = len(init_list)  
        if ____①______      #如果问题的规模等于1,直接解决 
          return is_in_list(init_list,num)  
        #分解(子问题规模为n/2)  
        left_list,right_list = _________②____________  
      
  
        #递归,分治,合并  
        res=find_out(left_list,num) __③__ find_out(right_list,num)  
      
  
        return res  
      
  
      if __name__ == "__main__":  
        #测试数据  
        test_list = [18,43,21,3,28,2,46,25,32,40,14,36]  
        #查找  
        print(_____④_____)

程序运行结果: 

      >>>True

题目信息
2021年 9月 编程题
-
正确率
0
评论
106
点击