Two City Scheduling | Leetcode

แชร์
ฝัง
  • เผยแพร่เมื่อ 6 ม.ค. 2025

ความคิดเห็น • 145

  • @aldowachyudi6859
    @aldowachyudi6859 4 ปีที่แล้ว +19

    I like that you've explained the thinking process ("can I use sort?"). Rather than just explaining the solution.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      :)

    • @urveshgodhani4542
      @urveshgodhani4542 2 ปีที่แล้ว

      static bool comp(vector &a , vector &b)
      {
      return (a[0] - a[1]) < (b[0] - b[1]);
      }

      int twoCitySchedCost(vector& costs) {
      sort(costs.begin() , costs.end() , comp);
      int n = costs.size();
      int ans = 0;

      for(int i = 0 ; i < costs.size() / 2 ; i++)
      {
      ans += costs[i][0] + costs[i+n/2][1];
      }

      return ans;
      }

    • @urveshgodhani4542
      @urveshgodhani4542 2 ปีที่แล้ว

      please try this

  • @NeverGiveUp186
    @NeverGiveUp186 4 ปีที่แล้ว +9

    Sometimes I feel you only design those questions 😂
    Perfect solutions every time !! 🙌

  • @himanshuchhikara4918
    @himanshuchhikara4918 3 ปีที่แล้ว +1

    amazing best part of explation was explaning why sorting will not work then move to right solution

  • @meghashanbhag5188
    @meghashanbhag5188 4 ปีที่แล้ว +4

    Made the problem very easy to understand.Good explanation. Thanks a lot 👍

  • @laurawu5146
    @laurawu5146 4 ปีที่แล้ว +2

    very clear explanation from the problem to the solution and time/space complexity. Thanks very much !!

  • @ShreyaSingh-vr9qi
    @ShreyaSingh-vr9qi 4 ปีที่แล้ว +2

    Nice explaination Sir, Lockdown and Leetcode with @Techdose. I saw almost 70./. of your videos your explaination is clear and too the point in all videos. Keep going Sir !!

  • @faangsde
    @faangsde 4 ปีที่แล้ว

    another fantastic video from Tech Dose. I love the comprehensive approach in terms of methods to resolve the problem. You are a rising star 🌟

  • @punjabicodingstyle5111
    @punjabicodingstyle5111 4 ปีที่แล้ว +6

    Finally it is i was waiting from one hour.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +6

      I hope you tried yourself :)

  • @punjabicodingstyle5111
    @punjabicodingstyle5111 4 ปีที่แล้ว +1

    There may be good solutions but i am following you because explanation and style of teaching is superb.

  • @saurabhkukreja1982
    @saurabhkukreja1982 ปีที่แล้ว

    best explaination . You got a subscriber

  • @srivatsanv.r1162
    @srivatsanv.r1162 4 ปีที่แล้ว +2

    Thanks a ton 🙏 Elegant explanation. Fan of you sir 🤓

  • @akhilesh59
    @akhilesh59 2 ปีที่แล้ว

    Very Well Explained... Thank You :)

  • @tanishqgupta1071
    @tanishqgupta1071 4 ปีที่แล้ว +1

    Your explanation style is very good

  • @spetsnaz_2
    @spetsnaz_2 4 ปีที่แล้ว +1

    This questions was tougher than most of the easy problems on LeetCode

  • @BaishaliGhosh13
    @BaishaliGhosh13 4 ปีที่แล้ว +3

    Great explanation. You make the logic so clear to understand. Thank you.

  • @_HarshitSharma
    @_HarshitSharma 2 ปีที่แล้ว

    Excellent explanation sir, thank you so much for such an amazing content ♥

  • @Daamilola
    @Daamilola 2 ปีที่แล้ว

    Excellent explanation, thank you

  • @vibunkumarvs5744
    @vibunkumarvs5744 4 ปีที่แล้ว +1

    Mad respect !!! Great explanation 👍🏻

  • @sahazeerks2363
    @sahazeerks2363 4 ปีที่แล้ว +1

    Great explanation

  • @arunadang2130
    @arunadang2130 4 ปีที่แล้ว +1

    Nice Explaination

  • @lifehacks9450
    @lifehacks9450 4 ปีที่แล้ว +1

    Great job

  • @HimanshuSingh-ob9qo
    @HimanshuSingh-ob9qo 4 ปีที่แล้ว +1

    Nice explanation

  • @harinijeyaraman8789
    @harinijeyaraman8789 4 ปีที่แล้ว +1

    Good explanation!

  • @jeysiva_old
    @jeysiva_old 4 ปีที่แล้ว +1

    Well explained sir, thankyou :)

  • @arthurg5966
    @arthurg5966 4 ปีที่แล้ว +2

    The heap approach will also be O(nlogn) as after every deletion of max from heap balancing the heap everytime will take O(logn) time. The heap won't balance itself in O(1) time.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +4

      I wrote O(N) extra space and not time. Time is O(NligN). I think you misunderstood by reading what I wrote for space 😅

    • @arthurg5966
      @arthurg5966 4 ปีที่แล้ว +1

      @@techdose4u oh sorry my bad😅

    • @sangramkapre
      @sangramkapre 4 ปีที่แล้ว

      @@techdose4u I think creating a new array of profits and sorting that array would also have O(NlogN) time and O(N) space complexity.

  • @danavram8437
    @danavram8437 4 ปีที่แล้ว

    c++ Heap solution:
    // Time complexity: O(NlogN) -> we need to push all the items in the heap
    // Space complexity: O(N)
    class Solution {
    public:
    int twoCitySchedCost(vector& costs) {
    auto comp = [](pair& lhs, pair& rhs){
    return lhs.first > rhs.first;
    };

    priority_queue maxHeap(comp);
    int n = costs.size();
    for (int i = 0; i < n; ++i )
    {
    maxHeap.push({costs[i][1] - costs[i][0], i});
    }

    int sum = 0;
    while (!maxHeap.empty())
    {
    const auto& entry = maxHeap.top();
    int idx = entry.second;
    if (maxHeap.size() > n/2)
    // the equal needs to be on the else here..
    {
    sum += costs[idx][1];
    } else // n/2 or smaller items left in the heap
    {
    sum += costs[idx][0];
    }
    maxHeap.pop();
    }

    return sum;
    }
    };

  • @mujahidpasha4440
    @mujahidpasha4440 4 ปีที่แล้ว +1

    Thanks for your time...

  • @i.vigneshdavid1698
    @i.vigneshdavid1698 4 ปีที่แล้ว +1

    Tq bro waiting for your explanation

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      My pleasure. I hope you tried your best before looking at solution :)

    • @i.vigneshdavid1698
      @i.vigneshdavid1698 4 ปีที่แล้ว

      @@techdose4u yea bro

  • @avgerageCSStudent
    @avgerageCSStudent 4 ปีที่แล้ว +1

    I really enjoy the way you approach the problem and solve it with different methods. What would be your approach if we want to schedule the same number of candidates for 3 different cities instead? I could only think of using brute force(back tracking) at the moment.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      Using backtracking with memoization. This will work for all the cases.

  • @danavram8437
    @danavram8437 4 ปีที่แล้ว +1

    6:44 is not a good example at all. Nothing guarantees that A of i < B of i in all pairs. The rest is great. It's a bit confusing what happens when the difference is negative.

    • @the.haunted.hourglass21
      @the.haunted.hourglass21 2 ปีที่แล้ว

      Yeah, exactly. What if the element [30, 300] was [300, 30] instead? Then even when the list of pairs is sorted by the highest differences of each, B would be cheaper for that first pair. So even after sorting by the biggest difference, you need to check whether A or B is lower, and if either one is already full (you've already used n A's or n B's), then you use the other.

  • @nikunjgupta2878
    @nikunjgupta2878 4 ปีที่แล้ว +1

    Nice

  • @uditagrawal6603
    @uditagrawal6603 3 ปีที่แล้ว

    I think there seems to be issue with the comparator shouldn't it be
    (b[1]-b[0])-(a[1]-a[0]) so that highest difference comes on top.

  • @abhishekrai4325
    @abhishekrai4325 4 ปีที่แล้ว +1

    Thak you sir. 😊

  • @uk007rider
    @uk007rider 4 ปีที่แล้ว +2

    Hey,I think after sorting it is not necessary that we have to take first n/2 from cityA..it can be from CityB also..i think it will be the min(cityA,cityB)..then whoever fills first rest will be from remaining cities filling count.Its while explaining the solution..

    • @kushgupta6416
      @kushgupta6416 4 ปีที่แล้ว +2

      Not needed to compare...as here absolute difference is not taken while sorting..so in every case first half will be from A, second half will be from B city.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      I already said that we are sorting based on profit we would get if we choose to go to city A. So the first N/2 elements will give max profit for going to city A. According to constraints of the problem, you had to send N/2 candidates to city A. So we needed to choose all first N/2 elements after sorting based on profit. Re-watch the video and listen carefully. I think it's easy to understand. You will get it.

    • @uk007rider
      @uk007rider 4 ปีที่แล้ว

      @@techdose4u i think i used diff approach after sorting the profit in desc order

    • @kushgupta6416
      @kushgupta6416 4 ปีที่แล้ว

      @@uk007rider if you sort in decreasing order. the first half will be for city B and the second half for city A. in your approach you must have taken absolute difference. try to dry run for different input data. you will get why it is working and how it is not working in case of absolute difference

  • @jaydeepmahajan6598
    @jaydeepmahajan6598 4 ปีที่แล้ว +1

    def twoCitySchedCost(self, arr: List[List[int]]) -> int:
    arr.sort(key=lambda x:(x[1]-x[0]),reverse=True)
    n=len(arr)
    x,y=0,0
    for i in range(n//2):
    x+=arr[i][0]+arr[n-i-1][1]
    return x

  • @SurajKumar-cg1mm
    @SurajKumar-cg1mm 4 ปีที่แล้ว

    How will it solve minimize this cost matrix
    10,20. 30,200. 400,50. 30,20
    By sort by its diff.

  • @kushagrabhargav8084
    @kushagrabhargav8084 4 ปีที่แล้ว +1

    y we used static in bool comparator function?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      You need to make comparator static. Please read stackoverflow for this question.

  • @s1mple965
    @s1mple965 2 ปีที่แล้ว

    perfect soln :D

  • @Safar_Ayushi_Ka
    @Safar_Ayushi_Ka 4 ปีที่แล้ว +1

    How you made perfect your DS and algo part?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +3

      Nothing is perfect. I am still learning. I just try to improve each passing day. You can do it too with a lot of practice :)

    • @YouTube-Joy-Happy
      @YouTube-Joy-Happy 4 ปีที่แล้ว

      @@techdose4u you are awesome, I came accross several youtubers who claim to have mastered DS & Algorithm.
      But what I think about DS is that no one can master it, but they can only become good at it by practicing.
      Any way thanks for being honest.

  • @CollectConnectDots
    @CollectConnectDots 4 ปีที่แล้ว

    Java Solution - github.com/neeraj11789/tech-interview-problems/blob/33b0cd96a62a9155c0f801dea9e85974522ac11d/src/main/java/leetcode/junechallenge/TwoCityScheduling.java

  • @madhavsahi7400
    @madhavsahi7400 4 ปีที่แล้ว +1

    Sir what if in the given example which j used , the pairs are opposite ?...here u r taking A city cost always less than B city cost ...

    • @spetsnaz_2
      @spetsnaz_2 4 ปีที่แล้ว +1

      Since all candidates must go in either city A or B, then taking the opposite will also work

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      It will work even if A's cost is more. Take some examples and do dry run. You will get it.

  • @OfficialUPSCAspirant
    @OfficialUPSCAspirant 4 ปีที่แล้ว +1

    Pls explain how you calculated complexity too

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      Okay. I try to explain it very briefly.

  • @mayankprakash9651
    @mayankprakash9651 4 ปีที่แล้ว +1

    Which software you are using to make videos?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      Inkspace pro with Wacom pro.

  • @ginotamaca7827
    @ginotamaca7827 4 ปีที่แล้ว +3

    Hello, is it also possible to solve it using dynamic programming?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      Yes offcourse. I have uploaded my CODE using Dynamic Programming (Memoization) in CODE LINK in the description. Please have a look. It's easy to understand.

  • @md_aaqil8027
    @md_aaqil8027 4 ปีที่แล้ว +2

    Java solution
    class Solution {
    public int twoCitySchedCost(int[][] costs) {
    Arrays.sort(costs,(a,b)->(a[0]-a[1])-(b[0]-b[1]));
    int len=costs.length;
    int res=0;
    for(int i=0;i

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      Thanks for continuously sharing :)

    • @md_aaqil8027
      @md_aaqil8027 4 ปีที่แล้ว

      @@techdose4u
      First of all ,I want you to thank for the great explanation video then even paid course in the internet
      Keep rocking sir 🥳

  • @chetanmuliya6030
    @chetanmuliya6030 4 ปีที่แล้ว

    java solution :
    public int twoCitySchedCost(int[][] costs) {
    Arrays.sort(costs,(a,b) -> {
    return (a[0]-a[1])-(b[0]-b[1]);
    });
    int n = costs.length;
    int ans = 0;
    for(int i=0;i=n/2?costs[i][1]:costs[i][0];
    }
    return ans;
    }

  • @goyalayush57
    @goyalayush57 4 ปีที่แล้ว +1

    Thank you for this approach, but I am not able to figure out why just considering one city max profit we will be able to get maximum profit,why we are not taking city B into consideration
    It will be great if you can explain me how we can expand this problem if we have 3 cities and 3N candidate
    Solution to this might be simple but its not striking

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +2

      Use dynamic programming (memoization) to solve for as many N and as many cities as you want. I have uploaded DP CODE LINK in description as well. Please have a look. When there are just 2 cities then it doesn't matter whether you consider A or B, the other one will always get considered. We are doing based on profit of A. This means we segregating all max profit candidates for city A. Therefore, least profit candidates to A gets segregated on the other side. It was also guaranteed that N candidates had to go to A and B both. So, take most profitable half for A and other half for B. It's simple. You will get it.

    • @goyalayush57
      @goyalayush57 4 ปีที่แล้ว

      @@techdose4u Thanx , trying to digest :)

  • @rajatmehta8499
    @rajatmehta8499 4 ปีที่แล้ว +1

    I did it with dp stiill faster than 97%

  • @lifeoftravelleronmt
    @lifeoftravelleronmt 4 ปีที่แล้ว +1

    What if there is a case where cost for city A is more than city B

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      Try that case. I don't know where is the problem. Will sorting won't work for -ve number? If it won't then this technique won't work either. So try to dry run.

    • @lifeoftravelleronmt
      @lifeoftravelleronmt 4 ปีที่แล้ว

      @@techdose4u sure thank you 🙂

    • @lifeoftravelleronmt
      @lifeoftravelleronmt 4 ปีที่แล้ว

      This is a very good explanation i wish i will see many more such types of problem solvings in future

  • @mayankprakash9651
    @mayankprakash9651 4 ปีที่แล้ว +2

    Can it be done through dp?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      It's dp problem only. I have added the new DP code link in the video description. Follow that.

  • @anuragtiwari5396
    @anuragtiwari5396 4 ปีที่แล้ว +1

    I've written a recursive function to calculate the min cost but I'm not able to memoize my solution
    class Solution {
    public int twoCitySchedCost(int[][] costs) {
    int nTotal=costs.length;
    return totalCost(costs,nTotal/2,nTotal/2,nTotal);
    }
    public int totalCost(int [][]costs,int a,int b,int nT){
    if(a==0&&b==0)
    return 0;
    else if(a==0&&b>0)
    return totalCost(costs,a,b-1,nT-1)+costs[nT-1][1];
    else if(a>0&&b==0)
    return totalCost(costs,a-1,b,nT-1)+costs[nT-1][0];
    return Math.min(totalCost(costs,a-1,b,nT-1)+costs[nT-1][0],totalCost(costs,a,b-1,nT-1)+costs[nT-1][1]);

    }
    }

    • @mayankprakash9651
      @mayankprakash9651 4 ปีที่แล้ว +1

      Is it working?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      I have added memoization solution to the video in a separate link DP solution. Please read that. It's pretty simple and self explanatory :)

    • @anuragtiwari5396
      @anuragtiwari5396 4 ปีที่แล้ว

      @@mayankprakash9651 yes but it is too slow with exponential time complexity

  • @mahimakalra1181
    @mahimakalra1181 4 ปีที่แล้ว +1

    Sir please make a video on digit dp

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      Finally someone asked it :) Have you encountered this on hackerrank contest or on leetcode?

    • @mahimakalra1181
      @mahimakalra1181 4 ปีที่แล้ว

      @@techdose4u It was in an Asia Pacific contest

  • @rahulbhati3079
    @rahulbhati3079 4 ปีที่แล้ว +1

    Can we use dp

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      This is a dp problem. Look at the description for dp solution code.

    • @rahulbhati3079
      @rahulbhati3079 4 ปีที่แล้ว

      @@techdose4u ok i got it and it was really very good explaination

  • @pahehepaa4182
    @pahehepaa4182 4 ปีที่แล้ว +1

    Can you make a video with the dp solution ?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      I have posted my DP solution. Please have a look. It is nothing but recursion with memoization. Try to write recursive code.

    • @pahehepaa4182
      @pahehepaa4182 4 ปีที่แล้ว

      @@techdose4u Didn't get it even after reading the discussions.

  • @evgeni-nabokov
    @evgeni-nabokov 4 ปีที่แล้ว +1

    Rust:
    costs.sort_unstable_by_key(|a| a[0] - a[1]);
    let n = costs.len() / 2;
    costs.iter().take(n).map(|x| x[0]).sum::() + costs.iter().skip(n).map(|x| x[1]).sum::()

  • @pratyush2604
    @pratyush2604 4 ปีที่แล้ว +1

    how does our comparator takes into account for vector like [400,50] in [[10,20],[30,200],[400,50],[30,20]]
    wont doing a[1] - a[0] give a negative value for this
    in your explanation, you have taken the a[i][1] greater than a[i][0] for all i

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +1

      (400,50) will have profit as -350. So we are at loss of 350 if we chose to go to city A. So after sorting in your array, (400,50) will come last. So, City B will be chosen for it.

  • @vishrutmishra3243
    @vishrutmishra3243 4 ปีที่แล้ว

    I solved this question using Dynamic Programming. Here is my solution.
    class Solution {
    public:
    int twoCitySchedCost(vector& costs) {
    int n = costs.size();
    int dp[200][200];

    for (int i = 0; i < 200; i++) {
    for (int j = 0; j < 200; j++) {
    dp[i][j] = -1;
    }
    }

    return solve(costs, n/2, n/2, 0, dp);
    }

    int solve(vector& costs, int a, int b, int i, int dp[][200]) {
    int cost = 0;

    if (a == 0) {
    int sum = 0;
    for (; i < costs.size(); i++) {
    sum += costs[i][1];
    }

    dp[a][b] = sum;
    return dp[a][b];
    }

    if (b == 0) {
    int sum = 0;
    for (; i < costs.size(); i++) {
    sum += costs[i][0];
    }

    dp[a][b] = sum;
    return dp[a][b];
    }

    if (dp[a][b] != -1) {
    return dp[a][b];
    }

    cost += min(costs[i][0] + solve(costs, a-1, b, i+1, dp), costs[i][1] + solve(costs, a, b-1, i+1, dp));
    dp[a][b] = cost;

    return dp[a][b];
    }
    };

  • @lifehacks9450
    @lifehacks9450 4 ปีที่แล้ว +1

    Sir I have doubt in k similar string in leetcode please upload it sir please

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      If it comes in June challenge then sure otherwise when leetcode challenge ends then I will.

    • @lifehacks9450
      @lifehacks9450 4 ปีที่แล้ว

      @@techdose4u thanks

  • @amanvashistha984
    @amanvashistha984 3 ปีที่แล้ว

    Why will DP with memoization not work?

  • @vineethdasi
    @vineethdasi 4 ปีที่แล้ว +1

    I thought the parameter was the ratio of costs of both cities.....but it didn't work out

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +2

      Nice idea though. By trying different parameters you might have been able to reach this profit parameter as well. Keep experimenting.

  • @cloud15487
    @cloud15487 4 ปีที่แล้ว +1

    How do you manage to keep Leetcoding + TH-cam + Work Full Time? Do you have any tips for me brother?

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว +2

      Just following passion with hard work :)

    • @cloud15487
      @cloud15487 4 ปีที่แล้ว +2

      @@techdose4u I respect you for that man. I'll give my best.

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      👍

  • @mspprasath1178
    @mspprasath1178 4 ปีที่แล้ว +1

    Instead of subracting values we can also add city a cost and city b cost, and after sorting we could find??isn't

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      I don't think this will work. Share your code if it does.

  • @lokeshgupta8212
    @lokeshgupta8212 4 ปีที่แล้ว

    Sir ji kaise samjaaate pura samajh hi nhi aaaya, top n/ 2 element coty A ke kaise honge...bhai

    • @techdose4u
      @techdose4u  4 ปีที่แล้ว

      Please rewatch to get full understanding. I have already explained the reason in video.

    • @ShreyaSingh-vr9qi
      @ShreyaSingh-vr9qi 4 ปีที่แล้ว

      total size array k 2N given hain, N candidates city A m jana hain and N candidates city B ma. Toh sir na 2N ki jagh i think N size suppose karka kia hain, So for N size (N/2) element city A ma jana hain and (N/2) element city B ma.

  • @chanduc2000
    @chanduc2000 3 ปีที่แล้ว

    I got same question in curefit interview but I messed it :(

  • @neeteshpatel1164
    @neeteshpatel1164 4 ปีที่แล้ว +1

    Could it be solved by dynamic programming ?if yes, please post a video on that one too.
    Please refer below link for my java solution with iterative approach in order of n^2 time complexity & O(1) space.
    github.com/master-raccoons/mission-achieve/blob/master/Practice/TwoCitySchedule.java

  • @shivrajnag12
    @shivrajnag12 4 ปีที่แล้ว +1

    Is this a Greedy approach???

  • @mdnoverflow
    @mdnoverflow 2 ปีที่แล้ว +1

    awesome explanation!!!