Java代码

public class Arr_Algorithms {

    public String findMinMax(int[] arr){
        int min = arr[0];
        int max = arr[0];
        String result = "";

        for(int i = 0; i < arr.length; i++){
            if(arr[i] < min)
                min = arr[i];
            if(arr[i] > max)
                max = arr[i];
        }
        result = "MIN:" + min + " Max:" + max;
        return result;
    }

    public String CalculateSum(int[] arr){
        int sum=0;
        for(int i:arr)
            sum+=i;
        double average= (double)sum/arr.length;

        int mode=arr[0];
        int Maxcount=1;
        for(int num:arr){
            int count=0;
            for(int n:arr){
                if(n==num)
                    count++;
            }
            if(count>Maxcount){
                Maxcount=count;
                mode=num;
            }
        }
        return "sum: "+sum+" average: "+average+ " mode: "+mode;

    }
    
    public String Even(int[] arr){
        boolean hasEven=false;
        for(int i:arr){
            if(i%2==0){
                hasEven=true;
            }
        }
        return hasEven?"true":"false";
    }

    public String CheckAllEven(int[] arr){
        boolean alleven=true;
        for(int num:arr){
            if(num%2==1)
                alleven=false;
        }
        return alleven?"true":"false";

    }

    public String Consecutive(int[] arr){
        int n=arr.length;
        //排序
        for(int i=0;i<n-1;i++){
            for(int j=0;j<n-i-1;j++){
                if(arr[j]>arr[j+1]){
                    int temp=arr[j];
                    arr[j]=arr[j+1];
                    arr[j+1]=temp;
                }
            }
        }
        boolean result=true;
        for(int i=1;i<arr.length;i++){
            if(arr[i]-arr[i-1]!=1)
                result=false;
        }
        return result?"true":"false";
    }

    public String duplicate(int[] arr){
        boolean result=false;
        for(int i=1;i<arr.length;i++){
            if(arr[i]-arr[i-1]==1)
                 result=true;
        }
        return result?"Yes,Array has duplicate elements":"No,Array has no duplicate elements";
    }

    public int[] ReverseArr(int[] arr){
        int back=arr.length-1;
        for(int front=0;front<arr.length/2;front++){
            int temp=arr[front];
            arr[front]=arr[back];
            arr[back]=temp;
            back--;
        }
        for(int num:arr){
            System.out.printf(num+" ");
        }
        System.out.println(" ");
        return arr;
    }

    public int[] shiftRight(int[] arr){
        int x=arr[arr.length-1];
        for(int i=0;i<arr.length;i++){
            int temp=arr[i];
            arr[i]=x;
            x=temp;
        }
        for(int i:arr){
            System.out.printf(i+" ");
        }
        return arr;
    }


    //main
    public static void main(String[] args) {
        Arr_Algorithms d1 = new Arr_Algorithms();
        int[] numbers1 = {1, 1, 5, 3, 2, 4, 7, 8, 9, 10};
        System.out.println(d1.findMinMax(numbers1));
        int[] numbers2={1,1,2,2,3,3,3,3,3,3,4,4};
        System.out.println(d1.CalculateSum(numbers2));
        int[] numbers3={1,2,3,5};
        System.out.println(d1.Even(numbers3));
        int[] numbers4={2,4,6,8,4};
        System.out.println(d1.CheckAllEven(numbers4));
        int[] numbers5={47,43,44,45,46};
        System.out.println(d1.Consecutive(numbers5));
        int[] numbers7={1,2,3,4,4};
        System.out.println(d1.duplicate(numbers7));
        int[] numbers8={1,2,3,4,5};
        d1.ReverseArr(numbers8);
        int[] numbers9={1,2,3,4,5};
        d1.shiftRight(numbers9);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值