Check my code please
@deepgarg46 Benchmark your code with my code :
import java.util.Scanner;
public class Main {
    // Function to count the length of window which can be made of char ch with <= k
    // swaps
    static int countMaxWindowSize(String s, char ch, int k) {
        int i = 0; // Left pointer
        int j = 0; // Right pointer
        // First move the right pointer forward by k steps.
        // If the character is already ch , do not count a swap and move freely
        int c = 0; // Variable to count the swaps so far
        int ans = 0; // Variable to store the final answer
        for (; c < k && j < s.length() - 1; j++) {
            if (s.charAt(j) != ch) {
                // If s.charAt(j) is not ch then count it as a swap and move forward
                c++;
            }
            if (c == k) {
                // If no of swaps has reached k, stop moving j any more forward
                break;
            }
        }
        while (i < j) {
            // Move j ahead if next element is ch as it doesn't count as a swap
            while (j < s.length() - 1 && s.charAt(j + 1) == ch) {
                j++;
            }
            // Store the maximum length of all windows
            int currentLength = j - i + 1;
            ans = Math.max(ans, currentLength);
            // Move left pointer by one to slide the window
            i++;
            // If the char at previous position of left pointer was not ch, then that
            // position must
            // have counted as a swap earlier. Now we have a free swap available.
            // Iterate right pointer forward to use that one free swap
            if (j < s.length() - 1 && s.charAt(i - 1) != ch) {
                j++;
            }
        }
        return ans;
    }
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int k = sc.nextInt();
        String s = sc.next();
        if (k >= s.length()) {
            // If k is larger than s.length() then we can swap all the elements to either A
            // or B
            // and obtain the answer equal to length of string
            System.out.println(s.length());
            return;
        }
        // First let us check for longest perfect string of A's then we will find the
        // same for B's and compare
        int ansForA = countMaxWindowSize(s, 'a', k);
        // Now we do the same for B's
        int ansForB = countMaxWindowSize(s, 'b', k);
        // Final answer is max of the two answers obtained above
        System.out.println(Math.max(ansForA, ansForB));
    }
}
I hope I’ve cleared your doubt. I ask you to please rate your experience here
Your feedback is very important. It helps us improve our platform and hence provide you
the learning experience you deserve.
On the off chance, you still have some questions or not find the answers satisfactory, you may reopen
the doubt.
