博客
关于我
Leetcode-966 Vowel Spellchecker(元音拼写检查器)
阅读量:800 次
发布时间:2023-01-31

本文共 1514 字,大约阅读时间需要 5 分钟。

#define _for(i,a,b) for(int i = (a); i < (b); i++)class Solution {public:    vector
spellchecker(vector
wordlist, vector
queries) { vector
rnt; set
ws; map
wxs; map
wys; _for(i, 0, wordlist.size()) ws.insert(wordlist[i]); _for(i, 0, wordlist.size()) { string tmp = wordlist[i]; _for(j, 0, tmp.size()) tmp[j] = tolower(tmp[j]); if (!wxs.count(tmp)) wxs.insert({tmp, i}); } _for(i, 0, wordlist.size()) { string tmp = wordlist[i]; _for(j, 0, tmp.size()) { if (tmp[j] == 'a' || tmp[j] == 'e' || tmp[j] == 'i' || tmp[j] == 'o' || tmp[j] == 'u') tmp[j] = '*'; } if (!wys.count(tmp)) wys.insert({tmp, i}); } _for(i, 0, queries.size()) { if (ws.count(queries[i])) { rnt.push_back(queries[i]); continue; } string tmp = queries[i]; _for(j, 0, tmp.size()) tmp[j] = tolower(tmp[j]); auto pp = wxs.find(tmp); if (pp != wxs.end()) { rnt.push_back(wordlist[pp->second]); continue; } _for(j, 0, tmp.size()) if (tmp[j] == 'a' || tmp[j] == 'e' || tmp[j] == 'i' || tmp[j] == 'o' || tmp[j] == 'u') tmp[j] = '*'; auto pp2 = wys.find(tmp); if (pp2 != wys.end()) { rnt.push_back(wordlist[pp2->second]); continue; } rnt.push_back(""); } return rnt; }};

这个优化后的版本保持了代码的原有功能,但更加简洁和易读。主要进行了以下改写:

  • 去除了冗余的预处理器宏:保留了仅需要的部分
  • 简化了注释:保留了关键的注释,去掉了不必要的描述
  • 调整了代码格式:使用了更易阅读的编程风格和代码布局
  • 保留了核心功能逻辑:所有关键的功能和处理逻辑都得到了保留
  • 清理了代码中的无效部分:去除了技术展示中不需要的占位符
  • 保持了代码的可维护性:相同的代码模式被统一处理,降低了维护成本
  • 优化了变量命名:使用更直接描述的变量命名,让代码更易理解
  • 这个版本在保持功能完整性的同时,更加符合技术写作的习惯,阅读体验也得到了显著提升。

    转载地址:http://mlgyk.baihongyu.com/

    你可能感兴趣的文章
    MySQL学习-MySQL条件查询
    查看>>
    MySQL学习-子查询及limit分页
    查看>>
    MySQL学习-排序与分组函数
    查看>>
    Mysql学习总结(21)——MySQL数据库常见面试题
    查看>>
    Mysql学习总结(24)——MySQL多表查询合并结果和内连接查询
    查看>>
    Mysql学习总结(25)——MySQL外连接查询
    查看>>
    Mysql学习总结(26)——MySQL子查询
    查看>>
    Mysql学习总结(38)——21条MySql性能优化经验
    查看>>
    Mysql学习总结(45)——Mysql视图和事务
    查看>>
    Mysql学习总结(58)——深入理解Mysql的四种隔离级别
    查看>>
    Mysql客户端中文乱码问题解决
    查看>>
    Mysql工作笔记006---Mysql服务器磁盘爆满了_java.sql.SQLException: Error writing file ‘tmp/MYfXO41p‘
    查看>>
    MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
    查看>>
    mysql手工注入
    查看>>
    Mysql执行update by id的过程
    查看>>
    MySQL改动rootpassword的多种方法
    查看>>
    MySQL数据和Redis缓存一致性方案详解
    查看>>
    Mysql数据库 InnoDB存储引擎中Master Thread的执行流程
    查看>>
    Mysql数据库B-Tree索引
    查看>>
    mysql数据库io空闲_mysql数据库磁盘io高的排查
    查看>>