字符组数的不重复组合方法

字符组数的不重复组合方法
namespace KeyWordSplit
{
class Program
{

private static string[] KeyWord { get; set; }

public static void Main(string[] args)
{
KeyWord = new string[] { "我", "是", "你", "老", "板" };
foreach (string str in GetKeyWordCollection())
{
Console.WriteLine(str);
}
Console.ReadLine();
}

private static List<string> GetKeyWordCollection()
{
List<String> result = new List<string>();
string index = CharArrayToString(new char[KeyWord.Length]);
while (true)
{
List<string> tmp = new List<string>();
index = CalculationNextKeyWord(index);
if (Convert.ToInt32(index) == 0) break;
char[] ch = index.ToString().ToCharArray();
for (int i = 0; i < ch.Length; i++)
{
if (!tmp.Contains(KeyWord[Convert.ToInt32(ch[i].ToString())]))
tmp.Add(KeyWord[Convert.ToInt32(ch[i].ToString())]);
else
{
tmp = null;
break;
}
}
if (tmp != null)
result.Add(ListToString(tmp));
}
return result;
}

private static string CalculationNextKeyWord(string keyWordIndex)
{
char[] keyWordArr = keyWordIndex.ToCharArray();
int index = keyWordArr.Length;
while (index-- > 0)
{
int num = Convert.ToInt32(keyWordArr[index].ToString());
if (num + 1 >= keyWordArr.Length)
{
keyWordArr[index] = '0';
continue;
}
else
{
int current = Convert.ToInt32(keyWordArr[index].ToString());
keyWordArr[index] = (current + 1).ToString().ToCharArray()[0];
break;
}
}
return CharArrayToString(keyWordArr);
}

private static string ListToString(List<string> array)
{
StringBuilder sb = new StringBuilder();
foreach (string str in array)
{
sb.Append(str);
}
return sb.ToString();

}

private static string CharArrayToString(char[] array)
{
StringBuilder sb = new StringBuilder();
foreach (char ch in array)
{
if (ch == 0)
sb.Append("0");
else
sb.Append(ch.ToString());
}
return sb.ToString();
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值