当前位置:编程学习 > C#/ASP.NET >>

如何判断一组号码中是否有连续5次以上的连号,并删除

比如文本中有一组数字:
1001
1002
1007
2001
2002
2003
2004
2005
2006

1067
1099

其中2001-2006超过5组的连续数据,如何编程判断并删除 --------------------编程问答-------------------- 循环。用个arraylist,如果两个数字相邻就写入,arraylist.count>5就... --------------------编程问答-------------------- 用 正则表达式 --------------------编程问答-------------------- 循环一次,然后使用字典来存放编号和他出现的次数,泛型字典
Dictionary<string, int> dic = new Dictionary<string, int>(); --------------------编程问答-------------------- 1,将数字全排序。
2,遍历原数组
3,当指向第N个数字array[n]的时候,看一下a[n+5] == a[n] + 5
   如果是,则删除a[n] ~ a[n+5]

如果是删除所有相连数字,要增加循环处理后面的“5”,让他自增到不满足条件或到末尾为止

--------------------编程问答-------------------- 学习ing --------------------编程问答-------------------- string [] stringArray=new string(.....)//用于存放需要判断的队列

string [] stringArray_new = new string[90];//用于存放判断后的队列。

int j=0;//计数器
int num = stringArray[0].toInt();//前一个数
int num2 = stringArray[1].toInt();//后一个数

int k=0;//用于结果数组的下标。


for (int i=0;i < stringArray.length -1 ; i++)
{
   // 判断相邻两个数据是否连号
   if (num2 == (num + 1))
   {
      j = j + 1;
   }
   else
   {
      j = 0;     
   }
   //取下一个数。
   num = stringArray[i + 1].toInt();
   num2 = stringArray[i + 2].toInt();

   //如果连号,并连号超过五个数,结果数组下标回拨5,
   if (j > 5)
   {
      k = k -5;
   }
   else
   {
      stringArray_new[k] = stringArray[i];
   }
              
}


以上代码未经测试,仅是思路供参考。 --------------------编程问答-------------------- 不考虑文件操作部分,仅从算法的角度的话,仅仅是一个思路,没有验证


public static List<int> ModifyList(int List<int> source)

{
List<int> result=new List<int>();
int LineNum=0;

while(true)
{
List<int> tempList=new List<int>();
Floater=LineNum;
tempList.Add(source[LineNum]);
while( LineNum<=source.Count-2)

if(source[LineNum]++== source[LineNum++])
tempList.Add(source[LineNum]);
else
{
 break;
 if( LineNum-Floater<5)
AppendToFinalList(tempList,result);
 }

}


if(LineNum==source.Count-1)
break;

}
return result;

} --------------------编程问答-------------------- 谢谢 楼上朋友们的方法 我试试
补充:.NET技术 ,  C#
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,