问题:
按照手机键盘输入字母的方式,计算所花费的时间
如:a,b,c都在“1”键上,输入a只需要按一次,输入c需要连续按三次。
如果连续两个字符不在同一个按键上,则可直接按,如:ad需要按两下,kz需要按6下
如果连续两字符在同一个按键上,则两个按键之间需要等一段时间,如ac,在按了a之后,需要等一会儿才能按C。
现在假设每按一次需要花费一个时间段,等待时间需要花费两个时间段。
现在给出一串字符,需要计划出它所需要花费的时间。
输入一:bob
输出一:7
输入二:www
输出二:7
解决方法:
所花费的时间我们可以分为两部分,即输入时间与等待时间。我们所要做的就是要分别计算两部分,而第一部分是已经定的根据手机键盘,等待时间要分析前后字母的位置,这个对于具体的前后两个字符而言是一定的。所以这两个操作我们都可以用表格来实现,从而程序的运行达到了线性的复杂度。
代码