Count of Smaller Numbers After Self (二分插入法)

 

You are given an integer array nums and you have to return a new counts array. The counts array has the property where counts[i] is the number of smaller elements to the right of nums[i].

Example:

Input: [5,2,6,1]
Output: [2,1,1,0] 
Explanation:
To the right of 5 there are 2 smaller elements (2 and 1).
To the right of 2 there is only 1 smaller element (1).
To the right of 6 there is 1 smaller element (1).
To the right of 1 there is 0 smaller element.

//Input: [5,2,6,1]
        //Output: [2,1,1,0]
        public static int[] CountSmaller(int[] nums)
        {
            List<int> sortList = new List<int>();
            int[] returnArr = new int[nums.Length];
            for (int i = nums.Length - 1; i >= 0; i--)
            {
                int beginIndex = 0;
                int endIndex = sortList.Count - 1;
                int insertIndex = 0;
                
                while (beginIndex <= endIndex)
                {
                    int mid = (beginIndex + endIndex) / 2;
                    if (nums[i] < sortList[mid])
                    {
                        endIndex = mid - 1;
                        if (endIndex < beginIndex)
                        {
                            insertIndex = beginIndex;
                            break;
                        }
                        else if (nums[i] > sortList[endIndex])
                        {
                            insertIndex = endIndex + 1;
                            break;
                        }
                    }
                    else if (nums[i] > sortList[mid])
                    {
                        beginIndex = mid + 1;
                        if (endIndex < beginIndex)
                        {
                            insertIndex = beginIndex;
                            break;
                        }
                        else if (nums[i] < sortList[beginIndex])
                        {
                            insertIndex = beginIndex;
                            break;
                        }
                    }
                    else
                    {
                        insertIndex = mid;
                        break;
                    }
                }
                //插入的位置排序数字有可能跟前一个或者多个数字相同
                if (sortList.Count > 0 && insertIndex<sortList.Count)
                {
                    while (sortList[insertIndex] == nums[i])
                    {
                        insertIndex--;
                    }
                }                
                sortList.Insert(insertIndex, nums[i]);
                returnArr[i] = insertIndex;
            }
            return returnArr;
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值