通过python实现随机交换礼物程序详解


Posted in Python onJuly 10, 2019

看到了一个面试题,想了两种解法,不知道符不符合要求,记录如下:

题目:有N个人,每人备一个圣诞礼物,现需要写一个程序,随机交互礼物,要求:自己不能换到自己的礼物,用python实现。

方法一:

构造二维列表存储参与者的名字和所带礼物,使用random.choice()随机选择礼物。

import random
 
lsGiftIn = [['Jack','apple'],['June','ball'],['Mary','card'],['Duke','doll'],['James','egg'],['Tina','flute'],['Tom','coffee']]#存储参与者的姓名和自己带来的礼物
lsGiftOut = []#存储交换后的结果
n = len(lsGiftIn)#参与人数
gifts = [i[1] for i in lsGiftIn]#未分配出去的礼物
for x in range(n):
  flag = 0
  person = lsGiftIn[x][0]
  myGift = lsGiftIn[x][1]
  if myGift in gifts:
    flag = 1
    gifts.remove(myGift)
  getGift = random.choice(gifts)#随机分配礼物
  lsGiftOut.append([person,getGift])
  gifts.remove(getGift)
  if flag:
    gifts.append(myGift)
 
print(lsGiftOut)

方法二:

构造字典存储参与者的姓名和礼物,其中姓名为key,礼物为value,使用字典的popitem()方法随机返回礼物。

dictGiftIn = {'Jack':'apple','Peter':'beer','Tom':'card','Duke':'doll','Mary':'pineapple','James':'flute','Tina':'coffee'}
dictGiftOut = {}
persons = list(dictGiftIn.keys())
for p in persons:
  flag = 0#标记自己带来的礼物是否还未分配出去
  if p in dictGiftIn:
    flag = 1
    myGift = dictGiftIn.pop(p)#如果自己带来的礼物还未分配,则去掉该礼物
  getGift = dictGiftIn.popitem()#随机返回并移除一对key-value值
  dictGiftOut[p] = getGift[1]#得到的礼物
  if flag:
    dictGiftIn[p] = myGift#将自己的礼物添到未分配礼物中
 
print(dictGiftOut)#输出礼物分配情况

The End ~

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python编程中归并排序算法的实现步骤详解
May 04 Python
搭建Python的Django框架环境并建立和运行第一个App的教程
Jul 02 Python
Python实现的朴素贝叶斯分类器示例
Jan 06 Python
Tensorflow 自带可视化Tensorboard使用方法(附项目代码)
Feb 10 Python
python3+PyQt5实现自定义窗口部件Counters
Apr 20 Python
python3 字符串/列表/元组(str/list/tuple)相互转换方法及join()函数的使用
Apr 03 Python
python开启debug模式的方法
Jun 27 Python
Django ORM 查询管理器源码解析
Aug 05 Python
解决Django中修改js css文件但浏览器无法及时与之改变的问题
Aug 31 Python
使用jupyter notebook将文件保存为Markdown,HTML等文件格式
Apr 14 Python
Python HTMLTestRunner测试报告view按钮失效解决方案
May 25 Python
在Pytorch中使用Mask R-CNN进行实例分割操作
Jun 24 Python
Python实现简单的列表冒泡排序和反转列表操作示例
Jul 10 #Python
Python获取好友地区分布及好友性别分布情况代码详解
Jul 10 #Python
Python中的类与类型示例详解
Jul 10 #Python
使用python打印十行杨辉三角过程详解
Jul 10 #Python
python简单实现矩阵的乘,加,转置和逆运算示例
Jul 10 #Python
Python中新式类与经典类的区别详析
Jul 10 #Python
详解Pandas之容易让人混淆的行选择和列选择
Jul 10 #Python
You might like
php foreach 参数强制类型转换的问题
2010/12/10 PHP
php 遍历目录,生成目录下每个文件的md5值并写入到结果文件中
2016/12/12 PHP
浅谈javascript中this在事件中的应用
2015/02/15 Javascript
jquery滚动条插件(可以自定义)
2016/12/11 Javascript
JS轮播图中缓动函数的封装
2020/11/25 Javascript
基于JavaScript实现购物车功能
2017/02/07 Javascript
jQuery日期范围选择器附源码下载
2017/05/23 jQuery
详解js静态资源文件请求的处理
2017/08/01 Javascript
Vue的MVVM实现方法
2017/08/16 Javascript
探索webpack模块及webpack3新特性
2017/09/18 Javascript
Angular 数据请求的实现方法
2018/05/07 Javascript
JS插件clipboard.js实现一键复制粘贴功能
2020/12/04 Javascript
对类Vue的MVVM前端库的实现代码
2018/09/07 Javascript
解决vue props 拿不到值的问题
2018/09/11 Javascript
微信小程序返回箭头跳转到指定页面实例解析
2019/10/08 Javascript
5分钟快速看懂ES6中的反射与代理
2019/12/19 Javascript
js实现二级联动简单实例
2020/01/11 Javascript
Preload基础使用方法详解
2020/02/03 Javascript
微信小程序连接服务器展示MQTT数据信息的实现
2020/07/14 Javascript
JavaScript数组排序的六种常见算法总结
2020/08/18 Javascript
用Python创建声明性迷你语言的教程
2015/04/13 Python
python通过smpt发送邮件的方法
2015/04/30 Python
Python的装饰器模式与面向切面编程详解
2015/06/21 Python
python解析html提取数据,并生成word文档实例解析
2018/01/22 Python
python使用KNN算法手写体识别
2018/02/01 Python
python函数中将变量名转换成字符串实例
2020/05/11 Python
HTML5等待加载动画效果
2017/07/27 HTML / CSS
Love, Bonito国际官网:新加坡女装品牌
2021/03/13 全球购物
科研先进个人典型材料
2014/01/31 职场文书
卖车协议书
2014/04/21 职场文书
2014年房地产个人工作总结
2014/12/20 职场文书
业务员岗位职责
2015/02/03 职场文书
不同意离婚答辩状
2015/05/22 职场文书
十二生肖观后感
2015/06/12 职场文书
如何书写先进事迹材料?
2019/07/02 职场文书
使用canvas仿Echarts实现金字塔图的实例代码
2021/11/11 HTML / CSS