当前位置: 首页 > news >正文

2023美赛C题:Wordle筛选算法

Wordle 规则介绍

Wordle 每天会更新一个5个字母的单词,在6次尝试中猜出单词就算成功。每个猜测必须是一个有效的单词(不能是不能组成单词的字母排列)。

每次猜测后,字母块的颜色会改变,颜色含义如下: 

程序编写

单词数据

Wordle的单词数据直接写在网页源代码里,进入Wordle,按F12查看源代码。 

我们将这些数据提取出来就能的到Wordle单词列表,网上已经有人整理成json文件(点击传送门获取),同时还提出了SOARE是最好的起始词,有兴趣的可查看《The Best Starting Word in WORDLE》

代码编写

获取单词列表之后,就可以开始代码的编写了。 代码的基本思路就是,按照灰色、黄色和绿色三种情况分别处理,排除不符合的单词。

代码编写思路:

  • 包含灰色色块字母的单词排除
  • 不包含黄色色块字母的单词排除
  • 包含黄色色块字母但是还在错误的位置的单词排除
  • 与绿色色块字母位置不符合的单词排除

代码开源在Github:eMUQI/wordle-helper

import jsonwith open("words.json", 'r') as f:data = json.load(f)words = data['words']# 初始化
fault = ""  # 灰色色块
pos_wrong = ["", "", "", "", ""]    # 黄色色块
right = ["", "", "", "", ""]    # 绿色色块
# 提示
print(40*"-")
print("The Best Starting Word in WORDLE may is 'SOARE'")
print("for result, gray:0 yellow:1 green:2")
print(40*"-")for i in range(5):# 处理输入,记录字母guess = input("{0}:".format(i+1))results = input("result:")for n in range(len(results)):if results[n] == "0":fault = fault + guess[n]elif results[n] == "1":pos_wrong[n] = pos_wrong[n] + guess[n]elif results[n] == "2":right[n] = guess[n]else:print("bad input")# 生成建议temp_list = []for word in words:# 检查灰色色块,也就是错误的字母flag = Truefor f in fault:if f in word:flag = Falsebreakif not flag:continuefor n in range(5):# 检查绿色色块,也就是正确的字母,字母和位置是否符合if right[n] != "" and right[n] != word[n]:flag = Falsebreak# 检查黄色色块,也就位置不对的字母if pos_wrong[n] != "":for ps in pos_wrong[n]:# 检查是否有黄色色块字母if ps not in word:flag = Falsebreakelse:#检查是否还在错误的位置if word.index(ps) == n:flag = Falsebreakif not flag:continuetemp_list.append(word)print("suggest:", temp_list)word = temp_list.copy()print(40*"-")

小结

本身写个程序是为了练练手,满足一下写代码的快乐。 经过实际测试,发现基本上到第三轮或者到第四轮猜测,可以选择的单词就非常少了,辅助效果不错。

另外,百万粉数学科普大神3Blue1Brown不光写出了求解算法,还用数学知识一步步优化至逼近理论极限,最终成绩平均3.138次猜测就能获胜,感兴趣的同学可以去找找他的视频,很有启发。 

http://www.lryc.cn/news/9946.html

相关文章:

  • SpringBoot 集成 Kafka
  • OpenCV 图像金字塔算子
  • 【自学Linux】Linux一切皆文件
  • CUDA C++扩展的详细描述
  • 为什么重写equals必须重写hashCode
  • < 每日小技巧:N个很棒的 Vue 开发技巧, 持续记录ing >
  • 数据结构与算法之二分查找分而治之思想
  • 训练自己的中文word2vec(词向量)--skip-gram方法
  • ubuntu系统环境配置和常用软件安装
  • 【1139. 最大的以 1 为边界的正方形】
  • windows11安装sqlserver2022报错
  • Python快速上手系列--日志模块--详解篇
  • 【THREE.JS学习(1)】绘制一个可以旋转、放缩的立方体
  • 数仓实战 - 滴滴出行
  • python虚拟环境与环境变量
  • BeautifulSoup文档4-详细方法 | 用什么方法对文档树进行搜索?
  • 初识Tkinter界面设计
  • 软件测试面试题中的sql题目你会做吗?
  • VS实用调试技巧
  • 通俗易懂理解三次握手、四次挥手(TCP)
  • 1.1 什么是并发
  • 万字讲解你写的代码是如何跑起来的?
  • 034.Solidity入门——21不可变量
  • Vulnhub 渗透练习(四)—— Acid
  • C++ 在线工具
  • 使用MMDetection进行目标检测、实例和全景分割
  • 使用ThreadLocal实现当前登录信息的存取
  • 高通平台开发系列讲解(Android篇)AudioTrack音频流数据传输
  • BUUCTF-firmware1
  • 【C++之容器篇】二叉搜索树的理论与使用