复制代码
public class SmallSum {

   public static int sum=0;
        public static void main(String[] args) {
            //int[] arr={1,3,4,2,5};
            int[] arr={1,3};
            process(arr,0,arr.length-1);
            for (int i1 : arr) {
                System.out.println(i1);
            }
            System.out.println("小和为:"+sum);
        }
        public static int process(int[] arr,int l,int r) {
            if (l==r) return 0;
            int mid=l+((r-l)>>1);
            return process(arr,l,mid)+
            process(arr,mid+1,r)+
            merge(arr,l,mid,r);
        }

        public static int  merge(int[] arr,int l,int mid,int r) {

            int[] help=new int[r-l+1];
            int i=0;
            int p=l;
            int q=mid+1;
            while(p<=mid&&q<=r)
            {
                sum+=arr[p]<arr[q]?(r-q+1)*arr[p]:0;
                help[i++]=arr[p]<arr[q]?arr[p++]:arr[q++];


            }
            while(p<=mid){
                help[i++]=arr[p++];
            }
            while (q<=r){
                help[i++]=arr[q++];
            }
            for (int i1 = 0; i1 < help.length; i1++) {
                arr[l+i1]=help[i1];
            }
            return sum;

    }

}
复制代码

 

posted on   upupup-999  阅读(24)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!



点击右上角即可分享
微信分享提示