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

【算法】九键输入法

题目:

输入数字字符串, 输出这串字符对应的九键输入法有可能出现的所有情况

算法:

  • 定义了一个全局变量 g_numStr,其中存储了每个数字对应的字母。
  • 定义了一个递归函数 str_combine,用于将每个数字对应的字母进行组合。
  • str_combine 函数接受四个参数:digits 表示输入的数字字符串,i 表示当前处理的数字在 digits 中的下标,vCombine 表示存储所有字母组合结果的 vector,tmp 表示当前已经组合好的字母。
  • i 的值等于 digits 的长度时,说明所有数字已经被处理完,将当前的组合结果 tmp 存入 vCombine 中,并返回。
  • for 循环中,枚举当前数字对应的所有字母,对每个字母进行递归处理。在递归调用中,将当前字母加入到 tmp 中,将 i 加一,继续处理下一个数字。
  • main 函数中,先读入输入的数字字符串,然后调用 letter_comvibinations 函数获取所有字母组合结果,并将结果输出到屏幕上。

源码:

#include <iostream>
#include <vector>
#include <string>
using namespace std;vector<string> g_numStr = { "", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz" };void str_combine(string digits, int i, vector<string>& vCombine, string tmp)
{if (i == digits.size()){vCombine.push_back(tmp);return;}for (auto ch : g_numStr[digits[i] - '0']){str_combine(digits, i + 1, vCombine, tmp + ch);}
}vector<string> letter_comvibinations(string digits)
{vector<string> vCombine;str_combine(digits, 0, vCombine, "");return vCombine;
}int main()
{string digits;cin >> digits;vector<string> vCombine = letter_comvibinations(digits);for (auto& e : vCombine){cout << e << " ";}cout << endl;return 0;
}

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

相关文章:

  • jvm之类加载器
  • Chapter4:频率响应法(上)
  • 【6. 激光雷达接入ROS】
  • Java 基础进阶篇(三)—— 面向对象的三大特征之二:继承
  • [angstromctf 2023] 部分
  • 死信队列
  • 基于YOLOv5的目标检测系统详解(附MATLAB GUI版代码)
  • 使用ChatGPT工具阅读文献的实战教程
  • 实训笔记1
  • CCD视觉检测设备如何选择光源
  • 基于协同过滤的旅游推荐系统设计与实现(论文+源码)_kaic
  • 代码随想录补打卡 746 使用最小花费爬楼梯
  • 有理函数的不定积分习题
  • PS滤镜插件-Nik Collection介绍
  • 力扣刷题2023-05-04-1——题目:2614. 对角线上的质数
  • 【Java笔试强训 2】
  • 术数基础背诵口诀整理
  • Linux 基础语法 -2
  • 深度学习框架发展趋势
  • Mysql为json字段创建索引的两种方式
  • cassandra数据库入门-4
  • 微服务学习——分布式搜索
  • ChatGPT根据销售数据、客户反馈、财务报告,自动生成报告,并根据不同利益方的需要和偏好进行调整?
  • Flask开发之环境搭建
  • Java集合框架与ArrayList、LinkedList的区别
  • python-pandas库
  • C++学习day--01 C生万物
  • 链表及链表的常见操作和用js封装一个链表
  • 源码安装工具checkinstall使用
  • 离散数学集合论