gpt4 book ai didi

c# - 将列表转换为数字范围字符串

转载 作者:可可西里 更新时间:2023-11-01 08:05:35 27 4
gpt4 key购买 nike

这个问题几乎与这个问题相反: Does C# have built-in support for parsing page-number strings?

给定

1,3,5,6,7,8,9,10,12:

我会输出:

1,3,5-10,12

这是我的第一次尝试。它看起来有点老套,可能是我写过的最糟糕的代码。您能建议改进\更好的方法吗?

static string numListToRangeStr(List<int> numList)
{
StringBuilder retString = new StringBuilder();
numList.Sort();

bool inRangeFind = false;
int firstInRange = numList[0];
int lastNumber = firstInRange;
bool first = true;

for (int i = 1; i < numList.Count; i++)
{
if (numList[i] == (lastNumber + 1))
{
inRangeFind = true;
}
else
{
if (inRangeFind)
{
if (!first)
{
retString.Append(",");
}
retString.Append(firstInRange);
retString.Append("-");
}
else
{
if (!first)
{
retString.Append(",");
}
}

retString.Append(lastNumber);

firstInRange = numList[i];
inRangeFind = false;
first = false;
}

lastNumber = numList[i];
}


if (inRangeFind)
{
if (!first)
{
retString.Append(",");
}
retString.Append(firstInRange);
retString.Append("-");
}
else
{
if (!first)
{
retString.Append(",");
}
}
retString.Append(lastNumber);

return retString.ToString();
}

最佳答案

当一个东西有多个像这样的移动部分时,我认为将它分解成小的逻辑单元然后将它们组合在一起会很有帮助。小逻辑单元甚至可以单独使用。下面的代码将问题分解为:

  • 将异构的连续和非连续数字集转换为同质范围集(可能包括以相同数字开始和结束的“退化”范围)
  • 一种“ pretty-print ”此类范围的方法:(x,y) 打印为“x-y”; (x,x) 打印为“x”
  • 一种在可枚举元素之间插入分隔符并将结果转换为字符串的方法。

程序是:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace ConsoleApplication37 {
public static class Program {
static void Main(string[] args) {
var numList=new[] {1, 3, 5, 6, 7, 8, 9, 10, 12};
Console.WriteLine(numListToPossiblyDegenerateRanges(numList).Select(r => PrettyRange(r)).Intersperse(","));
}

/// <summary>
/// e.g. 1,3,5,6,7,8,9,10,12
/// becomes
/// (1,1),(3,3),(5,10),(12,12)
/// </summary>
public static IEnumerable<Tuple<int,int>> numListToPossiblyDegenerateRanges(IEnumerable<int> numList) {
Tuple<int, int> currentRange=null;
foreach(var num in numList) {
if(currentRange==null) {
currentRange=Tuple.Create(num, num);
} else if(currentRange.Item2==num-1) {
currentRange=Tuple.Create(currentRange.Item1, num);
} else {
yield return currentRange;
currentRange=Tuple.Create(num, num);
}
}
if(currentRange!=null) {
yield return currentRange;
}
}

/// <summary>
/// e.g. (1,1) becomes "1"
/// (1,3) becomes "1-3"
/// </summary>
/// <param name="range"></param>
/// <returns></returns>
public static string PrettyRange(Tuple<int,int> range) {
if(range.Item1==range.Item2) {
return range.Item1.ToString();
}
return string.Format("{0}-{1}", range.Item1, range.Item2);
}

public static string Intersperse(this IEnumerable<string> items, string interspersand) {
var currentInterspersand="";
var result=new StringBuilder();
foreach(var item in items) {
result.Append(currentInterspersand);
result.Append(item);
currentInterspersand=interspersand;
}
return result.ToString();
}
}
}

关于c# - 将列表转换为数字范围字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7688881/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com