鱼C论坛

 找回密码
 立即注册
查看: 1175|回复: 11

[已解决]面试题目求助

[复制链接]
发表于 2018-12-12 10:20:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 一切好的 于 2018-12-14 14:15 编辑

删除
最佳答案
2018-12-12 13:11:09
  1. def generate(string, dic):
  2.     old1 = ['']
  3.     new1 = ['']
  4.     while dic:
  5.         old2 = []
  6.         new2 = []
  7.         key, value = dic.popitem()
  8.         for each in value:
  9.             for s1, s2 in zip(old1, new1):
  10.                 old2.append(s1 + key)
  11.                 new2.append(s2 + each)
  12.         old1 = old2
  13.         new1 = new2
  14.     for old, new in zip(old1, new1):
  15.         print(string.translate(str.maketrans(old, new)))
  16. string = 'adcbf'
  17. dic = {'a': ['B', 'C'], 'b': ['X'], 'f': ['W', 'Q']}
  18. generate(string, dic)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-12-12 10:21:26 | 显示全部楼层
求大佬帮助
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-12 10:22:15 | 显示全部楼层
@冬雪雪冬
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-12 10:59:26 | 显示全部楼层
  1. def change(string):
  2.     for old,new in dic.items():
  3.         i = string.find(old)
  4.         if i!=-1:
  5.             for new_a in new:
  6.                 string = string[:i]+new_a+string[i+1:]
  7.                 result.append(string)
  8.                 change(string)
  9. def remove(result):
  10.     for i in result[:]:
  11.         for j in list(dic):
  12.             if j in i:
  13.                 try:result.remove(i)
  14.                 except:pass
  15.     return list(set(result))

  16. dic= {'a': ['B', 'C'], 'b': ['X','G']}
  17. string = 'adcbfaba'
  18. result=[]
  19. change(string)
  20. print(remove(result))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-12 11:03:26 | 显示全部楼层

厉害啊,谢谢大佬
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-12 11:07:01 | 显示全部楼层

垃圾算法,自己用还行,拿去面试上不了台面的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-12 13:11:09 | 显示全部楼层    本楼为最佳答案   
  1. def generate(string, dic):
  2.     old1 = ['']
  3.     new1 = ['']
  4.     while dic:
  5.         old2 = []
  6.         new2 = []
  7.         key, value = dic.popitem()
  8.         for each in value:
  9.             for s1, s2 in zip(old1, new1):
  10.                 old2.append(s1 + key)
  11.                 new2.append(s2 + each)
  12.         old1 = old2
  13.         new1 = new2
  14.     for old, new in zip(old1, new1):
  15.         print(string.translate(str.maketrans(old, new)))
  16. string = 'adcbf'
  17. dic = {'a': ['B', 'C'], 'b': ['X'], 'f': ['W', 'Q']}
  18. generate(string, dic)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-12 16:15:43 | 显示全部楼层
新手,做了个练习,仅供参考,见笑了~

  1. def func1(str1, dic):
  2.     str2 = [[str1]]
  3.     for k in dic:
  4.         temp = []
  5.         for s in str2[-1]:
  6.             if k in s:
  7.                 for i in range(len(dic[k])):
  8.                     temp.append(s.replace(k, dic[k][i]))
  9.         str2.append(temp)

  10.     return str2[-1]


  11. dic = {'a': ['B', 'C'], 'b': ['X']}
  12. dic1 = {'a': ['B', 'C', 'D'], 'b': ['X', 'Y', 'Z'], 'f': ['P', 'O']}
  13. print(func1('adcbf', dic))
  14. print(func1('adcbf', dic1))
复制代码


结果:
['BdcXf', 'CdcXf']
['BdcXP', 'BdcXO', 'BdcYP', 'BdcYO', 'BdcZP', 'BdcZO', 'CdcXP', 'CdcXO', 'CdcYP', 'CdcYO', 'CdcZP', 'CdcZO', 'DdcXP', 'DdcXO', 'DdcYP', 'DdcYO', 'DdcZP', 'DdcZO']
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-12 17:59:20 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-12 17:59:57 | 显示全部楼层
graceasyi 发表于 2018-12-12 16:15
新手,做了个练习,仅供参考,见笑了~

谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-14 14:21:07 | 显示全部楼层

麻烦了,能不能把这贴子删了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-12-14 14:26:46 | 显示全部楼层
一切好的 发表于 2018-12-14 14:21
麻烦了,能不能把这贴子删了。

为什么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-10-25 15:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表