在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問(wèn)答/Java  PHP  C++  GO  HTML/ 計(jì)算一組數(shù)字是否順子問(wèn)題

計(jì)算一組數(shù)字是否順子問(wèn)題

規(guī)則: 比如1,2,3,4,5 / 4,5,1,2,3/ 2,3,4,5,1 /
5,1,2,3 ,這里最大值是5,最小值是1,逢5就到1了,滿足這樣條件就算順子

回答
編輯回答
她愚我

1.如果有固定位數(shù),并且不太多的話,你可以先把所有滿足的結(jié)果列舉出來(lái),存在一個(gè)數(shù)組里,然后用需要判斷的變量與數(shù)組里的每一項(xiàng)比較。
2.如果不想列舉的話,臥槽,兄弟你這規(guī)則有點(diǎn)奇怪啊,什么鬼都能叫順子嗎~~

2017年8月28日 21:37
編輯回答
絯孑氣

重新編輯了:

public static boolean isStraight(int[] num, int min, int max) {
    Arrays.sort(num);
    int i;
    for (i = 1; i < num.length; i++) {
        if (num[i] - num[i - 1] != 1) {
            break;
        }
    }
    if (i == num.length) {
        return true;
    }
    for (i = i + 1; i < num.length; i++) {
        if (num[i] - num[i - 1] != 1) {
            return false;
        }
    }
    if (num[num.length - 1] == max && num[0] == min) {
        return true;
    }
    return false;
}

public static void main(String[] args) {
    System.out.println(isStraight(new int[]{1,2,3,5},1,5));
}
2017年4月13日 12:34
編輯回答
未命名
arr.sort((a,b)=>a-b);
arr.every((t,i)=>{
    return i==0?true:t-arr[i-1]==1?true:false
})

更新

//參數(shù),數(shù)組范圍最小值,范圍最大值
var mtest = function(min,max){
    //這里min,max代表順子的最大值與最小值,確定一個(gè)邊界,如1-5
    return arr=>{
        arr.sort((a,b)=>a-b);
        //如果數(shù)組最大值超過(guò)設(shè)定的最大值max,返回錯(cuò)誤提醒
        if(arr[arr.length-1]>max){
            alert("數(shù)組元素最大值超過(guò)預(yù)期,錯(cuò)誤");
            return false;
        }
        var b = arr.every((m,n)=>n==0?true:m-arr[n-1]==1?true:false);
        if(b)return true;//如果傳進(jìn)來(lái)的數(shù)組本身是[2,3,4]這樣的連續(xù)遞增的數(shù)據(jù),返回true
        //走到這里,索命傳進(jìn)來(lái)的數(shù)據(jù)不是連續(xù)的,那么可以判斷沒有的數(shù)據(jù)是不是連續(xù)的
        //把1-5這幾個(gè)元素看成一個(gè)圓環(huán),取環(huán)上一段連續(xù)的數(shù)據(jù),那么剩下的數(shù)據(jù)也必然是連續(xù)的
        var arr1 = [];
        //從[1,2,3,4,5]中檢測(cè)[1,5,2]少了哪些數(shù)據(jù)
        for(var i=min;i<max+1;i++){
            arr.indexOf(i)<0 && arr1.push(i)
        }
        //arr1得到[3,4],然后檢測(cè)arr1是不是連續(xù)的
        return arr1.every((t,i)=>i==0?true:t-arr1[i-1]==1?true:false)
    }    
}(1,5);

mtest([1,5,2])
mtest([1,5,2,6])
mtest([3,2,4])
2018年4月12日 18:20