福如东海寿比南山 2017-12-02 15:24 采纳率: 0%
浏览 4213

有个问题,如何判断一个数组是否已经排好序?

自己想了一下,假如说,用下面的这个
public int check(int[] array)
{
int count = 0;//用来判断该数组是顺序排序还是逆序排序

for (int i = 0; i < array.length - 1; i++)
{
    if ( array[i] < array[i + 1])
    {
        count++;
    }

}

if ( count == array.length - 1)
{
    //返回1为正序,从小到大
    return 1;
}
else if (count > 0 && count < array.length - 1)
{

    return 0;
}
else
{
    //返回-1为逆序,从大到小
    return -1;
}

}

虽然确实是可以判断出来,但是如果错乱的位置刚好是那个数组的最后两位,例如:{1, 2, 3, 4, ..., 101,100}就感觉很尴尬,有没有好的方法?

  • 写回答

1条回答 默认 最新

  • threenewbee 2017-12-02 15:52
    关注
     public int check(int[] array)
    {
    if (array.size() < 2) return 1;
    int b =array[0] < array[1] ? 1 : -1;
    for (int i = 1; i < array.size(); i++)
    {
    if (b == 1 && array[i] > array[i - 1]) return 0;
    if (!b == -1 && array[i] < array[i - 1]) return 0;
    }
    return b;
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?