微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在C#中获取连续字符?

我有一个
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();

原文地址:https://www.jb51.cc/csharp/98478.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐