我有一个
List<String> MyList=new List<string>();
我需要用n值填充列表MyList.
如果n的值是2,则列表MyList将包含
"A","B"
如果10那么
"A","B","C"....."J"
如果30那么
"A"....."Z","AA","AB",AC","AD"
如果1000那么
"A",....."Z","AB"......"AZ","BA","BB"......."BZ"........"YZ","AAA",AAB"..... and so on
我不知道该怎么做.
请帮助我使用LINQ或LAMBDA Expression的任何方法执行此操作
解决方法
编辑2:
这可能是实现它的最简单方法.我测试过,它工作正常.您可以生成无限数量的字符串.
public IEnumerable<string> GenerateStrings() { foreach(string character in Alphabet()) { yield return character; } foreach (string prefix in GenerateStrings()) { foreach(string suffix in Alphabet()) { yield return prefix + suffix; } } } public IEnumerable<string> Alphabet() { for(int i = 0; i < 26; i++) { yield return ((char)('A' + i)).ToString(); } }
我之前写过的东西:
您还可以编写一个小的递归函数,它通过某个索引返回任何字符串.这可能不是最佳的性能,因为存在一些重复的划分,但它可能足够快以达到您的目的.
这很简单:
string GetString(int index) { if (index < 26) { return ((char)('A' + index)).ToString(); } return GetString(index / 26 - 1) + GetString(index % 26); }
List<string> strings = Enumerable.Range(0,1000) .Select(x => GetString(x)) .ToList();
这是工作代码,只是为它编写了一个测试.
编辑:例如,GetString的“完整linq方式”应用程序:
public void IEnumerale<string> GenerateStrings() { int index = 0; // generate "infinit" number of values ... while (true) { // ignoring index == int.MaxValue yield return GetString(index++); } } List<string> strings = GenerateStrings().Take(1000).ToList();