Letter Combination of a Phone Number

题目描述如下:

 

Given a digit string, return all possible letter combinations that the number could represent.

A mapping of digit to letters (just like on the telephone buttons) is given below.

 

代码如下:

vector<string> letterCombinations(string dig)
{
	vector<string> dict(12);
	dict.push_back("1");
	dict.push_back("abc");
	dict.push_back("def");
	dict.push_back("ghi");
	dict.push_back("jkl");
	dict.push_back("mno");
	dict.push_back("pqrs");
	dict.push_back("tuv");
	dict.push_back("wxyz");
	
	int n = dig.length();
	vector<int> idx(n,0);
	vector<string> ret;
	while(true)
	{
		int i=0;
		string tmp(n);
		for(i=0;i<n;i++)
		{
			tmp[i]=dict[ dig[i]-'0'-1 ][idx[i]];
		}
		ret.push_back(tmp);
		int k=n-1;
		while(k>=0)
		{
			if( idx[k] < dict[ dig[k]-'0'-1]-1)
			{
				idx[k]++;
				break;
			}
			else
			{
				idx[k]=0;
				k--;
			}
		}
		if(k<0)
			break;
	}
	return ret;
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值