黑马程序员技术交流社区
标题:
打印出一个字符串可拆分的所有结果
[打印本页]
作者:
时光♪微凉
时间:
2014-4-27 23:05
标题:
打印出一个字符串可拆分的所有结果
本帖最后由 时光♪微凉 于 2014-5-6 19:27 编辑
例如:原始字符串是"abc",打印得到下列所有组合情况:
"a" "b" "c"
"ab" "bc" "ca" "ba" "cb" "ac"
"abc" "acb" "bac" "bca" "cab" "cba"
作者:
时光♪微凉
时间:
2014-4-28 07:09
路过的大神们,解救啊!
作者:
۩大世界小人物
时间:
2014-5-14 21:39
利用全排列算法试试!
作者:
۩大世界小人物
时间:
2014-5-14 23:32
public class Test
{
public static void main(String args[])
{
String str = "abc";
char[] a = str.toCharArray();
sort(a, 0);
System.out.println("---------------------");
for(int i=0; i<str.length(); i++)
{
a = subString(str, i).toCharArray();
sort(a, 0);
System.out.println("--------------------");
}
}
//删除一个字符串中的第i个字母 返回一个新的字符串
static String subString(String str, int i)
{
if(i>0)
{
str = str.substring(0, i) + str.substring(++i, str.length());
return str;
}
else
return str.substring(++i, str.length());
}
static void sort(char[] str,int index)
{
int i;
if (index == str.length)
{
for (i = 0; i < str.length; i++)
{
System.out.print(str[i]);
}
System.out.println("");
return;
}
for (i = index; i < str.length; i++)
{
//交换字符
char temp;
temp = str[index];
str[index] = str[i];
str[i] = temp;
sort(str, index + 1);
temp = str[index];
str[index] = str[i];
str[i] = temp;
}
}
}
复制代码
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2