Welcome to Subscribe On Youtube

Formatted question description: https://leetcode.ca/all/2491.html

2491. Divide Players Into Teams of Equal Skill

  • Difficulty: Medium.
  • Related Topics: .
  • Similar Questions: Minimum Moves to Equal Array Elements, Max Number of K-Sum Pairs.

Problem

You are given a positive integer array skill of even length n where skill[i] denotes the skill of the ith player. Divide the players into n / 2 teams of size 2 such that the total skill of each team is equal.

The chemistry of a team is equal to the product of the skills of the players on that team.

Return the sum of the **chemistry of all the teams, or return -1 if there is no way to divide the players into teams such that the total skill of each team is equal.**

  Example 1:

Input: skill = [3,2,5,1,3,4]
Output: 22
Explanation: 
Divide the players into the following teams: (1, 5), (2, 4), (3, 3), where each team has a total skill of 6.
The sum of the chemistry of all the teams is: 1 * 5 + 2 * 4 + 3 * 3 = 5 + 8 + 9 = 22.

Example 2:

Input: skill = [3,4]
Output: 12
Explanation: 
The two players form a team with a total skill of 7.
The chemistry of the team is 3 * 4 = 12.

Example 3:

Input: skill = [1,1,2,3]
Output: -1
Explanation: 
There is no way to divide the players into teams such that the total skill of each team is equal.

  Constraints:

  • 2 <= skill.length <= 105

  • skill.length is even.

  • 1 <= skill[i] <= 1000

Solution (Java, C++, Python)

  • class Solution {
        public long dividePlayers(int[] skill) {
            Arrays.sort(skill);
            int n = skill.length;
            int t = skill[0] + skill[n - 1];
            long ans = 0;
            for (int i = 0, j = n - 1; i < j; ++i, --j) {
                if (skill[i] + skill[j] != t) {
                    return -1;
                }
                ans += (long) skill[i] * skill[j];
            }
            return ans;
        }
    }
    
  • class Solution {
    public:
        long long dividePlayers(vector<int>& skill) {
            sort(skill.begin(), skill.end());
            int n = skill.size();
            int t = skill[0] + skill[n - 1];
            long long ans = 0;
            for (int i = 0, j = n - 1; i < j; ++i, --j) {
                if (skill[i] + skill[j] != t) return -1;
                ans += 1ll * skill[i] * skill[j];
            }
            return ans;
        }
    };
    
  • class Solution:
        def dividePlayers(self, skill: List[int]) -> int:
            skill.sort()
            t = skill[0] + skill[-1]
            i, j = 0, len(skill) - 1
            ans = 0
            while i < j:
                if skill[i] + skill[j] != t:
                    return -1
                ans += skill[i] * skill[j]
                i, j = i + 1, j - 1
            return ans
    
    
  • func dividePlayers(skill []int) (ans int64) {
    	sort.Ints(skill)
    	n := len(skill)
    	t := skill[0] + skill[n-1]
    	for i, j := 0, n-1; i < j; i, j = i+1, j-1 {
    		if skill[i]+skill[j] != t {
    			return -1
    		}
    		ans += int64(skill[i] * skill[j])
    	}
    	return
    }
    
  • function dividePlayers(skill: number[]): number {
        const n = skill.length;
        skill.sort((a, b) => a - b);
        const target = skill[0] + skill[n - 1];
        let ans = 0;
        for (let i = 0; i < n >> 1; i++) {
            if (target !== skill[i] + skill[n - 1 - i]) {
                return -1;
            }
            ans += skill[i] * skill[n - 1 - i];
        }
        return ans;
    }
    
    
  • var dividePlayers = function (skill) {
        const n = skill.length,
            m = n / 2;
        skill.sort((a, b) => a - b);
        const sum = skill[0] + skill[n - 1];
        let ans = 0;
        for (let i = 0; i < m; i++) {
            const x = skill[i],
                y = skill[n - 1 - i];
            if (x + y != sum) return -1;
            ans += x * y;
        }
        return ans;
    };
    
    
  • impl Solution {
        pub fn divide_players(mut skill: Vec<i32>) -> i64 {
            let n = skill.len();
            skill.sort();
            let target = skill[0] + skill[n - 1];
            let mut ans = 0;
            for i in 0..n >> 1 {
                if skill[i] + skill[n - 1 - i] != target {
                    return -1;
                }
                ans += (skill[i] * skill[n - 1 - i]) as i64;
            }
            ans
        }
    }
    
    

Explain:

nope.

Complexity:

  • Time complexity : O(n).
  • Space complexity : O(n).

All Problems

All Solutions