我有一个问题,我需要一些帮助才能搞清楚。我希望能得到一些关于更好地接近我正在做的事情的指示。我的主要问题是下面几行(//这是什么让我感到困惑)并在页面底部进行了描述。
我需要排列电话号码的所有可能结果:(不仅仅是字典单词)
即。 222-2222
应输出一个3 ^ 7长的列表,其中包含a,b,c
的所有可能排列即
AAAAAAA
AAAAAAB
AAAAAAC
AAAAABA // THIS IS WHATS HANGING ME UP
AAAAABB
AAAAABC
AAAAACA // HERE TOO AND SO ON
我的代码(故意缩短以进行测试)GIVES ME:
AAAA
AAAB
AAAC
AABC
AACC
ABCC
ACCC
BCCC
CCCC
我是一名初学编程学生,所以我的知识可以用于,而if,if,语句和从数组中获取单个字符。
以下是我的代码到目前为止的样子:(这是函数的一部分。代码缺失)
char alphaFunc(char n []){
int d1=n[0]-48;
int d2=n[1]-48;
int d3=n[2]-48;
int d4=n[3]-48;
int d5=n[4]-48;
int d6=n[5]-48;
int d7=n[6]-48;
int a=0,b=0,c=0,d=0,e=0,f=0,g=0;
int i=0;
char charArray[10][4]={ {'0','0','0'},{'1','1','1'},{'A','B','C'},
{'D','E','F'},{'G','H','I'},{'J','K','L'},{'M','N','O'},
{'P','R','S'},{'T','U','V'},{'W','X','Y'} };
while(i <=14){
printf("%c%c%c%c\n", charArray[d1][a],
charArray[d2][b],charArray[d3][c],charArray[d4][d],
charArray[d5][e],charArray[d6][f],charArray[d7][g]);
g++;
if(g==3){
g=2;
f++;
}
if(f==3){
f=2;
e++;
}
if(e==3){
e=2;
d++;
}
我并不是在寻找有人为我做这件事我只需要一点帮助就可以确定当你有一个数字到达CharArray [d - ] [a]位置时哪种语句会起作用b / c [3]并将其重置为[0],它会将您发送到循环的不同部分。 (希望这很有意义)。
答案 0 :(得分:1)
由于charArray
的值是常量,我建议将其作为全局变量,而不是在函数中声明它。此外,由于某些数字有4个字母,而其他数字有3个,您可能需要考虑使用jagged array来表示它。
就打印您可以通过电话号码获得的排列而言,我认为递归将成为您的朋友。假设您可以将电话号码存储在一个int数组中,以下内容应该有效:
public void printPermutations(int[] phoneNumber)
{
printPermutations(phoneNumber, 0, String.Empty);
}
private void printPermutations(int[] phoneNumber, int index, string permutation)
{
if(index >= phoneNumber.Length)
{
// If we've reached the end, print the number
printf(permutation + "\n");
}
else
{
// Otherwise, generate a permutation for each
// character this digit can be
int digit = phoneNumber[index];
char[] chars = charArray[digit];
for (int i = 0; i < chars.Length; i++)
{
printPermutations(phoneNumber, index+1, permutation + chars[i]);
}
}
}