qq_41877813 2018-10-20 07:39 采纳率: 0%
浏览 6428

Java后台如何判断一串数字是否连续,连续合并数字

例如:Integer[] NoNum ={1,2,3,5,7,8,9,10,13}

        输出的结果为 1-3,5,7-10,13
  • 写回答

2条回答

  • threenewbee 2018-10-20 16:16
    关注

    这个简单,写一个状态机搞定:

    state 表示状态,0表示开始状态或者前面的是独立的
    1表示在连续之中
    2表示最后一个
    状态迁移图

    图片说明

    class Untitled {
        public static void main(String[] args) {
            int[] NoNum ={1,2,3,5,7,8,9,10,13};
            int state = 0;
            String result = "";
            for (int i = 0; i < NoNum.length; i++)
            {
                if (i == NoNum.length - 1) state = 2;
                if (state == 0) 
                {
                    if (NoNum[i + 1] == NoNum[i] + 1) 
                    {
                        result += Integer.toString(NoNum[i]);
                        result += "-";
                        state = 1;
                    }
                    else
                    {
                        result += Integer.toString(NoNum[i]);
                        result += ",";
                    }
                }
                else if (state == 1)
                {
                    if (NoNum[i + 1] != NoNum[i] + 1) 
                    {
                        result += Integer.toString(NoNum[i]);
                        result += ",";
                        state = 0;
                    }
                }
                else
                {
                    result += Integer.toString(NoNum[i]);
                }
            }
            System.out.println(result);
        }
    }
    

    上机验证结果:
    1-3,5,7-10,13

    评论

报告相同问题?

悬赏问题

  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序