πDay 2. Find H-Index π§
The problem can be found at the following link: Problem Link
π‘ Problem Description:
You are given an array of integers citations[], where citations[i] is the number of citations a researcher received for the i-th paper. Your task is to find the H-Index of the researcher.
H-Index is the largest value H such that the researcher has at least H papers that have been cited at least H times.
π Example Walkthrough:
Input:
citations[] = [3, 0, 5, 3, 0]
Output:
3
Explanation: There are at least 3 papers (with 3, 5, and 3 citations) that have been cited at least 3 times.
Input:
citations[] = [5, 1, 2, 4, 1]
Output:
2
Explanation: There are at least 2 papers (with 5 and 4 citations) that have been cited at least 2 times.
Input:
citations[] = [0, 0]
Output:
0
Explanation: No paper has been cited at least once.
Constraints:
- $ - 1 β€ citations.size() β€ 10^6$
- $ - 0 β€ citations[i] β€ 10^6$
π― My Approach:
- Bucket Sort Method: - We create an array - buckets[]where- buckets[i]stores the count of papers with exactly- icitations.
- If a paper has citations greater than or equal to the number of papers, it is counted in a special - buckets[n].
- After building the bucket, we compute the cumulative count of papers with at least - icitations to determine the H-Index.
 
- Steps: - Traverse the - citations[]array to populate the- buckets[].
- Traverse the - buckets[]array from the back to compute the cumulative counts and find the H-Index.
- This approach ensures a linear time complexity. 
 
π Time and Auxiliary Space Complexity
- Expected Time Complexity: O(n), where - nis the size of the- citationsarray. We perform one traversal to populate the- buckets[]and another traversal to compute the H-Index.
- Expected Auxiliary Space Complexity: O(n), as we use an array of size - n+1for the bucket sort.
π Solution Code
Code (C)
int hIndex(int citations[], int citationsSize) {
    int buckets[citationsSize + 1];
    memset(buckets, 0, sizeof(buckets));
    for (int i = 0; i < citationsSize; i++) {
        if (citations[i] >= citationsSize)
            buckets[citationsSize]++;
        else
            buckets[citations[i]]++;
    }
    int cumulative = 0;
    for (int i = citationsSize; i >= 0; i--) {
        cumulative += buckets[i];
        if (cumulative >= i)
            return i;
    }
    return 0;
}Code (Cpp)
class Solution {
public:
    int hIndex(vector<int>& citations) {
        int n = citations.size();
        vector<int> buckets(n + 1, 0);
        for (int c : citations) {
            if (c >= n)
                buckets[n]++;
            else
                buckets[c]++;
        }
        int cumulative = 0;
        for (int i = n; i >= 0; --i) {
            cumulative += buckets[i];
            if (cumulative >= i)
                return i;
        }
        return 0;
    }
};Code (Java)
class Solution {
    public int hIndex(int[] citations) {
        int n = citations.length;
        int[] buckets = new int[n + 1];
        for (int c : citations) {
            if (c >= n)
                buckets[n]++;
            else
                buckets[c]++;
        }
        int cumulative = 0;
        for (int i = n; i >= 0; i--) {
            cumulative += buckets[i];
            if (cumulative >= i)
                return i;
        }
        return 0;
    }
}Code (Python)
class Solution:
    def hIndex(self, citations):
        n = len(citations)
        buckets = [0] * (n + 1)
        for c in citations:
            if c >= n:
                buckets[n] += 1
            else:
                buckets[c] += 1
        cumulative = 0
        for i in range(n, -1, -1):
            cumulative += buckets[i]
            if cumulative >= i:
                return i
        return 0π― Contribution and Support:
For discussions, questions, or doubts related to this solution, feel free to connect on LinkedIn: Any Questions. Letβs make this learning journey more collaborative!
β If you find this helpful, please give this repository a star! β
πVisitor Count
Last updated