以下修改后的桶排序解决方案的时间复杂度是多少

What's time complexity of following modified bucket sort solution

这是一种桶排序算法,试图从点 (0,0) 获取 K 个最近的位置。这是通过计算这些位置的距离并根据距离对它们进行分桶来完成的。如果两个位置距离相等,则优先考虑壁橱 x 的位置,然后是 y(如果 x 值相同)

以下解决方案的时间复杂度是多少? O(NlogN) 或 O(KNlogN) 或其他任何东西

// java

Input: int k, List<Location>
Output: List<Location>

public class Location {
    //constructor x and y
    int x;
    int y;
    //get 
    //set

    //hashcode and equals
}

public class Solution {
    public List<Location> returnKNearestLocation(int k, List<Location> locations) {
        Map<Float, Set<Location>> map = new TreeMap<>();
        for(Location loc: locations) {
            float dist = calculateDistance(new Location(0,0), loc);
            List<Location> temp = map.getOrDefault(dist, new HashSet());
            temp.add(loc);
            map.put(temp);
        }

        List<Location> result = new ArrayList<>();
        int size = k;
        while(size > 0) {
            for(Float key : map.keySet()) {
                Set<Location> loc = map.get(key);
                Collection.sort(loc, p1, p2 -> {
                        return p1.x.equals(p2.x)? p1.y.compare(p2.y) : p1.x.compare(p2.x);
                });

                for(Location currLoc : loc) {
                    result.add(currLoc);
                    if(result.size() == k) {
                        return result;
                    }
                }
                size = size - loc.size();
            }                
        }

        return result;
    }

    private float calculateDistance(Location p, Location q) {
       // calculate distance Math.sqrt((P.x - Q.x)^2 + (P.y - Q.y)^2)
    }
}

我会说 O(N*log(N))。

  • 假设 float dist = calculateDistance(new Location(0,0), loc) 是 O(1)。
  • put()getOrDefault()TreeMap 中的实现是 O(log(N))。其他实现提供 O(1)。我会看看 HashMap.
  • addHashSet 中的实现是 O(1)(摊销)。
  • addArrayList 中的实现是 O(1)(摊销)
  • BucketSort 有一个 worst-case 的 O(N^2),在所有项目都放在同一个桶中的情况下。

我会看一下 HashMap 而不是 TreeMap

所以,假设我没有错:

  • 第一个循环 (foreach loc) 的复杂度为 O(N*log(N))。
  • 第二个循环(while size > 0)是 O(N*log(N))。
    • 假设所有位置都放在同一个桶中,我们将对所有项目进行排序 (O(N*log(N)))。
    • 然后我们将遍历前 K 个元素,并添加到结果中——这需要 O(K) < O(N)。