【2019工研/模拟】九键输入法(巧用数组)

该博客介绍了一个模拟老式手机输入的程序,通过接收一串包含数字和等待间隔的输入,根据九宫格键盘布局输出对应的字母。程序利用C++实现,通过遍历输入字符串并统计连续数字出现的次数来确定应输出的字母。例如,输入'2222------55'将输出'AK'。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、题目:

模拟老式手机输入,九宫格布局如下:
题目输入为数字或者’-’,其中‘-’代表手机输入时等待的时间间隔,数字表示点击某
个按键的次数。比如点击两次 2,则输出为 B,四次 2,则输出为 A。

输入:
255
输出:
AK
输入(等待间隔‘-’可以无限长,也可以没有):
2222------55
输出:
AK

2、思路

  • 对于不知道长度的字符串,最好定义为string类型,然后cin>>str
  • cnt定义在循环内,既可以控制i的前进步伐,也可以统计重复字符数,很巧妙!!
#include<iostream>
#include<string>
using namespace std;
int main() {
	string str;
	char mp[10][4] = { {},{},{'A','B','C'},{'D','E','F'},{'G','H','I'},{'J','K','L'},{'M','N','O'},{'P','Q','R','S'},{'T','U','V'},{'W','X','Y','Z'} };
	int i = 0;
	cin >> str;
	while (i < str.length()) {
		int cnt=1;
		int j = i;
		while (str[j] == str[j + 1] && str[j] >= '0'&&str[j] <= '9') {
			cnt++;
			j++;
		}
		if (str[i] == '7' || str[i] == '9')
			cout << mp[str[i] - '0'][(cnt - 1) % 4];
		else if(str[i] >= '0'&&str[i] <= '9'&&str[i] != '7'&&str[i] != '9')
			cout << mp[str[i] - '0'][(cnt - 1) % 3];
		i += cnt;
	}
	system("pause");
	return 0;
}

独立完成项目-----T9输入法模拟器 本来这是老师给我们尖子小组三个人的一个合作挑战项目 但是我自己想了想 结构和原理按我的思路应该是可以行的通的 和他们俩住的远 也没得商量 思路上来就自己搞完了 项目名:手机T9输入法模拟器 参加人员:小枪 开发平台:window XP 开发具:visual studio 2005 , sqlserver 2005 重点要点:全程数据库操作语句 全部采用 执行存储过程 模拟手机拼音输入法 如:2建代表 “abc” 贯彻三层结构数据理念 按不同的组织成不同的拼音组合 再根据这些拼音组合查询数据库 列出所有符合按拼音组合的汉字 这个地方相对我们在校的学生应该是比较有挑战的 总结思路 主要的思路构造就是全局做一个list将当前的所有能拼出来的拼音组合存起来 按下一个按就把它全拆开挨个拼出新的组合 然后将全局的list再用我们新拼的组合来替换掉 替换前要记得清掉我们listviwe 里的所有字和拼音 我觉得难的地方在于那个返回 也就是退格 它要干的事就是返回我们的上一个步骤 这里我处理手段使用的是以前依稀记得的冒泡排序 和list的rmove 来挨个处理 先把前面按组成的所有拼音组合挨个拿出来退一个字符 然后把第一个和所有集合中所有的拼音组合相比 有相同的就去掉 集合中原先第2个组合就成了现在的第一个组合 再把它拿出来挨个比较... 想了好久 靠 确实有点抽象了 说都有点说不明白 真不知道我们那班同学怎么去理解 字库问题 :还有就是字库的问题 据我所知汉字字库大概几千字 还是多少个来着 要做模拟器就得先做字库 这就有点麻烦了 一个一个的添显然麻烦 我偷了个懒 做俩个表 第一个表是我们的汉字表 包含两个字段: 汉字字符 和 我们的拼音外 (因为一个拼音组合可能会有几十或上百的同音字) 第二个表就是我们的拼音表 这样查询的时候也简单 根据拼音父建直接可以查到这个拼音组合下所有的同音字 为了字库入库方便 我顺便还写了一个入库具 呵呵 这个就比较简单了 输入流 把同一个拼音组合的汉字放一个文本中 然后把这个文本中这些汉字做成一个数组 加的时候等于说一次就加一个拼音组合的汉字 怎么样 思路还算可以吧 呵呵 字库未加完 我这里带上字库 自己加进去吧 呵呵这样应该可以交差了 在校学生: 小枪
对于想要了解北京理大学软件程专业硕士究经验的学生来说,可以参考以下几个方面来获取相关信息: 查找论坛和社交平台上的帖子 许多经历过考或者正在准备考的同学会在知乎、贴吧等平台上分享自己的备考经验和心得。这些真实的经历往往包含了从复习计划制定到最终录取的全过程。 关注学校官方资源及校友网络 北京理大学官方网站以及相关的教育机构网站可能会发布一些成功案例究或是毕业生故事。此外,加入北理大的校友会或联系在校生也能获得一手的信息和支持建议。 阅读学术文献与毕业设计作品 通过中国知网(CNKI)或其他数据库查询往届学生的学位论文摘要,这有助于理解不同方向的究热点和发展趋势;同时也可以了解到具体项目的实施过程和技术细节。 参加线上线下的交流活动 留意是否有针对目标院校专业的讲座、讨会等活动通知,这类场合通常会有教授介绍学科特色并且邀请优秀学子讲述个人成长路径。 以下是几个可能帮助找到更多有关于北京理大学软件程专业硕士究经验的具体来源: - 究生院官网发布的招生简章里有时也会附带对各专业的详细介绍; - 学校BBS如水木社区中的“理科讨论区”,这里聚集了很多计算机类专业的同学; - 微信公众号搜索关词“北理+软途”等相关表述也可能发现不少有价值的推送文章。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值