Sort by

recency

|

922 Discussions

|

  • + 0 comments

    Java:

    public static int luckBalance(int k, List<List<Integer>> contests) {
      int balance = 0;
      Collections.sort(contests, new Comparator<List<Integer>>() {
        @Override
        public int compare(List<Integer> o1, List<Integer> o2) {
          return o1.get(0).compareTo(o2.get(0));
        }
      });
      int n = contests.size();
      for (int i = n - 1; i >= 0; i--) {
        int current = contests.get(i).get(0);
        if (contests.get(i).get(1) == 1) {
          if (k > 0) {
            balance += current;
            k--;
          } else {
            balance -= current;
          }
    
        } else {
          balance += current;
        }
      }
    
      return balance;
    }
    
  • + 0 comments

    Here is my c++ solution, you can watch the explanation here : https://youtu.be/7L1lI6JScR8

    int luckBalance(int k, vector<vector<int>> contests) {
        sort(contests.begin(), contests.end(), [](vector<int> l, vector<int>r){
            return l[0] > r[0];
        });
        int ans = 0, im = 0;
        for(int i = 0; i < contests.size(); i++){
            if(im < k || contests[i][1] == 0) ans += contests[i][0];
            else ans -= contests[i][0];
            if(contests[i][1] == 1) im++;
        }
        return ans;
    }
    
  • + 0 comments

    Haskell

    module Main where
    
    import Control.Monad (replicateM)
    import Data.List (partition, sortBy, splitAt)
    
    solve :: Int -> [[Int]] -> Int
    solve k trials = sum pluses - sum minuses + sum uvals
      where
        (important, unimportant) = partition (\(_ : t : _) -> t == 1) trials
        ivals = sortBy (flip compare) $ map head important
        uvals = map head unimportant
        (pluses, minuses) = splitAt k ivals
    
    main :: IO ()
    main = do
        [n, k] <- fmap (map read . words) getLine :: IO [Int]
        trials <- replicateM n $ fmap (map read . words) getLine :: IO [[Int]]
        print $ solve k trials
    
  • + 0 comments

    What the actual f? I understand the need to decorate the abstract CS problem with some story. But why not have the story take place in a reality that we all share and can relate to instead of authors' weired nightmares. Obfiscuating the meaning of the problem with bizare fantasies isn't making it more interesting or challenging in a productive way

  • + 0 comments

    def luckBalance(k, contests): important = [luck for luck, importance in contests if importance == 1] unimportant = [luck for luck, importance in contests if importance == 0]

    # Sort important contests in descending order of luck
    important.sort(reverse=True)
    
    # Sum luck from the k most important contests and subtract the rest
    return sum(important[:k]) - sum(important[k:]) + sum(unimportant)