{"MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING": "def maximumChars ( str ) :\n    n = len ( str )\n    res = - 1\n    for i in range ( 0 , n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            if ( str [ i ] == str [ j ] ) :\n                res = max ( res , abs ( j - i - 1 ) )\n    return res\n", "FIND_MIRROR_IMAGE_POINT_2_D_PLANE": "def mirrorImage ( a , b , c , x1 , y1 ) :\n    temp = - 2 * ( a * x1 + b * y1 + c ) / ( a * a + b * b )\n    x = temp * a + x1\n    y = temp * b + y1\n    return ( x , y )\n", "EFFICIENTLY_COMPUTE_SUMS_OF_DIAGONALS_OF_A_MATRIX": "def printDiagonalSums ( mat , n ) :\n    principal = 0\n    secondary = 0 ;\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            if ( i == j ) :\n                principal += mat [ i ] [ j ]\n            if ( ( i + j ) == ( n - 1 ) ) :\n                secondary += mat [ i ] [ j ]\n    print ( \"Principal Diagonal:\" , principal )\n    print ( \"Secondary Diagonal:\" , secondary )\n", "COUNTS_PATHS_POINT_REACH_ORIGIN": "def countPaths ( n , m ) :\n    if ( n == 0 or m == 0 ) :\n        return 1\n    return ( countPaths ( n - 1 , m ) + countPaths ( n , m - 1 ) )\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE_1": "def find3Numbers ( A , arr_size , sum ) :\n    A.sort ( )\n    for i in range ( 0 , arr_size - 2 ) :\n        l = i + 1\n        r = arr_size - 1\n        while ( l < r ) :\n            if ( A [ i ] + A [ l ] + A [ r ] == sum ) :\n                print ( \"Triplet is\" , A [ i ] , ', ' , A [ l ] , ', ' , A [ r ] ) ;\n                return True\n            elif ( A [ i ] + A [ l ] + A [ r ] < sum ) :\n                l += 1\n            else :\n                r -= 1\n    return False\n", "CHECK_GIVEN_MATRIX_IS_MAGIC_SQUARE_OR_NOT": "def isMagicSquare ( mat ) :\n    s = 0\n    for i in range ( 0 , N ) :\n        s = s + mat [ i ] [ i ]\n    s2 = 0\n    for i in range ( 0 , N ) :\n        s2 = s2 + mat [ i ] [ N - i - 1 ]\n    if ( s != s2 ) :\n        return False\n    for i in range ( 0 , N ) :\n        rowSum = 0 ;\n        for j in range ( 0 , N ) :\n            rowSum += mat [ i ] [ j ]\n        if ( rowSum != s ) :\n            return False\n    for i in range ( 0 , N ) :\n        colSum = 0\n        for j in range ( 0 , N ) :\n            colSum += mat [ j ] [ i ]\n        if ( s != colSum ) :\n            return False\n    return True\n", "SEQUENCES_GIVEN_LENGTH_EVERY_ELEMENT_EQUAL_TWICE_PREVIOUS_1": "def getTotalNumberOfSequences ( m , n ) :\n    T = [ [ 0 for i in range ( n + 1 ) ] for i in range ( m + 1 ) ]\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            if i == 0 or j == 0 :\n                T [ i ] [ j ] = 0\n            elif i < j :\n                T [ i ] [ j ] = 0\n            elif j == 1 :\n                T [ i ] [ j ] = i\n            else :\n                T [ i ] [ j ] = T [ i - 1 ] [ j ] + T [ i // 2 ] [ j - 1 ]\n    return T [ m ] [ n ]\n", "FIND_DIFFERENCE_BETWEEN_SUMS_OF_TWO_DIAGONALS_1": "def difference ( arr , n ) :\n    d1 = 0\n    d2 = 0\n    for i in range ( 0 , n ) :\n        d1 = d1 + arr [ i ] [ i ]\n        d2 = d2 + arr [ i ] [ n - i - 1 ]\n    return abs ( d1 - d2 )\n", "MINIMUM_NUMBER_SUBSETS_DISTINCT_ELEMENTS": "def subset ( ar , n ) :\n    res = 0\n    ar.sort ( )\n    for i in range ( 0 , n ) :\n        count = 1\n        for i in range ( n - 1 ) :\n            if ar [ i ] == ar [ i + 1 ] :\n                count += 1\n            else :\n                break\n        res = max ( res , count )\n    return res\n", "DECIMAL_BINARY_CONVERSION_WITHOUT_USING_ARITHMETIC_OPERATORS": "def decToBin ( n ) :\n    if ( n == 0 ) :\n        return \"0\" ;\n    bin = \"\" ;\n    while ( n > 0 ) :\n        if ( n & 1 == 0 ) :\n            bin = '0' + bin ;\n        else :\n            bin = '1' + bin ;\n        n = n >> 1 ;\n    return bin ;\n", "FIND_NTH_TERM_DRAGON_CURVE_SEQUENCE": "def Dragon_Curve_Sequence ( n ) :\n    s = \"1\"\n    for i in range ( 2 , n + 1 ) :\n        temp = \"1\"\n        prev = '1'\n        zero = '0'\n        one = '1'\n        for j in range ( len ( s ) ) :\n            temp += s [ j ]\n            if ( prev == '0' ) :\n                temp += one\n                prev = one\n            else :\n                temp += zero\n                prev = zero\n        s = temp\n    return s\n", "STACK_SET_3_REVERSE_STRING_USING_STACK": "def reverse ( string ) :\n    string = string [ : : - 1 ]\n    return string\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER_1": "def bitonicGenerator ( arr , n ) :\n    i = 1\n    j = n - 1\n    if ( j % 2 != 0 ) :\n        j = j - 1\n    while ( i < j ) :\n        arr [ j ] , arr [ i ] = arr [ i ] , arr [ j ]\n        i = i + 2\n        j = j - 2\n    arr_f = [ ]\n    arr_s = [ ]\n    for i in range ( int ( ( n + 1 ) / 2 ) ) :\n        arr_f.append ( arr [ i ] )\n    i = int ( ( n + 1 ) / 2 )\n    while ( i < n ) :\n        arr_s.append ( arr [ i ] )\n        i = i + 1\n    arr_f.sort ( )\n    arr_s.sort ( reverse = True )\n    for i in arr_s :\n        arr_f.append ( i )\n    return arr_f\n", "GIVEN_TWO_NUMBERS_B_FIND_X_X_B": "def modularEquation ( a , b ) :\n    if ( a < b ) :\n        print ( \"No solution possible \" )\n        return\n    if ( a == b ) :\n        print ( \"Infinite Solution possible \" )\n        return\n    count = 0\n    n = a - b\n    y = ( int ) ( math.sqrt ( a - b ) )\n    for i in range ( 1 , y + 1 ) :\n        if ( n % i == 0 ) :\n            if ( n / i > b ) :\n                count = count + 1\n            if ( i > b ) :\n                count = count + 1\n    if ( y * y == n and y > b ) :\n        count = count - 1\n    print ( count )\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME": "def canFormPalindrome ( st ) :\n    count = [ 0 ] * ( NO_OF_CHARS )\n    for i in range ( 0 , len ( st ) ) :\n        count [ ord ( st [ i ] ) ] = count [ ord ( st [ i ] ) ] + 1\n    odd = 0\n    for i in range ( 0 , NO_OF_CHARS ) :\n        if ( count [ i ] & 1 ) :\n            odd = odd + 1\n        if ( odd > 1 ) :\n            return False\n    return True\n", "MAXIMUM_TRIPLET_SUM_ARRAY_1": "def maxTripletSum ( arr , n ) :\n    arr.sort ( )\n    return ( arr [ n - 1 ] + arr [ n - 2 ] + arr [ n - 3 ] )\n", "FIND_MEDIAN_ROW_WISE_SORTED_MATRIX": "def binaryMedian ( m , r , d ) :\n    mi = m [ 0 ] [ 0 ]\n    mx = 0\n    for i in range ( r ) :\n        if m [ i ] [ 0 ] < mi :\n            mi = m [ i ] [ 0 ]\n        if m [ i ] [ d - 1 ] > mx :\n            mx = m [ i ] [ d - 1 ]\n    desired = ( r * d + 1 ) // 2\n    while ( mi < mx ) :\n        mid = mi + ( mx - mi ) // 2\n        place = [ 0 ] ;\n        for i in range ( r ) :\n            j = upper_bound ( m [ i ] , mid )\n            place [ 0 ] = place [ 0 ] + j\n        if place [ 0 ] < desired :\n            mi = mid + 1\n        else :\n            mx = mid\n    print ( \"Median is\" , mi )\n    return\n", "HEIGHT_N_ARY_TREE_PARENT_ARRAY_GIVEN": "def findHeight ( parent , n ) :\n    res = 0\n    for i in range ( n ) :\n        p = i\n        current = 1\n        while ( parent [ p ] != - 1 ) :\n            current += 1\n            p = parent [ p ]\n        res = max ( res , current )\n    return res\n", "CHECK_LARGE_NUMBER_DIVISIBLE_20": "def divisibleBy20 ( num ) :\n    lastTwoDigits = int ( num [ - 2 : ] )\n    return ( ( lastTwoDigits % 5 == 0 and lastTwoDigits % 4 == 0 ) )\n", "MAXIMUM_VALUE_CHOICE_EITHER_DIVIDING_CONSIDERING": "def maxDP ( n ) :\n    res = list ( )\n    res.append ( 0 )\n    res.append ( 1 )\n    i = 2\n    while i < n + 1 :\n        res.append ( max ( i , ( res [ int ( i / 2 ) ] + res [ int ( i / 3 ) ] + res [ int ( i / 4 ) ] + res [ int ( i / 5 ) ] ) ) )\n        i = i + 1\n    return res [ n ]\n", "QUERIES_ON_ARRAY_WITH_DISAPPEARING_AND_REAPPEARING_ELEMENTS": "def PerformQueries ( a , vec ) :\n    ans = [ ] ;\n    n = len ( a ) - 1 ;\n    q = len ( vec ) ;\n    for i in range ( q ) :\n        t = vec [ i ] [ 0 ] ;\n        m = vec [ i ] [ 1 ] ;\n        if ( m > n ) :\n            ans.append ( - 1 ) ;\n            continue ;\n        turn = t // n ;\n        rem = t % n ;\n        if ( rem == 0 and turn % 2 == 1 ) :\n            ans.append ( - 1 ) ;\n            continue ;\n        if ( rem == 0 and turn % 2 == 0 ) :\n            ans.append ( a [ m ] ) ;\n            continue ;\n        if ( turn % 2 == 0 ) :\n            cursize = n - rem ;\n            if ( cursize < m ) :\n                ans.append ( - 1 ) ;\n                continue ;\n            ans.append ( a [ m + rem ] ) ;\n        else :\n            cursize = rem ;\n            if ( cursize < m ) :\n                ans.append ( - 1 ) ;\n                continue ;\n            ans.append ( a [ m ] ) ;\n    for i in ans :\n        print ( i ) ;\n", "FIND_THE_MINIMUM_DISTANCE_BETWEEN_TWO_NUMBERS_1": "def minDist ( arr , n , x , y ) :\n    min_dist = sys.maxsize\n    for i in range ( n ) :\n        if arr [ i ] == x or arr [ i ] == y :\n            prev = i\n            break\n    while i < n :\n        if arr [ i ] == x or arr [ i ] == y :\n            if arr [ prev ] != arr [ i ] and ( i - prev ) < min_dist :\n                min_dist = i - prev\n                prev = i\n            else :\n                prev = i\n        i += 1\n    return min_dist\n", "UNION_AND_INTERSECTION_OF_TWO_SORTED_ARRAYS_2": "def printUnion ( arr1 , arr2 , m , n ) :\n    i , j = 0 , 0\n    while i < m and j < n :\n        if arr1 [ i ] < arr2 [ j ] :\n            print ( arr1 [ i ] )\n            i += 1\n        elif arr2 [ j ] < arr1 [ i ] :\n            print ( arr2 [ j ] )\n            j += 1\n        else :\n            print ( arr2 [ j ] )\n            j += 1\n            i += 1\n    while i < m :\n        print ( arr1 [ i ] )\n        i += 1\n    while j < n :\n        print ( arr2 [ j ] )\n        j += 1\n", "WORD_WRAP_PROBLEM_SPACE_OPTIMIZED_SOLUTION": "def solveWordWrap ( arr , n , k ) :\n    dp = [ 0 ] * n\n    ans = [ 0 ] * n\n    dp [ n - 1 ] = 0\n    ans [ n - 1 ] = n - 1\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        currlen = - 1\n        dp [ i ] = sys.maxsize\n        for j in range ( i , n ) :\n            currlen += ( arr [ j ] + 1 )\n            if ( currlen > k ) :\n                break\n            if ( j == n - 1 ) :\n                cost = 0\n            else :\n                cost = ( ( k - currlen ) * ( k - currlen ) + dp [ j + 1 ] )\n            if ( cost < dp [ i ] ) :\n                dp [ i ] = cost\n                ans [ i ] = j\n    i = 0\n    while ( i < n ) :\n        print ( i + 1 , ans [ i ] + 1 , end = \" \" )\n        i = ans [ i ] + 1\n", "COUNT_DISTINCT_SUBSEQUENCES": "def countSub ( ss ) :\n    last = [ - 1 for i in range ( MAX_CHAR + 1 ) ]\n    n = len ( ss )\n    dp = [ - 2 for i in range ( n + 1 ) ]\n    dp [ 0 ] = 1\n    for i in range ( 1 , n + 1 ) :\n        dp [ i ] = 2 * dp [ i - 1 ]\n        if last [ ord ( ss [ i - 1 ] ) ] != - 1 :\n            dp [ i ] = dp [ i ] - dp [ last [ ord ( ss [ i - 1 ] ) ] ]\n        last [ ord ( ss [ i - 1 ] ) ] = i - 1\n    return dp [ n ]\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_3": "def findLength ( st , n ) :\n    total = [ 0 ] * ( n + 1 )\n    for i in range ( 1 , n + 1 ) :\n        total [ i ] = ( total [ i - 1 ] + int ( st [ i - 1 ] ) - int ( '0' ) )\n    ans = 0\n    l = 2\n    while ( l <= n ) :\n        for i in range ( n - l + 1 ) :\n            j = i + l - 1\n            if ( total [ i + int ( l / 2 ) ] - total [ i ] == total [ i + l ] - total [ i + int ( l / 2 ) ] ) :\n                ans = max ( ans , l )\n        l = l + 2\n    return ans\n", "MAXIMUM_PATH_SUM_MATRIX": "def findMaxPath ( mat ) :\n    res = - 1\n    for i in range ( M ) :\n        res = max ( res , mat [ 0 ] [ i ] )\n    for i in range ( 1 , N ) :\n        res = - 1\n        for j in range ( M ) :\n            if ( j > 0 and j < M - 1 ) :\n                mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ] , max ( mat [ i - 1 ] [ j - 1 ] , mat [ i - 1 ] [ j + 1 ] ) )\n            elif ( j > 0 ) :\n                mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ] , mat [ i - 1 ] [ j - 1 ] )\n            elif ( j < M - 1 ) :\n                mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ] , mat [ i - 1 ] [ j + 1 ] )\n            res = max ( mat [ i ] [ j ] , res )\n    return res\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING": "def maxRepeating ( str ) :\n    l = len ( str )\n    count = 0\n    res = str [ 0 ]\n    for i in range ( l ) :\n        cur_count = 1\n        for j in range ( i + 1 , l ) :\n            if ( str [ i ] != str [ j ] ) :\n                break\n            cur_count += 1\n        if cur_count > count :\n            count = cur_count\n            res = str [ i ]\n    return res\n", "MAXIMUM_LENGTH_SUBSEQUENCE_DIFFERENCE_ADJACENT_ELEMENTS_EITHER_0_1": "def maxLenSub ( arr , n ) :\n    mls = [ ]\n    max = 0\n    for i in range ( n ) :\n        mls.append ( 1 )\n    for i in range ( n ) :\n        for j in range ( i ) :\n            if ( abs ( arr [ i ] - arr [ j ] ) <= 1 and mls [ i ] < mls [ j ] + 1 ) :\n                mls [ i ] = mls [ j ] + 1\n    for i in range ( n ) :\n        if ( max < mls [ i ] ) :\n            max = mls [ i ]\n    return max\n", "BREAKING_NUMBER_FIRST_PART_INTEGRAL_DIVISION_SECOND_POWER_10": "def calculate ( N ) :\n    length = len ( N )\n    l = int ( ( length ) / 2 )\n    count = 0\n    for i in range ( l + 1 ) :\n        s = N [ 0 : 0 + i ]\n        l1 = len ( s )\n        t = N [ i : l1 + i ]\n        try :\n            if s [ 0 ] == '0' or t [ 0 ] == '0' :\n                continue\n        except :\n            continue\n        if s == t :\n            count += 1\n    return count\n", "PROGRAM_BINARY_DECIMAL_CONVERSION": "def binaryToDecimal ( n ) :\n    num = n ;\n    dec_value = 0 ;\n    base = 1 ;\n    temp = num ;\n    while ( temp ) :\n        last_digit = temp % 10 ;\n        temp = int ( temp / 10 ) ;\n        dec_value += last_digit * base ;\n        base = base * 2 ;\n    return dec_value ;\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT": "def getSum ( n ) :\n    sum = 0\n    while ( n != 0 ) :\n        sum = sum + int ( n % 10 )\n        n = int ( n / 10 )\n    return sum\n", "FIND_N_TH_ELEMENT_FROM_STERNS_DIATOMIC_SERIES": "def findSDSFunc ( n ) :\n    DP = [ 0 ] * ( n + 1 )\n    DP [ 0 ] = 0\n    DP [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        if ( int ( i % 2 ) == 0 ) :\n            DP [ i ] = DP [ int ( i / 2 ) ]\n        else :\n            DP [ i ] = ( DP [ int ( ( i - 1 ) / 2 ) ] + DP [ int ( ( i + 1 ) / 2 ) ] )\n    return DP [ n ]\n", "NUMBER_SINK_NODES_GRAPH": "def countSink ( n , m , edgeFrom , edgeTo ) :\n    mark = [ 0 ] * ( n + 1 )\n    for i in range ( m ) :\n        mark [ edgeFrom [ i ] ] = 1\n    count = 0\n    for i in range ( 1 , n + 1 ) :\n        if ( not mark [ i ] ) :\n            count += 1\n    return count\n", "BREAK_NUMBER_THREE_PARTS": "def count_of_ways ( n ) :\n    count = 0\n    for i in range ( 0 , n + 1 ) :\n        for j in range ( 0 , n + 1 ) :\n            for k in range ( 0 , n + 1 ) :\n                if ( i + j + k == n ) :\n                    count = count + 1\n    return count\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY": "def printDistinct ( arr , n ) :\n    for i in range ( 0 , n ) :\n        d = 0\n        for j in range ( 0 , i ) :\n            if ( arr [ i ] == arr [ j ] ) :\n                d = 1\n                break\n        if ( d == 0 ) :\n            print ( arr [ i ] )\n", "MAXIMUM_NUMBER_SEGMENTS_LENGTHS_B_C": "def maximumSegments ( n , a , b , c ) :\n    dp = [ - 1 ] * ( n + 10 )\n    dp [ 0 ] = 0\n    for i in range ( 0 , n ) :\n        if ( dp [ i ] != - 1 ) :\n            if ( i + a <= n ) :\n                dp [ i + a ] = max ( dp [ i ] + 1 , dp [ i + a ] )\n            if ( i + b <= n ) :\n                dp [ i + b ] = max ( dp [ i ] + 1 , dp [ i + b ] )\n            if ( i + c <= n ) :\n                dp [ i + c ] = max ( dp [ i ] + 1 , dp [ i + c ] )\n    return dp [ n ]\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M": "def isPossible ( n , index , Sum , M , arr , dp ) :\n    global MAX\n    if index == n :\n        if ( Sum % M ) == 0 :\n            return True\n        return False\n    if dp [ index ] [ Sum ] != - 1 :\n        return dp [ index ] [ Sum ]\n    placeAdd = isPossible ( n , index + 1 , Sum + arr [ index ] , M , arr , dp )\n    placeMinus = isPossible ( n , index + 1 , Sum - arr [ index ] , M , arr , dp )\n    res = placeAdd or placeMinus\n    dp [ index ] [ Sum ] = res\n    return res\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY": "def findGreatest ( arr , n ) :\n    result = - 1\n    for i in range ( n ) :\n        for j in range ( n - 1 ) :\n            for k in range ( j + 1 , n ) :\n                if ( arr [ j ] * arr [ k ] == arr [ i ] ) :\n                    result = max ( result , arr [ i ] )\n    return result\n", "MAXIMUM_SUBARRAY_SUM_ARRAY_CREATED_REPEATED_CONCATENATION": "def maxSubArraySumRepeated ( a , n , k ) :\n    max_so_far = - 2147483648\n    max_ending_here = 0\n    for i in range ( n * k ) :\n        max_ending_here = max_ending_here + a [ i % n ]\n        if ( max_so_far < max_ending_here ) :\n            max_so_far = max_ending_here\n        if ( max_ending_here < 0 ) :\n            max_ending_here = 0\n    return max_so_far\n", "LEONARDO_NUMBER_1": "def leonardo ( n ) :\n    dp = [ ] ;\n    dp.append ( 1 ) ;\n    dp.append ( 1 ) ;\n    for i in range ( 2 , n + 1 ) :\n        dp.append ( dp [ i - 1 ] + dp [ i - 2 ] + 1 ) ;\n    return dp [ n ] ;\n", "SUM_OF_ALL_SUBSTRINGS_OF_A_STRING_REPRESENTING_A_NUMBER": "def sumOfSubstrings ( num ) :\n    n = len ( num )\n    sumofdigit = [ ]\n    sumofdigit.append ( int ( num [ 0 ] ) )\n    res = sumofdigit [ 0 ]\n    for i in range ( 1 , n ) :\n        numi = int ( num [ i ] )\n        sumofdigit.append ( ( i + 1 ) * numi + 10 * sumofdigit [ i - 1 ] )\n        res += sumofdigit [ i ]\n    return res\n", "PRUFER_CODE_TREE_CREATION": "def printTreeEdges ( prufer , m ) :\n    vertices = m + 2\n    vertex_set = [ 0 ] * vertices\n    for i in range ( vertices - 2 ) :\n        vertex_set [ prufer [ i ] - 1 ] += 1\n    print ( \"The edge set E(G) is :\" )\n    j = 0\n    for i in range ( vertices - 2 ) :\n        for j in range ( vertices ) :\n            if ( vertex_set [ j ] == 0 ) :\n                vertex_set [ j ] = - 1\n                print ( \"(\" , ( j + 1 ) , \", \" , prufer [ i ] , \") \" , sep = \"\" , end = \"\" )\n                vertex_set [ prufer [ i ] - 1 ] -= 1\n                break\n    j = 0\n    for i in range ( vertices ) :\n        if ( vertex_set [ i ] == 0 and j == 0 ) :\n            print ( \"(\" , ( i + 1 ) , \", \" , sep = \"\" , end = \"\" )\n            j += 1\n        elif ( vertex_set [ i ] == 0 and j == 1 ) :\n            print ( ( i + 1 ) , \")\" )\n", "PROGRAM_FIND_SMALLEST_DIFFERENCE_ANGLES_TWO_PARTS_GIVEN_CIRCLE": "def findMinimumAngle ( arr , n ) :\n    l = 0\n    _sum = 0\n    ans = 360\n    for i in range ( n ) :\n        _sum += arr [ i ]\n        while _sum >= 180 :\n            ans = min ( ans , 2 * abs ( 180 - _sum ) )\n            _sum -= arr [ l ]\n            l += 1\n        ans = min ( ans , 2 * abs ( 180 - _sum ) )\n    return ans\n", "FIND_MAXIMUM_AVERAGE_SUBARRAY_OF_K_LENGTH": "def findMaxAverage ( arr , n , k ) :\n    if k > n :\n        return - 1\n    csum = [ 0 ] * n\n    csum [ 0 ] = arr [ 0 ]\n    for i in range ( 1 , n ) :\n        csum [ i ] = csum [ i - 1 ] + arr [ i ] ;\n    max_sum = csum [ k - 1 ]\n    max_end = k - 1\n    for i in range ( k , n ) :\n        curr_sum = csum [ i ] - csum [ i - k ]\n        if curr_sum > max_sum :\n            max_sum = curr_sum\n            max_end = i\n    return max_end - k + 1\n", "SQUARE_PYRAMIDAL_NUMBER_SUM_SQUARES": "def findS ( s ) :\n    _sum = 0\n    n = 1\n    while ( _sum < s ) :\n        _sum += n * n\n        n += 1\n    n -= 1\n    if _sum == s :\n        return n\n    return - 1\n", "PROGRAM_TO_CALCULATE_AREA_OF_AN_CIRCLE_INSCRIBED_IN_A_SQUARE": "def areaOfInscribedCircle ( a ) :\n    return ( PI / 4 ) * a * a\n", "MINIMUM_NUMBER_CHARACTERS_REMOVED_MAKE_BINARY_STRING_ALTERNATE": "def countToMake0lternate ( s ) :\n    result = 0\n    for i in range ( len ( s ) - 1 ) :\n        if ( s [ i ] == s [ i + 1 ] ) :\n            result += 1\n    return result\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND": "def findMissing ( a , b , n , m ) :\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( a [ i ] == b [ j ] ) :\n                break\n        if ( j == m - 1 ) :\n            print ( a [ i ] , end = \" \" )\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM": "def rearrange ( arr , n ) :\n    temp = n * [ None ]\n    small , large = 0 , n - 1\n    flag = True\n    for i in range ( n ) :\n        if flag is True :\n            temp [ i ] = arr [ large ]\n            large -= 1\n        else :\n            temp [ i ] = arr [ small ]\n            small += 1\n        flag = bool ( 1 - flag )\n    for i in range ( n ) :\n        arr [ i ] = temp [ i ]\n    return arr\n", "DYNAMIC_PROGRAMMING_SET_15_LONGEST_BITONIC_SUBSEQUENCE": "def lbs ( arr ) :\n    n = len ( arr )\n    lis = [ 1 for i in range ( n + 1 ) ]\n    for i in range ( 1 , n ) :\n        for j in range ( 0 , i ) :\n            if ( ( arr [ i ] > arr [ j ] ) and ( lis [ i ] < lis [ j ] + 1 ) ) :\n                lis [ i ] = lis [ j ] + 1\n    lds = [ 1 for i in range ( n + 1 ) ]\n    for i in reversed ( range ( n - 1 ) ) :\n        for j in reversed ( range ( i - 1 , n ) ) :\n            if ( arr [ i ] > arr [ j ] and lds [ i ] < lds [ j ] + 1 ) :\n                lds [ i ] = lds [ j ] + 1\n    maximum = lis [ 0 ] + lds [ 0 ] - 1\n    for i in range ( 1 , n ) :\n        maximum = max ( ( lis [ i ] + lds [ i ] - 1 ) , maximum )\n    return maximum\n", "COUNT_PAIRS_WHOSE_PRODUCTS_EXIST_IN_ARRAY": "def countPairs ( arr , n ) :\n    result = 0 ;\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            product = arr [ i ] * arr [ j ] ;\n            for k in range ( 0 , n ) :\n                if ( arr [ k ] == product ) :\n                    result = result + 1 ;\n                    break ;\n    return result ;\n", "COUNT_SINGLE_NODE_ISOLATED_SUB_GRAPHS_DISCONNECTED_GRAPH": "def compute ( graph , N ) :\n    count = 0\n    for i in range ( 1 , N + 1 ) :\n        if ( len ( graph [ i ] ) == 0 ) :\n            count += 1\n    return count\n", "HARDY_RAMANUJAN_THEOREM": "def exactPrimeFactorCount ( n ) :\n    count = 0\n    if ( n % 2 == 0 ) :\n        count = count + 1\n        while ( n % 2 == 0 ) :\n            n = int ( n / 2 )\n    i = 3\n    while ( i <= int ( math.sqrt ( n ) ) ) :\n        if ( n % i == 0 ) :\n            count = count + 1\n            while ( n % i == 0 ) :\n                n = int ( n / i )\n        i = i + 2\n    if ( n > 2 ) :\n        count = count + 1\n    return count\n", "SHORTEST_COMMON_SUPERSEQUENCE_1": "def superSeq ( X , Y , m , n ) :\n    dp = [ [ 0 ] * ( n + 2 ) for i in range ( m + 2 ) ]\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            if ( not i ) : dp [ i ] [ j ] = j\n            elif ( not j ) : dp [ i ] [ j ] = i\n            elif ( X [ i - 1 ] == Y [ j - 1 ] ) :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ]\n            else : dp [ i ] [ j ] = 1 + min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] )\n    return dp [ m ] [ n ]\n", "POWER_SET": "def printPowerSet ( set , set_size ) :\n    pow_set_size = ( int ) ( math.pow ( 2 , set_size ) ) ;\n    counter = 0 ;\n    j = 0 ;\n    for counter in range ( 0 , pow_set_size ) :\n        for j in range ( 0 , set_size ) :\n            if ( ( counter & ( 1 << j ) ) > 0 ) :\n                print ( set [ j ] , end = \"\" ) ;\n        print ( \"\" ) ;\n", "CHECK_ARRAY_MAJORITY_ELEMENT": "def isMajority ( a ) :\n    mp = { }\n    for i in a :\n        if i in mp : mp [ i ] += 1\n        else : mp [ i ] = 1\n    for x in mp :\n        if mp [ x ] >= len ( a ) // 2 :\n            return True\n    return False\n", "PRINT_GIVEN_MATRIX_COUNTER_CLOCK_WISE_SPIRAL_FORM": "def counterClockspiralPrint ( m , n , arr ) :\n    k = 0 ; l = 0\n    cnt = 0\n    total = m * n\n    while ( k < m and l < n ) :\n        if ( cnt == total ) :\n            break\n        for i in range ( k , m ) :\n            print ( arr [ i ] [ l ] , end = \" \" )\n            cnt += 1\n        l += 1\n        if ( cnt == total ) :\n            break\n        for i in range ( l , n ) :\n            print ( arr [ m - 1 ] [ i ] , end = \" \" )\n            cnt += 1\n        m -= 1\n        if ( cnt == total ) :\n            break\n        if ( k < m ) :\n            for i in range ( m - 1 , k - 1 , - 1 ) :\n                print ( arr [ i ] [ n - 1 ] , end = \" \" )\n                cnt += 1\n            n -= 1\n        if ( cnt == total ) :\n            break\n        if ( l < n ) :\n            for i in range ( n - 1 , l - 1 , - 1 ) :\n                print ( arr [ k ] [ i ] , end = \" \" )\n                cnt += 1\n            k += 1\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD": "def isPrime ( n ) :\n    if n <= 1 :\n        return False\n    for i in range ( 2 , n ) :\n        if n % i == 0 :\n            return False ;\n    return True\n", "FIND_CHARACTER_FIRST_STRING_PRESENT_MINIMUM_INDEX_SECOND_STRING": "def printMinIndexChar ( Str , patt ) :\n    minIndex = 10 ** 9\n    m = len ( Str )\n    n = len ( patt )\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( patt [ i ] == Str [ j ] and j < minIndex ) :\n                minIndex = j\n                break\n    if ( minIndex != 10 ** 9 ) :\n        print ( \"Minimum Index Character = \" , Str [ minIndex ] )\n    else :\n        print ( \"No character present\" )\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX_1": "def transpose ( A , B ) :\n    for i in range ( N ) :\n        for j in range ( M ) :\n            B [ i ] [ j ] = A [ j ] [ i ]\n", "COUNT_NATURAL_NUMBERS_WHOSE_PERMUTATION_GREATER_NUMBER": "def countNumber ( n ) :\n    result = 0\n    for i in range ( 1 , 10 ) :\n        s = [ ]\n        if ( i <= n ) :\n            s.append ( i )\n            result += 1\n        while len ( s ) != 0 :\n            tp = s [ - 1 ]\n            s.pop ( )\n            for j in range ( tp % 10 , 10 ) :\n                x = tp * 10 + j\n                if ( x <= n ) :\n                    s.append ( x )\n                    result += 1\n    return result\n", "FIND_FIRST_NATURAL_NUMBER_WHOSE_FACTORIAL_DIVISIBLE_X": "def firstFactorialDivisibleNumber ( x ) :\n    i = 1 ;\n    fact = 1 ;\n    for i in range ( 1 , x ) :\n        fact = fact * i\n        if ( fact % x == 0 ) :\n            break\n    return i\n", "PRINT_EQUAL_SUM_SETS_ARRAY_PARTITION_PROBLEM_SET_2": "def printEqualSumSets ( arr , n ) :\n    sum_array = sum ( arr )\n    if ( sum_array & 1 ) :\n        print ( \"-1\" )\n        return\n    k = sum_array >> 1\n    dp = np.zeros ( ( n + 1 , k + 1 ) )\n    for i in range ( 1 , k + 1 ) :\n        dp [ 0 ] [ i ] = False\n    for i in range ( n + 1 ) :\n        dp [ i ] [ 0 ] = True\n    for i in range ( 1 , n + 1 ) :\n        for currSum in range ( 1 , k + 1 ) :\n            dp [ i ] [ currSum ] = dp [ i - 1 ] [ currSum ]\n            if ( arr [ i - 1 ] <= currSum ) :\n                dp [ i ] [ currSum ] = ( dp [ i ] [ currSum ] or dp [ i - 1 ] [ currSum - arr [ i - 1 ] ] )\n    set1 , set2 = [ ] , [ ]\n    if ( not dp [ n ] [ k ] ) :\n        print ( \"-1\" )\n        return\n    i = n\n    currSum = k\n    while ( i > 0 and currSum >= 0 ) :\n        if ( dp [ i - 1 ] [ currSum ] ) :\n            i -= 1\n            set2.append ( arr [ i ] )\n        elif ( dp [ i - 1 ] [ currSum - arr [ i - 1 ] ] ) :\n            i -= 1\n            currSum -= arr [ i ]\n            set1.append ( arr [ i ] )\n    print ( \"Set 1 elements:\" , end = \" \" )\n    for i in range ( len ( set1 ) ) :\n        print ( set1 [ i ] , end = \" \" )\n    print ( \"\\nSet 2 elements:\" , end = \" \" )\n    for i in range ( len ( set2 ) ) :\n        print ( set2 [ i ] , end = \" \" )\n", "COUNTING_PAIRS_PERSON_CAN_FORM_PAIR_ONE_1": "def numberOfWays ( x ) :\n    if x == 0 or x == 1 :\n        return 1\n    else :\n        return ( numberOfWays ( x - 1 ) + ( x - 1 ) * numberOfWays ( x - 2 ) )\n", "COUNT_NEGATIVE_NUMBERS_IN_A_COLUMN_WISE_ROW_WISE_SORTED_MATRIX": "def countNegative ( M , n , m ) :\n    count = 0\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if M [ i ] [ j ] < 0 :\n                count += 1\n            else :\n                break\n    return count\n", "COUNT_SET_BITS_IN_AN_INTEGER": "def countSetBits ( n ) :\n    count = 0\n    while ( n ) :\n        count += n & 1\n        n >>= 1\n    return count\n", "MODULUS_TWO_FLOAT_DOUBLE_NUMBERS": "def findMod ( a , b ) :\n    if ( a < 0 ) :\n        a = - a\n    if ( b < 0 ) :\n        b = - b\n    mod = a\n    while ( mod >= b ) :\n        mod = mod - b\n    if ( a < 0 ) :\n        return - mod\n    return mod\n", "FIND_A_SPECIFIC_PAIR_IN_MATRIX_1": "def findMaxValue ( mat ) :\n    maxValue = - sys.maxsize - 1\n    maxArr = [ [ 0 for x in range ( N ) ] for y in range ( N ) ]\n    maxArr [ N - 1 ] [ N - 1 ] = mat [ N - 1 ] [ N - 1 ]\n    maxv = mat [ N - 1 ] [ N - 1 ] ;\n    for j in range ( N - 2 , - 1 , - 1 ) :\n        if ( mat [ N - 1 ] [ j ] > maxv ) :\n            maxv = mat [ N - 1 ] [ j ]\n        maxArr [ N - 1 ] [ j ] = maxv\n    maxv = mat [ N - 1 ] [ N - 1 ]\n    for i in range ( N - 2 , - 1 , - 1 ) :\n        if ( mat [ i ] [ N - 1 ] > maxv ) :\n            maxv = mat [ i ] [ N - 1 ]\n        maxArr [ i ] [ N - 1 ] = maxv\n    for i in range ( N - 2 , - 1 , - 1 ) :\n        for j in range ( N - 2 , - 1 , - 1 ) :\n            if ( maxArr [ i + 1 ] [ j + 1 ] - mat [ i ] [ j ] > maxValue ) :\n                maxValue = ( maxArr [ i + 1 ] [ j + 1 ] - mat [ i ] [ j ] )\n            maxArr [ i ] [ j ] = max ( mat [ i ] [ j ] , max ( maxArr [ i ] [ j + 1 ] , maxArr [ i + 1 ] [ j ] ) )\n    return maxValue\n", "MINIMUM_SUM_TWO_NUMBERS_FORMED_DIGITS_ARRAY": "def solve ( arr , n ) :\n    arr.sort ( )\n    a = 0 ; b = 0\n    for i in range ( n ) :\n        if ( i % 2 != 0 ) :\n            a = a * 10 + arr [ i ]\n        else :\n            b = b * 10 + arr [ i ]\n    return a + b\n", "COUNT_DISTINCT_NON_NEGATIVE_PAIRS_X_Y_SATISFY_INEQUALITY_XX_YY_N_2_1": "def countSolutions ( n ) :\n    x = 0\n    res = 0\n    yCount = 0\n    while ( yCount * yCount < n ) :\n        yCount = yCount + 1\n    while ( yCount != 0 ) :\n        res = res + yCount\n        x = x + 1\n        while ( yCount != 0 and ( x * x + ( yCount - 1 ) * ( yCount - 1 ) >= n ) ) :\n            yCount = yCount - 1\n    return res\n", "FIND_INDEX_GIVEN_FIBONACCI_NUMBER_CONSTANT_TIME": "def findIndex ( n ) :\n    if ( n <= 1 ) :\n        return n\n    a = 0\n    b = 1\n    c = 1\n    res = 1\n    while ( c < n ) :\n        c = a + b\n        res = res + 1\n        a = b\n        b = c\n    return res\n", "PROGRAM_OCTAL_DECIMAL_CONVERSION": "def octalToDecimal ( n ) :\n    num = n ;\n    dec_value = 0 ;\n    base = 1 ;\n    temp = num ;\n    while ( temp ) :\n        last_digit = temp % 10 ;\n        temp = int ( temp / 10 ) ;\n        dec_value += last_digit * base ;\n        base = base * 8 ;\n    return dec_value ;\n", "FIND_PERMUTED_ROWS_GIVEN_ROW_MATRIX": "def permutatedRows ( mat , m , n , r ) :\n    s = set ( )\n    for j in range ( n ) :\n        s.add ( mat [ r ] [ j ] )\n    for i in range ( m ) :\n        if i == r :\n            continue\n        for j in range ( n ) :\n            if mat [ i ] [ j ] not in s :\n                j = j - 2\n                break ;\n        if j + 1 != n :\n            continue\n        print ( i )\n", "PRINT_A_CLOSEST_STRING_THAT_DOES_NOT_CONTAIN_ADJACENT_DUPLICATES": "def noAdjacentDup ( s ) :\n    n = len ( s )\n    for i in range ( 1 , n ) :\n        if ( s [ i ] == s [ i - 1 ] ) :\n            s [ i ] = \"a\"\n            while ( s [ i ] == s [ i - 1 ] or ( i + 1 < n and s [ i ] == s [ i + 1 ] ) ) :\n                s [ i ] += 1\n            i += 1\n    return s\n", "SUM_MANHATTAN_DISTANCES_PAIRS_POINTS": "def distancesum ( x , y , n ) :\n    sum = 0\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            sum += ( abs ( x [ i ] - x [ j ] ) + abs ( y [ i ] - y [ j ] ) )\n    return sum\n", "PROGRAM_FIND_STRING_START_END_GEEKS": "def isCornerPresent ( str , corner ) :\n    n = len ( str )\n    cl = len ( corner )\n    if ( n < cl ) :\n        return False\n    return ( ( str [ : cl ] == corner ) and ( str [ n - cl : ] == corner ) )\n", "LONGEST_SUBARRAY_COUNT_1S_ONE_COUNT_0S": "def lenOfLongSubarr ( arr , n ) :\n    um = { i : 0 for i in range ( 10 ) }\n    sum = 0\n    maxLen = 0\n    for i in range ( n ) :\n        if arr [ i ] == 0 :\n            sum += - 1\n        else :\n            sum += 1\n        if ( sum == 1 ) :\n            maxLen = i + 1\n        elif ( sum not in um ) :\n            um [ sum ] = i\n        if ( ( sum - 1 ) in um ) :\n            if ( maxLen < ( i - um [ sum - 1 ] ) ) :\n                maxLen = i - um [ sum - 1 ]\n    return maxLen\n", "DIVIDE_CONQUER_SET_6_SEARCH_ROW_WISE_COLUMN_WISE_SORTED_2D_ARRAY": "def search ( mat , fromRow , toRow , fromCol , toCol , key ) :\n    i = fromRow + ( toRow - fromRow ) // 2 ;\n    j = fromCol + ( toCol - fromCol ) // 2 ;\n    if ( mat [ i ] [ j ] == key ) :\n        print ( \"Found \" , key , \" at \" , i , \" \" , j ) ;\n    else :\n        if ( i != toRow or j != fromCol ) :\n            search ( mat , fromRow , i , j , toCol , key ) ;\n        if ( fromRow == toRow and fromCol + 1 == toCol ) :\n            if ( mat [ fromRow ] [ toCol ] == key ) :\n                print ( \"Found \" , key , \" at \" , fromRow , \" \" , toCol ) ;\n        if ( mat [ i ] [ j ] < key ) :\n            if ( i + 1 <= toRow ) :\n                search ( mat , i + 1 , toRow , fromCol , toCol , key ) ;\n        else :\n            if ( j - 1 >= fromCol ) :\n                search ( mat , fromRow , toRow , fromCol , j - 1 , key ) ;\n", "SHORTEST_COMMON_SUPERSEQUENCE": "def superSeq ( X , Y , m , n ) :\n    if ( not m ) : return n\n    if ( not n ) : return m\n    if ( X [ m - 1 ] == Y [ n - 1 ] ) :\n        return 1 + superSeq ( X , Y , m - 1 , n - 1 )\n    return 1 + min ( superSeq ( X , Y , m - 1 , n ) , superSeq ( X , Y , m , n - 1 ) )\n", "URLIFY_GIVEN_STRING_REPLACE_SPACES": "def replaceSpaces ( string ) :\n    string = string.strip ( )\n    i = len ( string )\n    space_count = string.count ( '' )\n    new_length = i + space_count * 2\n    if new_length > MAX :\n        return - 1\n    index = new_length - 1\n    string = list ( string )\n    for f in range ( i - 2 , new_length - 2 ) :\n        string.append ( '0' )\n    for j in range ( i - 1 , 0 , - 1 ) :\n        if string [ j ] == '' :\n            string [ index ] = '0'\n            string [ index - 1 ] = '2'\n            string [ index - 2 ] = '%'\n            index = index - 3\n        else :\n            string [ index ] = string [ j ]\n            index -= 1\n    return ''.join ( string )\n", "MAXIMUM_PATH_SUM_STARTING_CELL_0_TH_ROW_ENDING_CELL_N_1_TH_ROW": "def MaximumPath ( Mat ) :\n    result = 0\n    dp = [ [ 0 for i in range ( N + 2 ) ] for j in range ( N ) ]\n    for i in range ( N ) :\n        for j in range ( 1 , N + 1 ) :\n            dp [ i ] [ j ] = max ( dp [ i - 1 ] [ j - 1 ] , max ( dp [ i - 1 ] [ j ] , dp [ i - 1 ] [ j + 1 ] ) ) + \\\n                Mat [ i ] [ j - 1 ]\n    for i in range ( N + 1 ) :\n        result = max ( result , dp [ N - 1 ] [ i ] )\n    return result\n", "COMPUTE_THE_INTEGER_ABSOLUTE_VALUE_ABS_WITHOUT_BRANCHING": "def getAbs ( n ) :\n    mask = n >> ( SIZE_INT * CHARBIT - 1 ) ;\n    return ( ( n + mask ) ^ mask ) ;\n", "COUNT_PALINDROMIC_SUBSEQUENCE_GIVEN_STRING_1": "def countPS ( i , j ) :\n    if ( i >= n or j < 0 ) :\n        return 0\n    if ( dp [ i ] [ j ] != - 1 ) :\n        return dp [ i ] [ j ]\n    if ( abs ( i - j ) == 1 ) :\n        if ( str [ i ] == str [ j ] ) :\n            dp [ i ] [ j ] = 3\n            return dp [ i ] [ j ]\n        else :\n            dp [ i ] [ j ] = 2\n            return dp [ i ] [ j ]\n    if ( i == j ) :\n        dp [ 1 ] [ j ] = 1\n        return dp [ 1 ] [ j ]\n    elif ( str [ i ] == str [ j ] ) :\n        dp [ i ] [ j ] = ( countPS ( i + 1 , j ) + countPS ( i , j - 1 ) + 1 )\n        return dp [ i ] [ j ]\n    else :\n        dp [ i ] [ j ] = ( countPS ( i + 1 , j ) + countPS ( i , j - 1 ) - countPS ( i + 1 , j - 1 ) )\n        return dp [ i ] [ j ]\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY_2": "def maxSubArraySum ( a , size ) :\n    max_so_far = a [ 0 ]\n    curr_max = a [ 0 ]\n    for i in range ( 1 , size ) :\n        curr_max = max ( a [ i ] , curr_max + a [ i ] )\n        max_so_far = max ( max_so_far , curr_max )\n    return max_so_far\n", "COUNT_MINIMUM_STEPS_GET_GIVEN_DESIRED_ARRAY": "def countMinOperations ( target , n ) :\n    result = 0 ;\n    while ( True ) :\n        zero_count = 0 ;\n        i = 0 ;\n        while ( i < n ) :\n            if ( ( target [ i ] & 1 ) > 0 ) :\n                break ;\n            elif ( target [ i ] == 0 ) :\n                zero_count += 1 ;\n            i += 1 ;\n        if ( zero_count == n ) :\n            return result ;\n        if ( i == n ) :\n            for j in range ( n ) :\n                target [ j ] = target [ j ] // 2 ;\n            result += 1 ;\n        for j in range ( i , n ) :\n            if ( target [ j ] & 1 ) :\n                target [ j ] -= 1 ;\n                result += 1 ;\n", "PRINT_FIBONACCI_SEQUENCE_USING_2_VARIABLES_1": "def fib ( n ) :\n    a = 0\n    b = 1\n    if ( n >= 0 ) :\n        print ( a , end = ' ' )\n    if ( n >= 1 ) :\n        print ( b , end = ' ' )\n    for i in range ( 2 , n + 1 ) :\n        print ( a + b , end = ' ' )\n        b = a + b\n        a = b - a\n", "PROGRAM_CHECK_INPUT_INTEGER_STRING": "def isNumber ( s ) :\n    for i in range ( len ( s ) ) :\n        if s [ i ].isdigit ( ) != True :\n            return False\n    return True\n", "MINIMUM_HEIGHT_TRIANGLE_GIVEN_BASE_AREA": "def minHeight ( area , base ) :\n    return math.ceil ( ( 2 * area ) / base )\n", "FIND_POSITION_GIVEN_NUMBER_AMONG_NUMBERS_MADE_4_7": "def findpos ( n ) :\n    i = 0\n    j = len ( n )\n    pos = 0\n    while ( i < j ) :\n        if ( n [ i ] == '4' ) :\n            pos = pos * 2 + 1\n        if ( n [ i ] == '7' ) :\n            pos = pos * 2 + 2\n        i = i + 1\n    return pos\n", "MINIMUM_OPERATIONS_REQUIRED_SET_ELEMENTS_BINARY_MATRIX": "def minOperation ( arr ) :\n    ans = 0\n    for i in range ( N - 1 , - 1 , - 1 ) :\n        for j in range ( M - 1 , - 1 , - 1 ) :\n            if ( arr [ i ] [ j ] == 0 ) :\n                ans += 1\n                for k in range ( i + 1 ) :\n                    for h in range ( j + 1 ) :\n                        if ( arr [ k ] [ h ] == 1 ) :\n                            arr [ k ] [ h ] = 0\n                        else :\n                            arr [ k ] [ h ] = 1\n    return ans\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_2": "def findLength ( string , n ) :\n    Sum = [ 0 ] * ( n + 1 )\n    for i in range ( 1 , n + 1 ) :\n        Sum [ i ] = ( Sum [ i - 1 ] + int ( string [ i - 1 ] ) )\n    ans = 0\n    for length in range ( 2 , n + 1 , 2 ) :\n        for i in range ( 0 , n - length + 1 ) :\n            j = i + length - 1\n            if ( Sum [ i + length // 2 ] - Sum [ i ] == Sum [ i + length ] - Sum [ i + length // 2 ] ) :\n                ans = max ( ans , length )\n    return ans\n", "MULTIPLY_LARGE_NUMBERS_REPRESENTED_AS_STRINGS": "def multiply ( num1 , num2 ) :\n    len1 = len ( num1 )\n    len2 = len ( num2 )\n    if len1 == 0 or len2 == 0 :\n        return \"0\"\n    result = [ 0 ] * ( len1 + len2 )\n    i_n1 = 0\n    i_n2 = 0\n    for i in range ( len1 - 1 , - 1 , - 1 ) :\n        carry = 0\n        n1 = ord ( num1 [ i ] ) - 48\n        i_n2 = 0\n        for j in range ( len2 - 1 , - 1 , - 1 ) :\n            n2 = ord ( num2 [ j ] ) - 48\n            summ = n1 * n2 + result [ i_n1 + i_n2 ] + carry\n            carry = summ // 10\n            result [ i_n1 + i_n2 ] = summ % 10\n            i_n2 += 1\n        if ( carry > 0 ) :\n            result [ i_n1 + i_n2 ] += carry\n        i_n1 += 1\n    i = len ( result ) - 1\n    while ( i >= 0 and result [ i ] == 0 ) :\n        i -= 1\n    if ( i == - 1 ) :\n        return \"0\"\n    s = \"\"\n    while ( i >= 0 ) :\n        s += chr ( result [ i ] + 48 )\n        i -= 1\n    return s\n", "PARTITION_NUMBER_TWO_DIVISBLE_PARTS": "def findDivision ( str , a , b ) :\n    lenn = len ( str )\n    lr = [ 0 ] * ( lenn + 1 )\n    lr [ 0 ] = ( int ( str [ 0 ] ) ) % a\n    for i in range ( 1 , lenn ) :\n        lr [ i ] = ( ( lr [ i - 1 ] * 10 ) % a + \\ int ( str [ i ] ) ) % a\n    rl = [ 0 ] * ( lenn + 1 )\n    rl [ lenn - 1 ] = int ( str [ lenn - 1 ] ) % b\n    power10 = 10\n    for i in range ( lenn - 2 , - 1 , - 1 ) :\n        rl [ i ] = ( rl [ i + 1 ] + int ( str [ i ] ) * power10 ) % b\n        power10 = ( power10 * 10 ) % b\n    for i in range ( 0 , lenn - 1 ) :\n        if ( lr [ i ] != 0 ) :\n            continue\n        if ( rl [ i + 1 ] == 0 ) :\n            print ( \"YES\" )\n            for k in range ( 0 , i + 1 ) :\n                print ( str [ k ] , end = \"\" )\n            print ( \",\" , end = \"\" )\n            for i in range ( i + 1 , lenn ) :\n                print ( str [ k ] , end = \"\" )\n                return\n    print ( \"NO\" )\n", "PROGRAM_BEST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "def bestFit ( blockSize , m , processSize , n ) :\n    allocation = [ - 1 ] * n\n    for i in range ( n ) :\n        bestIdx = - 1\n        for j in range ( m ) :\n            if blockSize [ j ] >= processSize [ i ] :\n                if bestIdx == - 1 :\n                    bestIdx = j\n                elif blockSize [ bestIdx ] > blockSize [ j ] :\n                    bestIdx = j\n        if bestIdx != - 1 :\n            allocation [ i ] = bestIdx\n            blockSize [ bestIdx ] -= processSize [ i ]\n    print ( \"Process No.Process Size     Block no.\" )\n    for i in range ( n ) :\n        print ( i + 1 , \"         \" , processSize [ i ] , end = \"         \" )\n        if allocation [ i ] != - 1 :\n            print ( allocation [ i ] + 1 )\n        else :\n            print ( \"Not Allocated\" )\n", "FINDING_THE_MAXIMUM_SQUARE_SUB_MATRIX_WITH_ALL_EQUAL_ELEMENTS": "def largestKSubmatrix ( a ) :\n    dp = [ [ 0 for x in range ( Row ) ] for y in range ( Col ) ]\n    result = 0\n    for i in range ( Row ) :\n        for j in range ( Col ) :\n            if ( i == 0 or j == 0 ) :\n                dp [ i ] [ j ] = 1\n            else :\n                if ( a [ i ] [ j ] == a [ i - 1 ] [ j ] and a [ i ] [ j ] == a [ i ] [ j - 1 ] and a [ i ] [ j ] == a [ i - 1 ] [ j - 1 ] ) :\n                    dp [ i ] [ j ] = min ( min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) , dp [ i - 1 ] [ j - 1 ] ) + 1\n                else :\n                    dp [ i ] [ j ] = 1\n            result = max ( result , dp [ i ] [ j ] )\n    return result\n", "FRIENDS_PAIRING_PROBLEM_1": "def countFriendsPairings ( n ) :\n    dp = [ - 1 ] * 100\n    if ( dp [ n ] != - 1 ) :\n        return dp [ n ]\n    if ( n > 2 ) :\n        dp [ n ] = ( countFriendsPairings ( n - 1 ) + ( n - 1 ) * countFriendsPairings ( n - 2 ) )\n        return dp [ n ]\n    else :\n        dp [ n ] = n\n        return dp [ n ]\n", "FIRST_ELEMENT_OCCURRING_K_TIMES_ARRAY": "def firstElement ( arr , n , k ) :\n    count_map = { } ;\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] in count_map.keys ( ) ) :\n            count_map [ arr [ i ] ] += 1\n        else :\n            count_map [ arr [ i ] ] = 1\n        i += 1\n    for i in range ( 0 , n ) :\n        if ( count_map [ arr [ i ] ] == k ) :\n            return arr [ i ]\n        i += 1\n    return - 1\n", "SUM_SERIES_0_6_0_06_0_006_0_0006_N_TERMS": "def sumOfSeries ( n ) :\n    return ( ( 0.666 ) * ( 1 - 1 / pow ( 10 , n ) ) ) ;\n", "COUNT_WORDS_IN_A_GIVEN_STRING": "def countWords ( string ) :\n    state = OUT\n    wc = 0\n    for i in range ( len ( string ) ) :\n        if ( string [ i ] == ' ' or string [ i ] == '\\n' or string [ i ] == '\\t' ) :\n            state = OUT\n        elif state == OUT :\n            state = IN\n            wc += 1\n    return wc\n", "PARTITION_INTO_TWO_SUBARRAYS_OF_LENGTHS_K_AND_N_K_SUCH_THAT_THE_DIFFERENCE_OF_SUMS_IS_MAXIMUM": "def maxDifference ( arr , N , k ) :\n    S = 0\n    S1 = 0\n    max_difference = 0\n    for i in range ( N ) :\n        S += arr [ i ]\n    arr.sort ( reverse = True )\n    M = max ( k , N - k )\n    for i in range ( M ) :\n        S1 += arr [ i ]\n    max_difference = S1 - ( S - S1 )\n    return max_difference\n", "HOW_WILL_YOU_PRINT_NUMBERS_FROM_1_TO_200_WITHOUT_USING_LOOP": "def printNos ( n ) :\n    if n > 0 :\n        printNos ( n - 1 )\n        print ( n , end = ' ' )\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM_1": "def pairsInSortedRotated ( arr , n , x ) :\n    for i in range ( n ) :\n        if arr [ i ] > arr [ i + 1 ] :\n            break\n    l = ( i + 1 ) % n\n    r = i\n    cnt = 0\n    while ( l != r ) :\n        if arr [ l ] + arr [ r ] == x :\n            cnt += 1\n            if l == ( r - 1 + n ) % n :\n                return cnt\n            l = ( l + 1 ) % n\n            r = ( r - 1 + n ) % n\n        elif arr [ l ] + arr [ r ] < x :\n            l = ( l + 1 ) % n\n        else :\n            r = ( n + r - 1 ) % n\n    return cnt\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE": "def getSingle ( arr , n ) :\n    ones = 0\n    twos = 0\n    for i in range ( n ) :\n        twos = twos | ( ones & arr [ i ] )\n        ones = ones ^ arr [ i ]\n        common_bit_mask = ~ ( ones & twos )\n        ones &= common_bit_mask\n        twos &= common_bit_mask\n    return ones\n", "CASSINIS_IDENTITY": "def cassini ( n ) :\n    return - 1 if ( n & 1 ) else 1\n", "DISTRIBUTING_ALL_BALLS_WITHOUT_REPETITION": "def distributingBalls ( k , n , string ) :\n    a = [ 0 ] * MAX_CHAR\n    for i in range ( n ) :\n        a [ ord ( string [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( MAX_CHAR ) :\n        if ( a [ i ] > k ) :\n            return False\n    return True\n", "DISTRIBUTING_ITEMS_PERSON_CANNOT_TAKE_TWO_ITEMS_TYPE": "def checkCount ( arr , n , k ) :\n    for i in range ( n ) :\n        count = 0\n        for j in range ( n ) :\n            if arr [ j ] == arr [ i ] :\n                count += 1\n            if count > 2 * k :\n                return False\n    return True\n", "MAXIMIZE_ARRJ_ARRI_ARRL_ARRK_SUCH_THAT_I_J_K_L": "def findMaxValue ( arr , n ) :\n    if n < 4 :\n        print ( \"The array should have atlest 4 elements\" )\n        return MIN\n    table1 , table2 = [ MIN ] * ( n + 1 ) , [ MIN ] * n\n    table3 , table4 = [ MIN ] * ( n - 1 ) , [ MIN ] * ( n - 2 )\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        table1 [ i ] = max ( table1 [ i + 1 ] , arr [ i ] )\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        table2 [ i ] = max ( table2 [ i + 1 ] , table1 [ i + 1 ] - arr [ i ] )\n    for i in range ( n - 3 , - 1 , - 1 ) :\n        table3 [ i ] = max ( table3 [ i + 1 ] , table2 [ i + 1 ] + arr [ i ] )\n    for i in range ( n - 4 , - 1 , - 1 ) :\n        table4 [ i ] = max ( table4 [ i + 1 ] , table3 [ i + 1 ] - arr [ i ] )\n    return table4 [ 0 ]\n", "COUNT_NEGATIVE_NUMBERS_IN_A_COLUMN_WISE_ROW_WISE_SORTED_MATRIX_1": "def countNegative ( M , n , m ) :\n    count = 0\n    i = 0\n    j = m - 1\n    while j >= 0 and i < n :\n        if M [ i ] [ j ] < 0 :\n            count += ( j + 1 )\n            i += 1\n        else :\n            j -= 1\n    return count\n", "SORT_AN_ARRAY_OF_0S_1S_AND_2S": "def sort012 ( a , arr_size ) :\n    lo = 0\n    hi = arr_size - 1\n    mid = 0\n    while mid <= hi :\n        if a [ mid ] == 0 :\n            a [ lo ] , a [ mid ] = a [ mid ] , a [ lo ]\n            lo = lo + 1\n            mid = mid + 1\n        elif a [ mid ] == 1 :\n            mid = mid + 1\n        else :\n            a [ mid ] , a [ hi ] = a [ hi ] , a [ mid ]\n            hi = hi - 1\n", "NTH_EVEN_FIBONACCI_NUMBER": "def evenFib ( n ) :\n    if ( n < 1 ) :\n        return n\n    if ( n == 1 ) :\n        return 2\n    return ( ( 4 * evenFib ( n - 1 ) ) + evenFib ( n - 2 ) )\n", "NEXT_GREATER_ELEMENT": "def printNGE ( arr ) :\n    for i in range ( 0 , len ( arr ) , 1 ) :\n        next = - 1\n        for j in range ( i + 1 , len ( arr ) , 1 ) :\n            if arr [ i ] < arr [ j ] :\n                next = arr [ j ]\n                break\n        print ( str ( arr [ i ] ) + \" -- \" + str ( next ) )\n", "CHECK_WHETHER_GIVEN_CIRCLE_RESIDE_BOUNDARY_MAINTAINED_OUTER_CIRCLE_INNER_CIRCLE": "def fitOrNotFit ( R , r , x , y , rad ) :\n    val = math.sqrt ( math.pow ( x , 2 ) + math.pow ( y , 2 ) )\n    if ( val + rad <= R and val - rad >= R - r ) :\n        print ( \"Fits\\n\" )\n    else :\n        print ( \"Doesn't Fit\" )\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS_1": "def gcdExtended ( a , b , x , y ) :\n    if a == 0 :\n        x = 0\n        y = 1\n        return b\n    x1 = 1\n    y1 = 1\n    gcd = gcdExtended ( b % a , a , x1 , y1 )\n    x = y1 - ( b / a ) * x1\n    y = x1\n    return gcd\n", "FIND_SMALLEST_RANGE_CONTAINING_ELEMENTS_FROM_K_LISTS": "def findSmallestRange ( arr , n , k ) :\n    i , minval , maxval , minrange , minel , maxel , flag , minind = 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0\n    for i in range ( k + 1 ) :\n        ptr [ i ] = 0\n    minrange = 10 ** 9\n    while ( 1 ) :\n        minind = - 1\n        minval = 10 ** 9\n        maxval = - 10 ** 9\n        flag = 0\n        for i in range ( k ) :\n            if ( ptr [ i ] == n ) :\n                flag = 1\n                break\n            if ( ptr [ i ] < n and arr [ i ] [ ptr [ i ] ] < minval ) :\n                minind = i\n                minval = arr [ i ] [ ptr [ i ] ]\n            if ( ptr [ i ] < n and arr [ i ] [ ptr [ i ] ] > maxval ) :\n                maxval = arr [ i ] [ ptr [ i ] ]\n        if ( flag ) :\n            break\n        ptr [ minind ] += 1\n        if ( ( maxval - minval ) < minrange ) :\n            minel = minval\n            maxel = maxval\n            minrange = maxel - minel\n    print ( \"The smallest range is [\" , minel , maxel , \"]\" )\n", "FIND_THE_MINIMUM_COST_TO_REACH_A_DESTINATION_WHERE_EVERY_STATION_IS_CONNECTED_IN_ONE_DIRECTION": "def minCost ( cost ) :\n    dist = [ 0 for i in range ( N ) ]\n    for i in range ( N ) :\n        dist [ i ] = INF\n    dist [ 0 ] = 0\n    for i in range ( N ) :\n        for j in range ( i + 1 , N ) :\n            if ( dist [ j ] > dist [ i ] + cost [ i ] [ j ] ) :\n                dist [ j ] = dist [ i ] + cost [ i ] [ j ]\n    return dist [ N - 1 ]\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS_1": "def middleOfThree ( a , b , c ) :\n    if a > b :\n        if ( b > c ) :\n            return b\n        elif ( a > c ) :\n            return c\n        else :\n            return a\n    else :\n        if ( a > c ) :\n            return a\n        elif ( b > c ) :\n            return c\n        else :\n            return b\n", "CHECK_LARGE_NUMBER_DIVISIBLE_11_NOT": "def check ( st ) :\n    n = len ( st )\n    oddDigSum = 0\n    evenDigSum = 0\n    for i in range ( 0 , n ) :\n        if ( i % 2 == 0 ) :\n            oddDigSum = oddDigSum + ( ( int ) ( st [ i ] ) )\n        else :\n            evenDigSum = evenDigSum + ( ( int ) ( st [ i ] ) )\n    return ( ( oddDigSum - evenDigSum ) % 11 == 0 )\n", "COMPUTE_MODULUS_DIVISION_BY_A_POWER_OF_2_NUMBER": "def getModulo ( n , d ) :\n    return ( n & ( d - 1 ) )\n", "COUNT_BINARY_STRINGS_K_TIMES_APPEARING_ADJACENT_TWO_SET_BITS": "def countStrings ( n , k ) :\n    dp = [ [ [ 0 , 0 ] for __ in range ( k + 1 ) ] for _ in range ( n + 1 ) ]\n    dp [ 1 ] [ 0 ] [ 0 ] = 1\n    dp [ 1 ] [ 0 ] [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( k + 1 ) :\n            dp [ i ] [ j ] [ 0 ] = ( dp [ i - 1 ] [ j ] [ 0 ] + dp [ i - 1 ] [ j ] [ 1 ] )\n            dp [ i ] [ j ] [ 1 ] = dp [ i - 1 ] [ j ] [ 0 ]\n            if j >= 1 :\n                dp [ i ] [ j ] [ 1 ] += dp [ i - 1 ] [ j - 1 ] [ 1 ]\n    return dp [ n ] [ k ] [ 0 ] + dp [ n ] [ k ] [ 1 ]\n", "FINDING_K_MODULUS_ARRAY_ELEMENT": "def printEqualModNumbers ( arr , n ) :\n    arr.sort ( ) ;\n    d = arr [ n - 1 ] - arr [ 0 ] ;\n    v = [ ] ;\n    i = 1 ;\n    while ( i * i <= d ) :\n        if ( d % i == 0 ) :\n            v.append ( i ) ;\n            if ( i != d / i ) :\n                v.append ( d / i ) ;\n        i += 1 ;\n    for i in range ( len ( v ) ) :\n        temp = arr [ 0 ] % v [ i ] ;\n        j = 1 ;\n        while ( j < n ) :\n            if ( arr [ j ] % v [ i ] != temp ) :\n                break ;\n            j += 1 ;\n        if ( j == n ) :\n            print ( v [ i ] , end = \" \" ) ;\n", "CIRCULAR_MATRIX_CONSTRUCT_A_MATRIX_WITH_NUMBERS_1_TO_MN_IN_SPIRAL_WAY": "def spiralFill ( m , n , a ) :\n    val = 1\n    k , l = 0 , 0\n    while ( k < m and l < n ) :\n        for i in range ( l , n ) :\n            a [ k ] [ i ] = val\n            val += 1\n        k += 1\n        for i in range ( k , m ) :\n            a [ i ] [ n - 1 ] = val\n            val += 1\n        n -= 1\n        if ( k < m ) :\n            for i in range ( n - 1 , l - 1 , - 1 ) :\n                a [ m - 1 ] [ i ] = val\n                val += 1\n            m -= 1\n        if ( l < n ) :\n            for i in range ( m - 1 , k - 1 , - 1 ) :\n                a [ i ] [ l ] = val\n                val += 1\n            l += 1\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_2": "def printRepeating ( arr , size ) :\n    xor = arr [ 0 ]\n    n = size - 2\n    x = 0\n    y = 0\n    for i in range ( 1 , size ) :\n        xor ^= arr [ i ]\n    for i in range ( 1 , n + 1 ) :\n        xor ^= i\n    set_bit_no = xor & ~ ( xor - 1 )\n    for i in range ( 0 , size ) :\n        if ( arr [ i ] & set_bit_no ) :\n            x = x ^ arr [ i ]\n        else :\n            y = y ^ arr [ i ]\n    for i in range ( 1 , n + 1 ) :\n        if ( i & set_bit_no ) :\n            x = x ^ i\n        else :\n            y = y ^ i\n    print ( \"The two repeating\" , \"elements are\" , y , x )\n", "COUNT_POSSIBLE_WAYS_TO_CONSTRUCT_BUILDINGS": "def countWays ( N ) :\n    if ( N == 1 ) :\n        return 4\n    countB = 1\n    countS = 1\n    for i in range ( 2 , N + 1 ) :\n        prev_countB = countB\n        prev_countS = countS\n        countS = prev_countB + prev_countS\n        countB = prev_countS\n    result = countS + countB\n    return ( result * result )\n", "ONE_LINE_FUNCTION_FOR_FACTORIAL_OF_A_NUMBER": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 ) ;\n", "CHECK_GIVEN_MATRIX_SPARSE_NOT": "def isSparse ( array , m , n ) :\n    counter = 0\n    for i in range ( 0 , m ) :\n        for j in range ( 0 , n ) :\n            if ( array [ i ] [ j ] == 0 ) :\n                counter = counter + 1\n    return ( counter > ( ( m * n ) // 2 ) )\n", "DYNAMIC_PROGRAMMING_SET_10_0_1_KNAPSACK_PROBLEM": "def knapSack ( W , wt , val , n ) :\n    if n == 0 or W == 0 :\n        return 0\n    if ( wt [ n - 1 ] > W ) :\n        return knapSack ( W , wt , val , n - 1 )\n    else :\n        return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ] , wt , val , n - 1 ) , knapSack ( W , wt , val , n - 1 ) )\n", "FIND_SUBARRAY_LEAST_AVERAGE": "def findMinAvgSubarray ( arr , n , k ) :\n    if ( n < k ) : return 0\n    res_index = 0\n    curr_sum = 0\n    for i in range ( k ) :\n        curr_sum += arr [ i ]\n    min_sum = curr_sum\n    for i in range ( k , n ) :\n        curr_sum += arr [ i ] - arr [ i - k ]\n        if ( curr_sum < min_sum ) :\n            min_sum = curr_sum\n            res_index = ( i - k + 1 )\n    print ( \"Subarray between [\" , res_index , \", \" , ( res_index + k - 1 ) , \"] has minimum average\" )\n", "QUERIES_FOR_CHARACTERS_IN_A_REPEATED_STRING": "def query ( s , i , j ) :\n    n = len ( s )\n    i %= n\n    j %= n\n    print ( \"Yes\" ) if s [ i ] == s [ j ] else print ( \"No\" )\n", "A_PRODUCT_ARRAY_PUZZLE_1": "def productArray ( arr , n ) :\n    if n == 1 :\n        print ( 0 )\n        return\n    i , temp = 1 , 1\n    prod = [ 1 for i in range ( n ) ]\n    for i in range ( n ) :\n        prod [ i ] = temp\n        temp *= arr [ i ]\n    temp = 1\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        prod [ i ] *= temp\n        temp *= arr [ i ]\n    for i in range ( n ) :\n        print ( prod [ i ] , end = \" \" )\n    return\n", "FIND_PAIRS_GIVEN_SUM_ELEMENTS_PAIR_DIFFERENT_ROWS": "def pairSum ( mat , n , sum ) :\n    for i in range ( n ) :\n        mat [ i ].sort ( )\n    for i in range ( n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            left = 0\n            right = n - 1\n            while ( left < n and right >= 0 ) :\n                if ( ( mat [ i ] [ left ] + mat [ j ] [ right ] ) == sum ) :\n                    print ( \"(\" , mat [ i ] [ left ] , \", \" , mat [ j ] [ right ] , \"), \" , end = \" \" )\n                    left += 1\n                    right -= 1\n                else :\n                    if ( ( mat [ i ] [ left ] + mat [ j ] [ right ] ) < sum ) :\n                        left += 1\n                    else :\n                        right -= 1\n", "CHECK_STRING_CAN_OBTAINED_ROTATING_ANOTHER_STRING_2_PLACES": "def isRotated ( str1 , str2 ) :\n    if ( len ( str1 ) != len ( str2 ) ) :\n        return False\n    clock_rot = \"\"\n    anticlock_rot = \"\"\n    l = len ( str2 )\n    anticlock_rot = ( anticlock_rot + str2 [ l - 2 : ] + str2 [ 0 : l - 2 ] )\n    clock_rot = clock_rot + str2 [ 2 : ] + str2 [ 0 : 2 ]\n    return ( str1 == clock_rot or str1 == anticlock_rot )\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN": "def findNth ( n ) :\n    count = 0\n    for curr in itertools.count ( ) :\n        sum = 0\n        x = curr\n        while ( x ) :\n            sum = sum + x % 10\n            x = x // 10\n        if ( sum == 10 ) :\n            count = count + 1\n        if ( count == n ) :\n            return curr\n    return - 1\n", "PROGRAM_FIND_SLOPE_LINE": "def slope ( x1 , y1 , x2 , y2 ) :\n    return ( float ) ( y2 - y1 ) / ( x2 - x1 )\n", "GCD_ELEMENTS_GIVEN_RANGE": "def rangeGCD ( n , m ) :\n    return n if ( n == m ) else 1\n", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY_1": "def alternateSubarray ( arr , n ) :\n    count = 1\n    prev = arr [ 0 ]\n    for i in range ( 1 , n ) :\n        if ( ( arr [ i ] ^ prev ) == 0 ) :\n            while ( count ) :\n                print ( count , end = \" \" )\n                count -= 1\n        count += 1\n        prev = arr [ i ]\n    while ( count ) :\n        print ( count , end = \" \" )\n        count -= 1\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y": "def unitDigitXRaisedY ( x , y ) :\n    res = 1\n    for i in range ( y ) :\n        res = ( res * x ) % 10\n    return res\n", "MULTIPLY_LARGE_INTEGERS_UNDER_LARGE_MODULO": "def moduloMultiplication ( a , b , mod ) :\n    res = 0 ;\n    a = a % mod ;\n    while ( b ) :\n        if ( b & 1 ) :\n            res = ( res + a ) % mod ;\n        a = ( 2 * a ) % mod ;\n        b >>= 1 ;\n    return res ;\n", "FIND_SMALLEST_NUMBER_WITH_GIVEN_NUMBER_OF_DIGITS_AND_DIGIT_SUM": "def findSmallest ( m , s ) :\n    if ( s == 0 ) :\n        if ( m == 1 ) :\n            print ( \"Smallest number is 0\" )\n        else :\n            print ( \"Not possible\" )\n        return\n    if ( s > 9 * m ) :\n        print ( \"Not possible\" )\n        return\n    res = [ 0 for i in range ( m + 1 ) ]\n    s -= 1\n    for i in range ( m - 1 , 0 , - 1 ) :\n        if ( s > 9 ) :\n            res [ i ] = 9\n            s -= 9\n        else :\n            res [ i ] = s\n            s = 0\n    res [ 0 ] = s + 1\n    print ( \"Smallest number is \" , end = \"\" )\n    for i in range ( m ) :\n        print ( res [ i ] , end = \"\" )\n", "C_PROGRAM_FIND_LARGEST_ELEMENT_ARRAY": "def largest ( arr , n ) :\n    max = arr [ 0 ]\n    for i in range ( 1 , n ) :\n        if arr [ i ] > max :\n            max = arr [ i ]\n    return max\n", "COUNT_NUMBERS_CAN_CONSTRUCTED_USING_TWO_NUMBERS": "def countNums ( n , x , y ) :\n    arr = [ False for i in range ( n + 2 ) ]\n    if ( x <= n ) :\n        arr [ x ] = True\n    if ( y <= n ) :\n        arr [ y ] = True\n    result = 0\n    for i in range ( min ( x , y ) , n + 1 ) :\n        if ( arr [ i ] ) :\n            if ( i + x <= n ) :\n                arr [ i + x ] = True\n            if ( i + y <= n ) :\n                arr [ i + y ] = True\n            result = result + 1\n    return result\n", "BUBBLE_SORT_1": "def bubbleSort ( arr ) :\n    n = len ( arr )\n    for i in range ( n ) :\n        swapped = False\n        for j in range ( 0 , n - i - 1 ) :\n            if arr [ j ] > arr [ j + 1 ] :\n                arr [ j ] , arr [ j + 1 ] = arr [ j + 1 ] , arr [ j ]\n                swapped = True\n        if swapped == False :\n            break\n", "MAXIMUM_SUM_2_X_N_GRID_NO_TWO_ELEMENTS_ADJACENT": "def maxSum ( grid , n ) :\n    incl = max ( grid [ 0 ] [ 0 ] , grid [ 1 ] [ 0 ] )\n    excl = 0\n    for i in range ( 1 , n ) :\n        excl_new = max ( excl , incl )\n        incl = excl + max ( grid [ 0 ] [ i ] , grid [ 1 ] [ i ] )\n        excl = excl_new\n    return max ( excl , incl )\n", "GCD_FACTORIALS_TWO_NUMBERS": "def gcdOfFactorial ( m , n ) :\n    return math.factorial ( min ( m , n ) )\n", "AREA_OF_A_SECTOR": "def SectorArea ( radius , angle ) :\n    pi = 22 / 7\n    if angle >= 360 :\n        print ( \"Angle not possible\" )\n        return\n    else :\n        sector = ( pi * radius ** 2 ) * ( angle / 360 )\n        print ( sector )\n        return\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS_1": "def countSeq ( n ) :\n    nCr = 1\n    res = 1\n    for r in range ( 1 , n + 1 ) :\n        nCr = ( nCr * ( n + 1 - r ) ) / r ;\n        res += nCr * nCr ;\n    return res ;\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_1": "def findLength ( string ) :\n    n = len ( string )\n    maxlen = 0\n    Sum = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    for i in range ( 0 , n ) :\n        Sum [ i ] [ i ] = int ( string [ i ] )\n    for length in range ( 2 , n + 1 ) :\n        for i in range ( 0 , n - length + 1 ) :\n            j = i + length - 1\n            k = length // 2\n            Sum [ i ] [ j ] = ( Sum [ i ] [ j - k ] + Sum [ j - k + 1 ] [ j ] )\n            if ( length % 2 == 0 and Sum [ i ] [ j - k ] == Sum [ ( j - k + 1 ) ] [ j ] and length > maxlen ) :\n                maxlen = length\n    return maxlen\n", "SWAP_ALL_ODD_AND_EVEN_BITS": "def swapBits ( x ) :\n    even_bits = x & 0xAAAAAAAA\n    odd_bits = x & 0x55555555\n    even_bits >>= 1\n    odd_bits <<= 1\n    return ( even_bits | odd_bits )\n", "SORT_ARRAY_WAVE_FORM_2": "def sortInWave ( arr , n ) :\n    arr.sort ( )\n    for i in range ( 0 , n - 1 , 2 ) :\n        arr [ i ] , arr [ i + 1 ] = arr [ i + 1 ] , arr [ i ]\n", "FIND_HARMONIC_MEAN_USING_ARITHMETIC_MEAN_GEOMETRIC_MEAN": "def compute ( a , b ) :\n    AM = ( a + b ) / 2\n    GM = math.sqrt ( a * b )\n    HM = ( GM * GM ) / AM\n    return HM\n", "COUNT_BALANCED_BINARY_TREES_HEIGHT_H": "def countBT ( h ) :\n    MOD = 1000000007\n    dp = [ 0 for i in range ( h + 1 ) ]\n    dp [ 0 ] = 1\n    dp [ 1 ] = 1\n    for i in range ( 2 , h + 1 ) :\n        dp [ i ] = ( dp [ i - 1 ] * ( ( 2 * dp [ i - 2 ] ) % MOD + dp [ i - 1 ] ) % MOD ) % MOD\n    return dp [ h ]\n", "MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME_WITH_PERMUTATIONS_ALLOWED": "def minInsertion ( tr1 ) :\n    n = len ( str1 )\n    res = 0\n    count = [ 0 for i in range ( 26 ) ]\n    for i in range ( n ) :\n        count [ ord ( str1 [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( 26 ) :\n        if ( count [ i ] % 2 == 1 ) :\n            res += 1\n    if ( res == 0 ) :\n        return 0\n    else :\n        return res - 1\n", "SHUFFLE_A_GIVEN_ARRAY": "def randomize ( arr , n ) :\n    for i in range ( n - 1 , 0 , - 1 ) :\n        j = random.randint ( 0 , i + 1 )\n        arr [ i ] , arr [ j ] = arr [ j ] , arr [ i ]\n    return arr\n", "UGLY_NUMBERS": "def getNthUglyNo ( n ) :\n    ugly = [ 0 ] * n\n    ugly [ 0 ] = 1\n    i2 = i3 = i5 = 0\n    next_multiple_of_2 = 2\n    next_multiple_of_3 = 3\n    next_multiple_of_5 = 5\n    for l in range ( 1 , n ) :\n        ugly [ l ] = min ( next_multiple_of_2 , next_multiple_of_3 , next_multiple_of_5 )\n        if ugly [ l ] == next_multiple_of_2 :\n            i2 += 1\n            next_multiple_of_2 = ugly [ i2 ] * 2\n        if ugly [ l ] == next_multiple_of_3 :\n            i3 += 1\n            next_multiple_of_3 = ugly [ i3 ] * 3\n        if ugly [ l ] == next_multiple_of_5 :\n            i5 += 1\n            next_multiple_of_5 = ugly [ i5 ] * 5\n    return ugly [ - 1 ]\n", "MINIMUM_COST_CUT_BOARD_SQUARES": "def minimumCostOfBreaking ( X , Y , m , n ) :\n    res = 0\n    X.sort ( reverse = True )\n    Y.sort ( reverse = True )\n    hzntl = 1 ; vert = 1\n    i = 0 ; j = 0\n    while ( i < m and j < n ) :\n        if ( X [ i ] > Y [ j ] ) :\n            res += X [ i ] * vert\n            hzntl += 1\n            i += 1\n        else :\n            res += Y [ j ] * hzntl\n            vert += 1\n            j += 1\n    total = 0\n    while ( i < m ) :\n        total += X [ i ]\n        i += 1\n    res += total * vert\n    total = 0\n    while ( j < n ) :\n        total += Y [ j ]\n        j += 1\n    res += total * hzntl\n    return res\n", "DYNAMIC_PROGRAMMING_SET_10_0_1_KNAPSACK_PROBLEM_1": "def knapSack ( W , wt , val , n ) :\n    K = [ [ 0 for x in range ( W + 1 ) ] for x in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        for w in range ( W + 1 ) :\n            if i == 0 or w == 0 :\n                K [ i ] [ w ] = 0\n            elif wt [ i - 1 ] <= w :\n                K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ] , K [ i - 1 ] [ w ] )\n            else :\n                K [ i ] [ w ] = K [ i - 1 ] [ w ]\n    return K [ n ] [ W ]\n", "STACK_PERMUTATIONS_CHECK_IF_AN_ARRAY_IS_STACK_PERMUTATION_OF_OTHER": "def checkStackPermutation ( ip , op , n ) :\n    Input = Queue ( )\n    for i in range ( n ) :\n        Input.put ( ip [ i ] )\n    output = Queue ( )\n    for i in range ( n ) :\n        output.put ( op [ i ] )\n    tempStack = [ ]\n    while ( not Input.empty ( ) ) :\n        ele = Input.queue [ 0 ]\n        Input.get ( )\n        if ( ele == output.queue [ 0 ] ) :\n            output.get ( )\n            while ( len ( tempStack ) != 0 ) :\n                if ( tempStack [ - 1 ] == output.queue [ 0 ] ) :\n                    tempStack.pop ( )\n                    output.get ( )\n                else :\n                    break\n        else :\n            tempStack.append ( ele )\n    return ( Input.empty ( ) and len ( tempStack ) == 0 )\n", "PROBABILITY_THREE_RANDOMLY_CHOSEN_NUMBERS_AP": "def procal ( n ) :\n    return ( 3.0 * n ) / ( 4.0 * ( n * n ) - 1 )\n", "REMOVE_BRACKETS_ALGEBRAIC_STRING_CONTAINING_OPERATORS": "def simplify ( Str ) :\n    Len = len ( Str )\n    res = [ None ] * Len\n    index = 0\n    i = 0\n    s = [ ]\n    s.append ( 0 )\n    while ( i < Len ) :\n        if ( Str [ i ] == '+' ) :\n            if ( s [ - 1 ] == 1 ) :\n                res [ index ] = '-'\n                index += 1\n            if ( s [ - 1 ] == 0 ) :\n                res [ index ] = '+'\n                index += 1\n        elif ( Str [ i ] == '-' ) :\n            if ( s [ - 1 ] == 1 ) :\n                res [ index ] = '+'\n                index += 1\n            elif ( s [ - 1 ] == 0 ) :\n                res [ index ] = '-'\n                index += 1\n        elif ( Str [ i ] == '(' and i > 0 ) :\n            if ( Str [ i - 1 ] == '-' ) :\n                x = 0 if ( s [ - 1 ] == 1 ) else 1\n                s.append ( x )\n            elif ( Str [ i - 1 ] == '+' ) :\n                s.append ( s [ - 1 ] )\n        elif ( Str [ i ] == ')' ) :\n            s.pop ( )\n        else :\n            res [ index ] = Str [ i ]\n            index += 1\n        i += 1\n    return res\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS": "def CountSquares ( a , b ) :\n    cnt = 0\n    for i in range ( a , b + 1 ) :\n        j = 1 ;\n        while j * j <= i :\n            if j * j == i :\n                cnt = cnt + 1\n            j = j + 1\n        i = i + 1\n    return cnt\n", "K_NUMBERS_DIFFERENCE_MAXIMUM_MINIMUM_K_NUMBER_MINIMIZED": "def minDiff ( arr , n , k ) :\n    result = + 2147483647\n    arr.sort ( )\n    for i in range ( n - k + 1 ) :\n        result = int ( min ( result , arr [ i + k - 1 ] - arr [ i ] ) )\n    return result\n", "CHECK_LARGE_NUMBER_DIVISIBLE_13_NOT": "def checkDivisibility ( num ) :\n    length = len ( num )\n    if ( length == 1 and num [ 0 ] == '0' ) :\n        return True\n    if ( length % 3 == 1 ) :\n        num = str ( num ) + \"00\"\n        length += 2\n    elif ( length % 3 == 2 ) :\n        num = str ( num ) + \"0\"\n        length += 1\n    sum = 0\n    p = 1\n    for i in range ( length - 1 , - 1 , - 1 ) :\n        group = 0\n        group += ord ( num [ i ] ) - ord ( '0' )\n        i -= 1\n        group += ( ord ( num [ i ] ) - ord ( '0' ) ) * 10\n        i -= 1\n        group += ( ord ( num [ i ] ) - ord ( '0' ) ) * 100\n        sum = sum + group * p\n        p *= ( - 1 )\n    sum = abs ( sum )\n    return ( sum % 13 == 0 )\n", "GIVEN_N_X_N_SQUARE_MATRIX_FIND_SUM_SUB_SQUARES_SIZE_K_X_K": "def printSumSimple ( mat , k ) :\n    if ( k > n ) :\n        return\n    for i in range ( n - k + 1 ) :\n        for j in range ( n - k + 1 ) :\n            sum = 0\n            for p in range ( i , k + i ) :\n                for q in range ( j , k + j ) :\n                    sum += mat [ p ] [ q ]\n            print ( sum , end = \" \" )\n        print ( )\n", "FIND_THE_POINT_WHERE_MAXIMUM_INTERVALS_OVERLAP_1": "def maxOverlap ( start , end ) :\n    n = len ( start )\n    maxa = max ( start )\n    maxb = max ( end )\n    maxc = max ( maxa , maxb )\n    x = ( maxc + 2 ) * [ 0 ]\n    cur = 0 ; idx = 0\n    for i in range ( 0 , n ) :\n        x [ start [ i ] ] += 1\n        x [ end [ i ] + 1 ] -= 1\n    maxy = - 1\n    for i in range ( 0 , maxc + 1 ) :\n        cur += x [ i ]\n        if maxy < cur :\n            maxy = cur\n            idx = i\n    print ( \"Maximum value is: {0:d}\".format ( maxy ) , \" at position: {0:d}\".format ( idx ) )\n", "MAXIMUM_SUBSEQUENCE_SUM_SUCH_THAT_NO_THREE_ARE_CONSECUTIVE_1": "def maxSumWO3Consec ( n ) :\n    if ( sum [ n ] != - 1 ) :\n        return sum [ n ]\n    if ( n == 0 ) :\n        sum [ n ] = 0\n        return sum [ n ]\n    if ( n == 1 ) :\n        sum [ n ] = arr [ 0 ]\n        return sum [ n ]\n    if ( n == 2 ) :\n        sum [ n ] = arr [ 1 ] + arr [ 0 ]\n        return sum [ n ]\n    sum [ n ] = max ( max ( maxSumWO3Consec ( n - 1 ) , maxSumWO3Consec ( n - 2 ) + arr [ n - 1 ] ) , arr [ n - 2 ] + arr [ n - 1 ] + maxSumWO3Consec ( n - 3 ) )\n    return sum [ n ]\n", "C_PROGRAM_ADDITION_TWO_MATRICES": "def add ( A , B , C ) :\n    for i in range ( N ) :\n        for j in range ( N ) :\n            C [ i ] [ j ] = A [ i ] [ j ] + B [ i ] [ j ]\n", "FIND_MAXIMUM_AVERAGE_SUBARRAY_OF_K_LENGTH_1": "def findMaxAverage ( arr , n , k ) :\n    if ( k > n ) :\n        return - 1\n    sum = arr [ 0 ]\n    for i in range ( 1 , k ) :\n        sum += arr [ i ]\n    max_sum = sum\n    max_end = k - 1\n    for i in range ( k , n ) :\n        sum = sum + arr [ i ] - arr [ i - k ]\n        if ( sum > max_sum ) :\n            max_sum = sum\n            max_end = i\n    return max_end - k + 1\n", "FIND_CENTER_CIRCLE_USING_ENDPOINTS_DIAMETER": "def center ( x1 , x2 , y1 , y2 ) :\n    print ( int ( ( x1 + x2 ) / 2 ) , end = \"\" )\n    print ( \",\" , int ( ( y1 + y2 ) / 2 ) )\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS": "def countNonDecreasing ( n ) :\n    dp = [ [ 0 for i in range ( n + 1 ) ] for i in range ( 10 ) ]\n    for i in range ( 10 ) :\n        dp [ i ] [ 1 ] = 1\n    for digit in range ( 10 ) :\n        for len in range ( 2 , n + 1 ) :\n            for x in range ( digit + 1 ) :\n                dp [ digit ] [ len ] += dp [ x ] [ len - 1 ]\n    count = 0\n    for i in range ( 10 ) :\n        count += dp [ i ] [ n ]\n    return count\n", "PRINT_REVERSE_STRING_REMOVING_VOWELS": "def replaceOriginal ( s , n ) :\n    r = [ ' ' ] * n\n    for i in range ( n ) :\n        r [ i ] = s [ n - 1 - i ]\n        if ( s [ i ] != 'a' and s [ i ] != 'e' and s [ i ] != 'i' and s [ i ] != 'o' and s [ i ] != 'u' ) :\n            print ( r [ i ] , end = \"\" )\n    print ( )\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND_1": "def findMissing ( a , b , n , m ) :\n    s = dict ( )\n    for i in range ( m ) :\n        s [ b [ i ] ] = 1\n    for i in range ( n ) :\n        if a [ i ] not in s.keys ( ) :\n            print ( a [ i ] , end = \" \" )\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS": "def countStr ( n , bCount , cCount ) :\n    if ( bCount < 0 or cCount < 0 ) :\n        return 0\n    if ( n == 0 ) :\n        return 1\n    if ( bCount == 0 and cCount == 0 ) :\n        return 1\n    res = countStr ( n - 1 , bCount , cCount )\n    res += countStr ( n - 1 , bCount - 1 , cCount )\n    res += countStr ( n - 1 , bCount , cCount - 1 )\n    return res\n", "GOLD_MINE_PROBLEM": "def getMaxGold ( gold , m , n ) :\n    goldTable = [ [ 0 for i in range ( n ) ] for j in range ( m ) ]\n    for col in range ( n - 1 , - 1 , - 1 ) :\n        for row in range ( m ) :\n            if ( col == n - 1 ) :\n                right = 0\n            else :\n                right = goldTable [ row ] [ col + 1 ]\n            if ( row == 0 or col == n - 1 ) :\n                right_up = 0\n            else :\n                right_up = goldTable [ row - 1 ] [ col + 1 ]\n            if ( row == m - 1 or col == n - 1 ) :\n                right_down = 0\n            else :\n                right_down = goldTable [ row + 1 ] [ col + 1 ]\n            goldTable [ row ] [ col ] = gold [ row ] [ col ] + max ( right , right_up , right_down )\n    res = goldTable [ 0 ] [ 0 ]\n    for i in range ( 1 , m ) :\n        res = max ( res , goldTable [ i ] [ 0 ] )\n    return res\n", "COUNT_WAYS_BUILD_STREET_GIVEN_CONSTRAINTS": "def countWays ( n ) :\n    dp = [ [ 0 ] * ( n + 1 ) for i in range ( 2 ) ]\n    dp [ 0 ] [ 1 ] = 1\n    dp [ 1 ] [ 1 ] = 2\n    for i in range ( 2 , n + 1 ) :\n        dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ] + dp [ 1 ] [ i - 1 ]\n        dp [ 1 ] [ i ] = ( dp [ 0 ] [ i - 1 ] * 2 + dp [ 1 ] [ i - 1 ] )\n    return dp [ 0 ] [ n ] + dp [ 1 ] [ n ]\n", "RETURN_A_PAIR_WITH_MAXIMUM_PRODUCT_IN_ARRAY_OF_INTEGERS_1": "def maxProduct ( arr , n ) :\n    if ( n < 2 ) :\n        print ( \"No pairs exists\" )\n        return\n    if ( n == 2 ) :\n        print ( arr [ 0 ] , \" \" , arr [ 1 ] )\n        return\n    posa = 0\n    posb = 0\n    nega = 0\n    negb = 0\n    for i in range ( n ) :\n        if ( arr [ i ] > posa ) :\n            posb = posa\n            posa = arr [ i ]\n        elif ( arr [ i ] > posb ) :\n            posb = arr [ i ]\n        if ( arr [ i ] < 0 and abs ( arr [ i ] ) > abs ( nega ) ) :\n            negb = nega\n            nega = arr [ i ]\n        elif ( arr [ i ] < 0 and abs ( arr [ i ] ) > abs ( negb ) ) :\n            negb = arr [ i ]\n    if ( nega * negb > posa * posb ) :\n        print ( \"Max product pair is {\" , nega , \", \" , negb , \"}\" )\n    else :\n        print ( \"Max product pair is {\" , posa , \", \" , posb , \"}\" )\n", "POSITION_OF_RIGHTMOST_SET_BIT": "def getFirstSetBitPos ( n ) :\n    return math.log2 ( n & - n ) + 1\n", "LONGEST_SUBSEQUENCE_WHERE_EVERY_CHARACTER_APPEARS_AT_LEAST_K_TIMES": "def longestSubseqWithK ( str , k ) :\n    n = len ( str )\n    freq = [ 0 ] * MAX_CHARS\n    for i in range ( n ) :\n        freq [ ord ( str [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( n ) :\n        if ( freq [ ord ( str [ i ] ) - ord ( 'a' ) ] >= k ) :\n            print ( str [ i ] , end = \"\" )\n", "POSSIBLE_TO_MAKE_A_DIVISIBLE_BY_3_NUMBER_USING_ALL_DIGITS_IN_AN_ARRAY": "def isPossibleToMakeDivisible ( arr , n ) :\n    remainder = 0\n    for i in range ( 0 , n ) :\n        remainder = ( remainder + arr [ i ] ) % 3\n    return ( remainder == 0 )\n", "AREA_SQUARE_CIRCUMSCRIBED_CIRCLE": "def find_Area ( r ) :\n    return ( 2 * r * r )\n", "FIND_MAXIMUM_DOT_PRODUCT_TWO_ARRAYS_INSERTION_0S": "def MaxDotProduct ( A , B , m , n ) :\n    dp = [ [ 0 for i in range ( m + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 , 1 ) :\n        for j in range ( i , m + 1 , 1 ) :\n            dp [ i ] [ j ] = max ( ( dp [ i - 1 ] [ j - 1 ] + ( A [ j - 1 ] * B [ i - 1 ] ) ) , dp [ i ] [ j - 1 ] )\n    return dp [ n ] [ m ]\n", "FIND_DISTINCT_SUBSET_SUBSEQUENCE_SUMS_ARRAY": "def printDistSum ( arr , n ) :\n    Sum = sum ( arr )\n    dp = [ [ False for i in range ( Sum + 1 ) ] for i in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        dp [ i ] [ 0 ] = True\n    for i in range ( 1 , n + 1 ) :\n        dp [ i ] [ arr [ i - 1 ] ] = True\n        for j in range ( 1 , Sum + 1 ) :\n            if ( dp [ i - 1 ] [ j ] == True ) :\n                dp [ i ] [ j ] = True\n                dp [ i ] [ j + arr [ i - 1 ] ] = True\n    for j in range ( Sum + 1 ) :\n        if ( dp [ n ] [ j ] == True ) :\n            print ( j , end = \" \" )\n", "SPLIT_NUMERIC_ALPHABETIC_AND_SPECIAL_SYMBOLS_FROM_A_STRING": "def splitString ( str ) :\n    alpha = \"\"\n    num = \"\"\n    special = \"\"\n    for i in range ( len ( str ) ) :\n        if ( str [ i ].isdigit ( ) ) :\n            num = num + str [ i ]\n        elif ( ( str [ i ] >= 'A' and str [ i ] <= 'Z' ) or ( str [ i ] >= 'a' and str [ i ] <= 'z' ) ) :\n            alpha += str [ i ]\n        else :\n            special += str [ i ]\n    print ( alpha )\n    print ( num )\n    print ( special )\n", "MAXIMUM_SUM_ALTERNATING_SUBSEQUENCE_SUM": "def maxAlternateSum ( arr , n ) :\n    if ( n == 1 ) :\n        return arr [ 0 ]\n    dec = [ 0 for i in range ( n + 1 ) ]\n    inc = [ 0 for i in range ( n + 1 ) ]\n    dec [ 0 ] = inc [ 0 ] = arr [ 0 ]\n    flag = 0\n    for i in range ( 1 , n ) :\n        for j in range ( i ) :\n            if ( arr [ j ] > arr [ i ] ) :\n                dec [ i ] = max ( dec [ i ] , inc [ j ] + arr [ i ] )\n                flag = 1\n            elif ( arr [ j ] < arr [ i ] and flag == 1 ) :\n                inc [ i ] = max ( inc [ i ] , dec [ j ] + arr [ i ] )\n    result = - 2147483648\n    for i in range ( n ) :\n        if ( result < inc [ i ] ) :\n            result = inc [ i ]\n        if ( result < dec [ i ] ) :\n            result = dec [ i ]\n    return result\n", "FIND_PAIR_MAXIMUM_GCD_ARRAY": "def findMaxGCD ( arr , n ) :\n    high = 0\n    i = 0\n    while i < n :\n        high = max ( high , arr [ i ] )\n        i = i + 1\n    divisors = [ 0 ] * ( high + 1 )\n    i = 0\n    while i < n :\n        j = 1\n        while j <= math.sqrt ( arr [ i ] ) :\n            if ( arr [ i ] % j == 0 ) :\n                divisors [ j ] = divisors [ j ] + 1\n                if ( j != arr [ i ] / j ) :\n                    divisors [ arr [ i ] / j ] = divisors [ arr [ i ] / j ]\n                        + 1\n            j = j + 1\n        i = i + 1\n    i = high\n    while i >= 1 :\n        if ( divisors [ i ] > 1 ) :\n            return i\n        i = i - 1\n    return 1\n", "FIND_MINIMUM_NUMBER_OF_COINS_THAT_MAKE_A_CHANGE_1": "def minCoins ( coins , m , V ) :\n    table = [ 0 for i in range ( V + 1 ) ]\n    table [ 0 ] = 0\n    for i in range ( 1 , V + 1 ) :\n        table [ i ] = sys.maxsize\n    for i in range ( 1 , V + 1 ) :\n        for j in range ( m ) :\n            if ( coins [ j ] <= i ) :\n                sub_res = table [ i - coins [ j ] ]\n                if ( sub_res != sys.maxsize and sub_res + 1 < table [ i ] ) :\n                    table [ i ] = sub_res + 1\n    return table [ V ]\n", "SUM_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING": "def sumAtKthLevel ( tree , k ) :\n    level = - 1\n    sum = 0\n    n = len ( tree )\n    for i in range ( n ) :\n        if ( tree [ i ] == '(' ) :\n            level += 1\n        elif ( tree [ i ] == ')' ) :\n            level -= 1\n        else :\n            if ( level == k ) :\n                sum += ( ord ( tree [ i ] ) - ord ( '0' ) )\n    return sum\n", "DYNAMIC_PROGRAMMING_SET_4_LONGEST_COMMON_SUBSEQUENCE": "def lcs ( X , Y , m , n ) :\n    if m == 0 or n == 0 :\n        return 0 ;\n    elif X [ m - 1 ] == Y [ n - 1 ] :\n        return 1 + lcs ( X , Y , m - 1 , n - 1 ) ;\n    else :\n        return max ( lcs ( X , Y , m , n - 1 ) , lcs ( X , Y , m - 1 , n ) ) ;\n", "CHECK_GIVEN_SENTENCE_GIVEN_SET_SIMPLE_GRAMMER_RULES": "def checkSentence ( string ) :\n    length = len ( string )\n    if string [ 0 ] < 'A' or string [ 0 ] > 'Z' :\n        return False\n    if string [ length - 1 ] != '.' :\n        return False\n    prev_state = 0\n    curr_state = 0\n    index = 1\n    while ( string [ index ] ) :\n        if string [ index ] >= 'A' and string [ index ] <= 'Z' :\n            curr_state = 0\n        elif string [ index ] == ' ' :\n            curr_state = 1\n        elif string [ index ] >= 'a' and string [ index ] <= 'z' :\n            curr_state = 2\n        elif string [ index ] == '.' :\n            curr_state = 3\n        if prev_state == curr_state and curr_state != 2 :\n            return False\n        if prev_state == 2 and curr_state == 0 :\n            return False\n        if curr_state == 3 and prev_state != 1 :\n            return True\n        index += 1\n        prev_state = curr_state\n    return False\n", "CHECK_DIVISIBILITY_LARGE_NUMBER_999": "def isDivisible999 ( num ) :\n    n = len ( num ) ;\n    if ( n == 0 or num [ 0 ] == '0' ) :\n        return true\n    if ( ( n % 3 ) == 1 ) :\n        num = \"00\" + num\n    if ( ( n % 3 ) == 2 ) :\n        num = \"0\" + num\n    gSum = 0\n    for i in range ( 0 , n , 3 ) :\n        group = 0\n        group += ( ord ( num [ i ] ) - 48 ) * 100\n        group += ( ord ( num [ i + 1 ] ) - 48 ) * 10\n        group += ( ord ( num [ i + 2 ] ) - 48 )\n        gSum += group\n    if ( gSum > 1000 ) :\n        num = str ( gSum )\n        n = len ( num )\n        gSum = isDivisible999 ( num )\n    return ( gSum == 999 )\n", "CHECK_LARGE_NUMBER_DIVISIBLE_9_NOT": "def check ( st ) :\n    n = len ( st )\n    digitSum = 0\n    for i in range ( 0 , n ) :\n        digitSum = digitSum + ( int ) ( st [ i ] )\n    return ( digitSum % 9 == 0 )\n", "NUMBER_OF_BINARY_TREES_FOR_GIVEN_PREORDER_SEQUENCE_LENGTH": "def countTrees ( n ) :\n    BT = [ 0 ] * ( n + 1 )\n    BT [ 0 ] = BT [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( i ) :\n            BT [ i ] += BT [ j ] * BT [ i - j - 1 ]\n    return BT [ n ]\n", "PROGRAM_SWAP_UPPER_DIAGONAL_ELEMENTS_LOWER_DIAGONAL_ELEMENTS_MATRIX": "def swapUpperToLower ( arr ) :\n    n = 4 ;\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            temp = arr [ i ] [ j ] ;\n            arr [ i ] [ j ] = arr [ j ] [ i ] ;\n            arr [ j ] [ i ] = temp ;\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            print ( arr [ i ] [ j ] , end = \" \" ) ;\n        print ( \" \" ) ;\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER_1": "def findSum ( N , K ) :\n    ans = 0 ;\n    y = N / K ;\n    x = N % K ;\n    ans = ( ( K * ( K - 1 ) / 2 ) * y + ( x * ( x + 1 ) ) / 2 ) ;\n    return int ( ans ) ;\n", "WAYS_REMOVE_ONE_ELEMENT_BINARY_STRING_XOR_BECOMES_ZERO": "def xorZero ( str ) :\n    one_count = 0\n    zero_count = 0\n    n = len ( str )\n    for i in range ( 0 , n , 1 ) :\n        if ( str [ i ] == '1' ) :\n            one_count += 1\n        else :\n            zero_count += 1\n    if ( one_count % 2 == 0 ) :\n        return zero_count\n    return one_count\n", "DYNAMIC_PROGRAMMING_SET_7_COIN_CHANGE": "def count ( S , m , n ) :\n    if ( n == 0 ) :\n        return 1\n    if ( n < 0 ) :\n        return 0 ;\n    if ( m <= 0 and n >= 1 ) :\n        return 0\n    return count ( S , m - 1 , n ) + count ( S , m , n - S [ m - 1 ] ) ;\n", "MINIMUM_SUM_SUBSEQUENCE_LEAST_ONE_EVERY_FOUR_CONSECUTIVE_ELEMENTS_PICKED": "def minSum ( arr , n ) :\n    dp = [ 0 ] * n\n    if ( n == 1 ) :\n        return arr [ 0 ]\n    if ( n == 2 ) :\n        return min ( arr [ 0 ] , arr [ 1 ] )\n    if ( n == 3 ) :\n        return min ( arr [ 0 ] , min ( arr [ 1 ] , arr [ 2 ] ) )\n    if ( n == 4 ) :\n        return min ( min ( arr [ 0 ] , arr [ 1 ] ) , min ( arr [ 2 ] , arr [ 3 ] ) )\n    dp [ 0 ] = arr [ 0 ]\n    dp [ 1 ] = arr [ 1 ]\n    dp [ 2 ] = arr [ 2 ]\n    dp [ 3 ] = arr [ 3 ]\n    for i in range ( 4 , n ) :\n        dp [ i ] = arr [ i ] + min ( min ( dp [ i - 1 ] , dp [ i - 2 ] ) , min ( dp [ i - 3 ] , dp [ i - 4 ] ) )\n    return min ( min ( dp [ n - 1 ] , dp [ n - 2 ] ) , min ( dp [ n - 4 ] , dp [ n - 3 ] ) )\n", "MAXIMUM_PATH_SUM_TRIANGLE": "def maxPathSum ( tri , m , n ) :\n    for i in range ( m - 1 , - 1 , - 1 ) :\n        for j in range ( i + 1 ) :\n            if ( tri [ i + 1 ] [ j ] > tri [ i + 1 ] [ j + 1 ] ) :\n                tri [ i ] [ j ] += tri [ i + 1 ] [ j ]\n            else :\n                tri [ i ] [ j ] += tri [ i + 1 ] [ j + 1 ]\n    return tri [ 0 ] [ 0 ]\n", "FIND_THREE_ELEMENT_FROM_DIFFERENT_THREE_ARRAYS_SUCH_THAT_THAT_A_B_C_K": "def findTriplet ( a1 , a2 , a3 , n1 , n2 , n3 , sum ) :\n    for i in range ( 0 , n1 ) :\n        for j in range ( 0 , n2 ) :\n            for k in range ( 0 , n3 ) :\n                if ( a1 [ i ] + a2 [ j ] + a3 [ k ] == sum ) :\n                    return True\n    return False\n", "TAIL_RECURSION_FIBONACCI": "def fib ( n , a = 0 , b = 1 ) :\n    if n == 0 :\n        return a\n    if n == 1 :\n        return b\n    return fib ( n - 1 , b , a + b ) ;\n", "PROGRAM_TO_CHECK_IF_A_GIVEN_NUMBER_IS_LUCKY_ALL_DIGITS_ARE_DIFFERENT": "def isLucky ( n ) :\n    ar = [ 0 ] * 10\n    while ( n > 0 ) :\n        digit = math.floor ( n % 10 )\n        if ( ar [ digit ] ) :\n            return 0\n        ar [ digit ] = 1\n        n = n / 10\n    return 1\n", "GIVEN_N_X_N_SQUARE_MATRIX_FIND_SUM_SUB_SQUARES_SIZE_K_X_K_1": "def printSumTricky ( mat , k ) :\n    global n\n    if k > n :\n        return\n    stripSum = [ [ None ] * n for i in range ( n ) ]\n    for j in range ( n ) :\n        Sum = 0\n        for i in range ( k ) :\n            Sum += mat [ i ] [ j ]\n        stripSum [ 0 ] [ j ] = Sum\n        for i in range ( 1 , n - k + 1 ) :\n            Sum += ( mat [ i + k - 1 ] [ j ] - mat [ i - 1 ] [ j ] )\n            stripSum [ i ] [ j ] = Sum\n    for i in range ( n - k + 1 ) :\n        Sum = 0\n        for j in range ( k ) :\n            Sum += stripSum [ i ] [ j ]\n        print ( Sum , end = \" \" )\n        for j in range ( 1 , n - k + 1 ) :\n            Sum += ( stripSum [ i ] [ j + k - 1 ] - stripSum [ i ] [ j - 1 ] )\n            print ( Sum , end = \" \" )\n        print ( )\n", "SCHEDULE_ELEVATOR_TO_REDUCE_THE_TOTAL_TIME_TAKEN": "def minTime ( n , k , a ) :\n    a.sort ( reverse = True ) ;\n    minTime = 0 ;\n    for i in range ( 0 , n , k ) :\n        minTime += ( 2 * a [ i ] ) ;\n    return minTime ;\n", "ODD_EVEN_SORT_BRICK_SORT": "def oddEvenSort ( arr , n ) :\n    isSorted = 0\n    while isSorted == 0 :\n        isSorted = 1\n        temp = 0\n        for i in range ( 1 , n - 1 , 2 ) :\n            if arr [ i ] > arr [ i + 1 ] :\n                arr [ i ] , arr [ i + 1 ] = arr [ i + 1 ] , arr [ i ]\n                isSorted = 0\n        for i in range ( 0 , n - 1 , 2 ) :\n            if arr [ i ] > arr [ i + 1 ] :\n                arr [ i ] , arr [ i + 1 ] = arr [ i + 1 ] , arr [ i ]\n                isSorted = 0\n    return\n", "RETURN_MAXIMUM_OCCURRING_CHARACTER_IN_THE_INPUT_STRING": "def getMaxOccuringChar ( str ) :\n    count = [ 0 ] * ASCII_SIZE\n    max = - 1\n    c = ''\n    for i in str :\n        count [ ord ( i ) ] += 1 ;\n    for i in str :\n        if max < count [ ord ( i ) ] :\n            max = count [ ord ( i ) ]\n            c = i\n    return c\n", "COUNT_NUMBER_PAIRS_N_B_N_GCD_B_B": "def CountPairs ( n ) :\n    k = n\n    imin = 1\n    ans = 0\n    while ( imin <= n ) :\n        imax = n / k\n        ans += k * ( imax - imin + 1 )\n        imin = imax + 1\n        k = n / imin\n    return ans\n", "K_TH_DISTINCT_OR_NON_REPEATING_ELEMENT_IN_AN_ARRAY_1": "def printKDistinct ( arr , size , KthIndex ) :\n    dict = { }\n    vect = [ ]\n    for i in range ( size ) :\n        if ( arr [ i ] in dict ) :\n            dict [ arr [ i ] ] = dict [ arr [ i ] ] + 1\n        else :\n            dict [ arr [ i ] ] = 1\n    for i in range ( size ) :\n        if ( dict [ arr [ i ] ] > 1 ) :\n            continue\n        else :\n            KthIndex = KthIndex - 1\n        if ( KthIndex == 0 ) :\n            return arr [ i ]\n    return - 1\n", "GENERATE_BINARY_PERMUTATIONS_1S_0S_EVERY_POINT_PERMUTATIONS": "def generate ( ones , zeroes , str , len1 ) :\n    if ( len1 == len ( str ) ) :\n        print ( str , end = \" \" )\n        return\n    generate ( ones + 1 , zeroes , str + \"1\" , len1 )\n    if ( ones > zeroes ) :\n        generate ( ones , zeroes + 1 , str + \"0\" , len1 )\n", "SEARCH_INSERT_AND_DELETE_IN_AN_UNSORTED_ARRAY": "def findElement ( arr , n , key ) :\n    for i in range ( n ) :\n        if ( arr [ i ] == key ) :\n            return i\n    return - 1\n", "LCS_LONGEST_COMMON_SUBSEQUENCE_THREE_STRINGS": "def lcsOf3 ( X , Y , Z , m , n , o ) :\n    L = [ [ [ 0 for i in range ( o + 1 ) ] for j in range ( n + 1 ) ] for k in range ( m + 1 ) ]\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            for k in range ( o + 1 ) :\n                if ( i == 0 or j == 0 or k == 0 ) :\n                    L [ i ] [ j ] [ k ] = 0\n                elif ( X [ i - 1 ] == Y [ j - 1 ] and X [ i - 1 ] == Z [ k - 1 ] ) :\n                    L [ i ] [ j ] [ k ] = L [ i - 1 ] [ j - 1 ] [ k - 1 ] + 1\n                else :\n                    L [ i ] [ j ] [ k ] = max ( max ( L [ i - 1 ] [ j ] [ k ] , L [ i ] [ j - 1 ] [ k ] ) , L [ i ] [ j ] [ k - 1 ] )\n    return L [ m ] [ n ] [ o ]\n", "MAXIMUM_SUM_SUBARRAY_REMOVING_ONE_ELEMENT": "def maxSumSubarrayRemovingOneEle ( arr , n ) :\n    fw = [ 0 for k in range ( n ) ]\n    bw = [ 0 for k in range ( n ) ]\n    cur_max , max_so_far = arr [ 0 ] , arr [ 0 ]\n    for i in range ( n ) :\n        cur_max = max ( arr [ i ] , cur_max + arr [ i ] )\n        max_so_far = max ( max_so_far , cur_max )\n        fw [ i ] = cur_max\n    cur_max = max_so_far = bw [ n - 1 ] = arr [ n - 1 ]\n    i = n - 2\n    while i >= 0 :\n        cur_max = max ( arr [ i ] , cur_max + arr [ i ] )\n        max_so_far = max ( max_so_far , cur_max )\n        bw [ i ] = cur_max\n        i -= 1\n    fans = max_so_far\n    for i in range ( 1 , n - 1 ) :\n        fans = max ( fans , fw [ i - 1 ] + bw [ i + 1 ] )\n    return fans\n", "COUNT_NUMBER_WAYS_TILE_FLOOR_SIZE_N_X_M_USING_1_X_M_SIZE_TILES": "def countWays ( n , m ) :\n    count = [ ]\n    for i in range ( n + 2 ) :\n        count.append ( 0 )\n    count [ 0 ] = 0\n    for i in range ( 1 , n + 1 ) :\n        if ( i > m ) :\n            count [ i ] = count [ i - 1 ] + count [ i - m ]\n        elif ( i < m ) :\n            count [ i ] = 1\n        else :\n            count [ i ] = 2\n    return count [ n ]\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS": "def middleOfThree ( a , b , c ) :\n    if ( ( a < b and b < c ) or ( c < b and b < a ) ) :\n        return b ;\n    if ( ( b < a and a < c ) or ( c < a and a < b ) ) :\n        return a ;\n    else :\n        return c\n", "LONGEST_COMMON_INCREASING_SUBSEQUENCE_LCS_LIS": "def LCIS ( arr1 , n , arr2 , m ) :\n    table = [ 0 ] * m\n    for j in range ( m ) :\n        table [ j ] = 0\n    for i in range ( n ) :\n        current = 0\n        for j in range ( m ) :\n            if ( arr1 [ i ] == arr2 [ j ] ) :\n                if ( current + 1 > table [ j ] ) :\n                    table [ j ] = current + 1\n            if ( arr1 [ i ] > arr2 [ j ] ) :\n                if ( table [ j ] > current ) :\n                    current = table [ j ]\n    result = 0\n    for i in range ( m ) :\n        if ( table [ i ] > result ) :\n            result = table [ i ]\n    return result\n", "MAXIMUM_SUBSEQUENCE_SUM_SUCH_THAT_NO_THREE_ARE_CONSECUTIVE": "def maxSumWO3Consec ( arr , n ) :\n    sum = [ 0 for k in range ( n ) ]\n    if n >= 1 :\n        sum [ 0 ] = arr [ 0 ]\n    if n >= 2 :\n        sum [ 1 ] = arr [ 0 ] + arr [ 1 ]\n    if n > 2 :\n        sum [ 2 ] = max ( sum [ 1 ] , max ( arr [ 1 ] + arr [ 2 ] , arr [ 0 ] + arr [ 2 ] ) )\n    for i in range ( 3 , n ) :\n        sum [ i ] = max ( max ( sum [ i - 1 ] , sum [ i - 2 ] + arr [ i ] ) , arr [ i ] + arr [ i - 1 ] + sum [ i - 3 ] )\n    return sum [ n - 1 ]\n", "EULERIAN_NUMBER_1": "def eulerian ( n , m ) :\n    dp = [ [ 0 for x in range ( m + 1 ) ] for y in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 0 , m + 1 ) :\n            if ( i > j ) :\n                if ( j == 0 ) :\n                    dp [ i ] [ j ] = 1\n                else :\n                    dp [ i ] [ j ] = ( ( ( i - j ) * dp [ i - 1 ] [ j - 1 ] ) + ( ( j + 1 ) * dp [ i - 1 ] [ j ] ) )\n    return dp [ n ] [ m ]\n", "DOUBLE_FACTORIAL": "def doublefactorial ( n ) :\n    if ( n == 0 or n == 1 ) :\n        return 1 ;\n    return n * doublefactorial ( n - 2 ) ;\n", "REARRANGE_POSITIVE_AND_NEGATIVE_NUMBERS_PUBLISH": "def rearrange ( arr , n ) :\n    i = - 1\n    for j in range ( n ) :\n        if ( arr [ j ] < 0 ) :\n            i += 1\n            arr [ i ] , arr [ j ] = arr [ j ] , arr [ i ]\n    pos , neg = i + 1 , 0\n    while ( pos < n and neg < pos and arr [ neg ] < 0 ) :\n        arr [ neg ] , arr [ pos ] = arr [ pos ] , arr [ neg ]\n        pos += 1\n        neg += 2\n", "MAXIMIZE_ARRAY_SUN_AFTER_K_NEGATION_OPERATIONS": "def maximumSum ( arr , n , k ) :\n    for i in range ( 1 , k + 1 ) :\n        min = + 2147483647\n        index = - 1\n        for j in range ( n ) :\n            if ( arr [ j ] < min ) :\n                min = arr [ j ]\n                index = j\n        if ( min == 0 ) :\n            break\n        arr [ index ] = - arr [ index ]\n    sum = 0\n    for i in range ( n ) :\n        sum += arr [ i ]\n    return sum\n", "MAXIMUM_SUM_INCREASING_SUBSEQUENCE_FROM_A_PREFIX_AND_A_GIVEN_ELEMENT_AFTER_PREFIX_IS_MUST": "def pre_compute ( a , n , index , k ) :\n    dp = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    for i in range ( n ) :\n        if a [ i ] > a [ 0 ] :\n            dp [ 0 ] [ i ] = a [ i ] + a [ 0 ]\n        else :\n            dp [ 0 ] [ i ] = a [ i ]\n    for i in range ( 1 , n ) :\n        for j in range ( n ) :\n            if a [ j ] > a [ i ] and j > i :\n                if dp [ i - 1 ] [ i ] + a [ j ] > dp [ i - 1 ] [ j ] :\n                    dp [ i ] [ j ] = dp [ i - 1 ] [ i ] + a [ j ]\n                else :\n                    dp [ i ] [ j ] = dp [ i - 1 ] [ j ]\n            else :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j ]\n    return dp [ index ] [ k ]\n", "FUNCTION_COPY_STRING_ITERATIVE_RECURSIVE": "def myCopy ( s1 , s2 ) :\n    for i in range ( len ( s1 ) ) :\n        s2 [ i ] = s1 [ i ] ;\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND_1": "def isSubSequence ( str1 , str2 , m , n ) :\n    j = 0\n    i = 0\n    while j < m and i < n :\n        if str1 [ j ] == str2 [ i ] :\n            j = j + 1\n        i = i + 1\n    return j == m\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y_1": "def unitnumber ( x , y ) :\n    x = x % 10\n    if y != 0 :\n        y = y % 4 + 4\n    return ( ( ( int ) ( math.pow ( x , y ) ) ) % 10 )\n", "PROGRAM_NEXT_FIT_ALGORITHM_MEMORY_MANAGEMENT": "def NextFit ( blockSize , m , processSize , n ) :\n    allocation = [ - 1 ] * n\n    j = 0\n    for i in range ( n ) :\n        while j < m :\n            if blockSize [ j ] >= processSize [ i ] :\n                allocation [ i ] = j\n                blockSize [ j ] -= processSize [ i ]\n                break\n            j = ( j + 1 ) % m\n    print ( \"Process No.Process Size Block no.\" )\n    for i in range ( n ) :\n        print ( i + 1 , \"         \" , processSize [ i ] , end = \"     \" )\n        if allocation [ i ] != - 1 :\n            print ( allocation [ i ] + 1 )\n        else :\n            print ( \"Not Allocated\" )\n", "NOBLE_INTEGERS_IN_AN_ARRAY_COUNT_OF_GREATER_ELEMENTS_IS_EQUAL_TO_VALUE": "def nobleInteger ( arr , size ) :\n    for i in range ( 0 , size ) :\n        count = 0\n        for j in range ( 0 , size ) :\n            if ( arr [ i ] < arr [ j ] ) :\n                count += 1\n        if ( count == arr [ i ] ) :\n            return arr [ i ]\n    return - 1\n", "MINIMUM_FLIP_REQUIRED_MAKE_BINARY_MATRIX_SYMMETRIC": "def minimumflip ( mat , n ) :\n    transpose = [ [ 0 ] * n ] * n\n    for i in range ( n ) :\n        for j in range ( n ) :\n            transpose [ i ] [ j ] = mat [ j ] [ i ]\n    flip = 0\n    for i in range ( n ) :\n        for j in range ( n ) :\n            if transpose [ i ] [ j ] != mat [ i ] [ j ] :\n                flip += 1\n    return int ( flip / 2 )\n", "SEGREGATE_EVEN_ODD_NUMBERS_SET_3": "def arrayEvenAndOdd ( arr , n ) :\n    i = - 1\n    j = 0\n    while ( j != n ) :\n        if ( arr [ j ] % 2 == 0 ) :\n            i = i + 1\n            arr [ i ] , arr [ j ] = arr [ j ] , arr [ i ]\n        j = j + 1\n    for i in arr :\n        print ( str ( i ) + \" \" , end = '' )\n", "DFS_N_ARY_TREE_ACYCLIC_GRAPH_REPRESENTED_ADJACENCY_LIST": "def dfs ( List , node , arrival ) :\n    print ( node )\n    for i in range ( len ( List [ node ] ) ) :\n        if ( List [ node ] [ i ] != arrival ) :\n            dfs ( List , List [ node ] [ i ] , node )\n", "HOW_TO_TURN_OFF_A_PARTICULAR_BIT_IN_A_NUMBER": "def turnOffK ( n , k ) :\n    if ( k <= 0 ) :\n        return n\n    return ( n & ~ ( 1 << ( k - 1 ) ) )\n", "NUMBER_SUBSTRINGS_DIVISIBLE_8_NOT_3": "def count ( s , Len ) :\n    global MAX\n    cur = 0\n    dig = 0\n    Sum = [ 0 ] * MAX\n    dp = [ [ 0 , 0 , 0 ] for i in range ( MAX ) ]\n    dp [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , Len + 1 ) :\n        dig = int ( s [ i - 1 ] ) - 48\n        cur += dig\n        cur %= 3\n        Sum [ i ] = cur\n        dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ]\n        dp [ i ] [ 1 ] = dp [ i - 1 ] [ 1 ]\n        dp [ i ] [ 2 ] = dp [ i - 1 ] [ 2 ]\n        dp [ i ] [ Sum [ i ] ] += 1\n    ans = 0\n    dprev = 0\n    value = 0\n    dprev2 = 0\n    for i in range ( 1 , Len + 1 ) :\n        dig = int ( s [ i - 1 ] ) - 48\n        if dig == 8 :\n            ans += 1\n        if i - 2 >= 0 :\n            dprev = int ( s [ i - 2 ] ) - 48\n            value = dprev * 10 + dig\n            if ( value % 8 == 0 ) and ( value % 3 != 0 ) :\n                ans += 1\n        if i - 3 >= 0 :\n            dprev2 = int ( s [ i - 3 ] ) - 48\n            dprev = int ( s [ i - 2 ] ) - 48\n            value = ( dprev2 * 100 + dprev * 10 + dig )\n            if value % 8 != 0 :\n                continue\n            ans += ( i - 2 )\n            ans -= ( dp [ i - 3 ] [ Sum [ i ] ] )\n    return ans\n", "ADD_1_TO_A_GIVEN_NUMBER_1": "def addOne ( x ) :\n    return ( - ( ~ x ) ) ;\n", "CHECK_STRING_FOLLOWS_ANBN_PATTERN_NOT": "def isAnBn ( str ) :\n    n = len ( str )\n    for i in range ( n ) :\n        if ( str [ i ] != 'a' ) :\n            break\n    if ( i * 2 != n ) :\n        return False\n    for j in range ( i , n ) :\n        if ( str [ j ] != 'b' ) :\n            return False\n    return True\n", "FIND_FIRST_REPEATING_ELEMENT_ARRAY_INTEGERS": "def printFirstRepeating ( arr , n ) :\n    Min = - 1\n    myset = dict ( )\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if arr [ i ] in myset.keys ( ) :\n            Min = i\n        else :\n            myset [ arr [ i ] ] = 1\n    if ( Min != - 1 ) :\n        print ( \"The first repeating element is\" , arr [ Min ] )\n    else :\n        print ( \"There are no repeating elements\" )\n", "COST_BALANCE_PARANTHESES": "def costToBalance ( s ) :\n    if ( len ( s ) == 0 ) :\n        print ( 0 )\n    ans = 0\n    o = 0\n    c = 0\n    for i in range ( len ( s ) ) :\n        if ( s [ i ] == '(' ) :\n            o += 1\n        if ( s [ i ] == ')' ) :\n            c += 1\n    if ( o != c ) :\n        return - 1\n    a = [ 0 for i in range ( len ( s ) ) ]\n    if ( s [ 0 ] == '(' ) :\n        a [ 0 ] = 1\n    else :\n        a [ 0 ] = - 1\n    if ( a [ 0 ] < 0 ) :\n        ans += abs ( a [ 0 ] )\n    for i in range ( 1 , len ( s ) ) :\n        if ( s [ i ] == '(' ) :\n            a [ i ] = a [ i - 1 ] + 1\n        else :\n            a [ i ] = a [ i - 1 ] - 1\n        if ( a [ i ] < 0 ) :\n            ans += abs ( a [ i ] )\n    return ans\n", "COIN_GAME_WINNER_EVERY_PLAYER_THREE_CHOICES": "def findWinner ( x , y , n ) :\n    dp = [ 0 for i in range ( n + 1 ) ]\n    dp [ 0 ] = False\n    dp [ 1 ] = True\n    for i in range ( 2 , n + 1 ) :\n        if ( i - 1 >= 0 and not dp [ i - 1 ] ) :\n            dp [ i ] = True\n        elif ( i - x >= 0 and not dp [ i - x ] ) :\n            dp [ i ] = True\n        elif ( i - y >= 0 and not dp [ i - y ] ) :\n            dp [ i ] = True\n        else :\n            dp [ i ] = False\n    return dp [ n ]\n", "SEQUENCES_GIVEN_LENGTH_EVERY_ELEMENT_EQUAL_TWICE_PREVIOUS": "def getTotalNumberOfSequences ( m , n ) :\n    if m < n :\n        return 0\n    if n == 0 :\n        return 1\n    res = ( getTotalNumberOfSequences ( m - 1 , n ) + getTotalNumberOfSequences ( m // 2 , n - 1 ) )\n    return res\n", "FIND_DUPLICATES_GIVEN_ARRAY_ELEMENTS_NOT_LIMITED_RANGE": "def printDuplicates ( arr ) :\n    dict = { }\n    for ele in arr :\n        try :\n            dict [ ele ] += 1\n        except :\n            dict [ ele ] = 1\n    for item in dict :\n        if ( dict [ item ] > 1 ) :\n            print ( item , end = \" \" )\n    print ( \"\\n\" )\n", "LONGEST_REPEATING_SUBSEQUENCE_1": "def findLongestRepeatingSubSeq ( X , m , n ) :\n    if ( dp [ m ] [ n ] != - 1 ) :\n        return dp [ m ] [ n ]\n    if ( m == 0 or n == 0 ) :\n        dp [ m ] [ n ] = 0\n        return dp [ m ] [ n ]\n    if ( X [ m - 1 ] == X [ n - 1 ] and m != n ) :\n        dp [ m ] [ n ] = findLongestRepeatingSubSeq ( X , m - 1 , n - 1 ) + 1\n        return dp [ m ] [ n ]\n    dp [ m ] [ n ] = max ( findLongestRepeatingSubSeq ( X , m , n - 1 ) , findLongestRepeatingSubSeq ( X , m - 1 , n ) )\n    return dp [ m ] [ n ]\n", "COUNT_OF_N_DIGIT_NUMBERS_WHOSE_SUM_OF_DIGITS_EQUALS_TO_GIVEN_SUM": "def findCount ( n , sum ) :\n    start = math.pow ( 10 , n - 1 ) ;\n    end = math.pow ( 10 , n ) - 1 ;\n    count = 0 ;\n    i = start ;\n    while ( i <= end ) :\n        cur = 0 ;\n        temp = i ;\n        while ( temp != 0 ) :\n            cur += temp % 10 ;\n            temp = temp // 10 ;\n        if ( cur == sum ) :\n            count = count + 1 ;\n            i += 9 ;\n        else :\n            i = i + 1 ;\n    print ( count ) ;\n", "MINIMUM_COST_CONNECT_WEIGHTED_NODES_REPRESENTED_ARRAY": "def minimum_cost ( a , n ) :\n    mn = sys.maxsize\n    sum = 0\n    for i in range ( n ) :\n        mn = min ( a [ i ] , mn )\n        sum += a [ i ]\n    return mn * ( sum - mn )\n", "FIND_ALL_DIVISORS_OF_A_NATURAL_NUMBER_SET_2": "def printDivisors ( n ) :\n    list = [ ]\n    for i in range ( 1 , int ( math.sqrt ( n ) + 1 ) ) :\n        if ( n % i == 0 ) :\n            if ( n / i == i ) :\n                print ( i , end = \" \" )\n            else :\n                print ( i , end = \" \" )\n                list.append ( int ( n / i ) )\n    for i in list [ : : - 1 ] :\n        print ( i , end = \" \" )\n", "SQUARES_OF_MATRIX_DIAGONAL_ELEMENTS_1": "def diagonalsquare ( mat , row , column ) :\n    print ( \"Diagonal one : \" , end = \"\" )\n    for i in range ( 0 , row ) :\n        print ( mat [ i ] [ i ] * mat [ i ] [ i ] , end = \"\" )\n    print ( \"\\n\\nDiagonal two : \" , end = \"\" )\n    for i in range ( 0 , row ) :\n        print ( mat [ i ] [ row - i - 1 ] * mat [ i ] [ row - i - 1 ] , end = \"\" )\n", "C_PROGRAM_FIND_AREA_TRIANGLE_1": "def polygonArea ( X , Y , n ) :\n    area = 0.0\n    j = n - 1\n    for i in range ( 0 , n ) :\n        area = area + ( X [ j ] + X [ i ] ) * ( Y [ j ] - Y [ i ] )\n        j = i\n    return abs ( area // 2.0 )\n", "RANGE_QUERIES_FOR_FREQUENCIES_OF_ARRAY_ELEMENTS": "def findFrequency ( arr , n , left , right , element ) :\n    count = 0\n    for i in range ( left - 1 , right ) :\n        if ( arr [ i ] == element ) :\n            count += 1\n    return count\n", "SERIES_LARGEST_GCD_SUM_EQUALS_N": "def print_sequence ( n , k ) :\n    b = int ( n / ( k * ( k + 1 ) / 2 ) ) ;\n    if b == 0 :\n        print ( \"-1\" )\n    else :\n        r = 1 ;\n        x = 1\n        while x ** 2 <= n :\n            if n % x != 0 :\n                continue ;\n            elif x <= b and x > r :\n                r = x\n            elif n / x <= b and n / x > r :\n                r = n / x\n            x = x + 1\n        i = 1\n        while i < k :\n            print ( r * i , end = \" \" )\n            i = i + 1\n        last_term = n - ( r * ( k * ( k - 1 ) / 2 ) )\n        print ( last_term )\n", "FIND_THREE_ELEMENT_FROM_DIFFERENT_THREE_ARRAYS_SUCH_THAT_THAT_A_B_C_K_1": "def findTriplet ( a1 , a2 , a3 , n1 , n2 , n3 , sum ) :\n    s = set ( )\n    for i in range ( n1 ) :\n        s.add ( a1 [ i ] )\n    for i in range ( n2 ) :\n        for j in range ( n3 ) :\n            if sum - a2 [ i ] - a3 [ j ] in s :\n                return True\n    return False\n", "FIND_THE_MAXIMUM_ELEMENT_IN_AN_ARRAY_WHICH_IS_FIRST_INCREASING_AND_THEN_DECREASING_1": "def findMaximum ( arr , low , high ) :\n    if low == high :\n        return arr [ low ]\n    if high == low + 1 and arr [ low ] >= arr [ high ] :\n        return arr [ low ] ;\n    if high == low + 1 and arr [ low ] < arr [ high ] :\n        return arr [ high ]\n    mid = ( low + high ) // 2\n    if arr [ mid ] > arr [ mid + 1 ] and arr [ mid ] > arr [ mid - 1 ] :\n        return arr [ mid ]\n    if arr [ mid ] > arr [ mid + 1 ] and arr [ mid ] < arr [ mid - 1 ] :\n        return findMaximum ( arr , low , mid - 1 )\n    else :\n        return findMaximum ( arr , mid + 1 , high )\n", "DYNAMIC_PROGRAMMING_SET_1": "def fib ( n , lookup ) :\n    if n == 0 or n == 1 :\n        lookup [ n ] = n\n    if lookup [ n ] is None :\n        lookup [ n ] = fib ( n - 1 , lookup ) + fib ( n - 2 , lookup )\n    return lookup [ n ]\n", "MODULAR_EXPONENTIATION_POWER_IN_MODULAR_ARITHMETIC": "def power ( x , y , p ) :\n    res = 1\n    x = x % p\n    while ( y > 0 ) :\n        if ( ( y & 1 ) == 1 ) :\n            res = ( res * x ) % p\n        y = y >> 1\n        x = ( x * x ) % p\n    return res\n", "WRITE_ONE_LINE_C_FUNCTION_TO_FIND_WHETHER_A_NO_IS_POWER_OF_TWO_1": "def isPowerOfTwo ( x ) :\n    return ( x and ( not ( x & ( x - 1 ) ) ) )\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_PERMUTATIONS_ALLOWED": "def longestString ( str1 , str2 ) :\n    count1 = [ 0 ] * 26\n    count2 = [ 0 ] * 26\n    for i in range ( len ( str1 ) ) :\n        count1 [ ord ( str1 [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( len ( str2 ) ) :\n        count2 [ ord ( str2 [ i ] ) - ord ( 'a' ) ] += 1\n    result = \"\"\n    for i in range ( 26 ) :\n        for j in range ( 1 , min ( count1 [ i ] , count2 [ i ] ) + 1 ) :\n            result = result + chr ( ord ( 'a' ) + i )\n    print ( result )\n", "DIFFERENCE_MAXIMUM_SUM_MINIMUM_SUM_N_M_ELEMENTSIN_REVIEW": "def find_difference ( arr , n , m ) :\n    max = 0 ; min = 0\n    arr.sort ( ) ;\n    j = n - 1\n    for i in range ( m ) :\n        min += arr [ i ]\n        max += arr [ j ]\n        j = j - 1\n    return ( max - min )\n", "PRINT_NUMBER_ASCENDING_ORDER_CONTAINS_1_2_3_DIGITS": "def printNumbers ( numbers ) :\n    numbers = map ( str , numbers )\n    result = [ ]\n    for num in numbers :\n        if ( '1' in num and '2' in num and '3' in num ) :\n            result.append ( num )\n    if not result :\n        result = [ '-1' ]\n    return sorted ( result ) ;\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE": "def lis ( arr ) :\n    global maximum\n    n = len ( arr )\n    maximum = 1\n    _lis ( arr , n )\n    return maximum\n", "MINIMUM_REVOLUTIONS_MOVE_CENTER_CIRCLE_TARGET": "def minRevolutions ( r , x1 , y1 , x2 , y2 ) :\n    d = math.sqrt ( ( x1 - x2 ) * ( x1 - x2 ) + ( y1 - y2 ) * ( y1 - y2 ) )\n    return math.ceil ( d // ( 2 * r ) )\n", "CHECK_TWO_GIVEN_SETS_DISJOINT": "def areDisjoint ( set1 , set2 , m , n ) :\n    for i in range ( 0 , m ) :\n        for j in range ( 0 , n ) :\n            if ( set1 [ i ] == set2 [ j ] ) :\n                return False\n    return True\n", "FIND_MINIMUM_SUM_FACTORS_NUMBER": "def findMinSum ( num ) :\n    sum = 0\n    i = 2\n    while ( i * i <= num ) :\n        while ( num % i == 0 ) :\n            sum += i\n            num /= i\n        i += 1\n    sum += num\n    return sum\n", "FREQUENT_ELEMENT_ARRAY": "def mostFrequent ( arr , n ) :\n    arr.sort ( )\n    max_count = 1 ; res = arr [ 0 ] ; curr_count = 1\n    for i in range ( 1 , n ) :\n        if ( arr [ i ] == arr [ i - 1 ] ) :\n            curr_count += 1\n        else :\n            if ( curr_count > max_count ) :\n                max_count = curr_count\n                res = arr [ i - 1 ]\n            curr_count = 1\n    if ( curr_count > max_count ) :\n        max_count = curr_count\n        res = arr [ n - 1 ]\n    return res\n", "MINIMUM_XOR_VALUE_PAIR_1": "def minXOR ( arr , n ) :\n    arr.sort ( )\n    minXor = int ( sys.float_info.max )\n    val = 0\n    for i in range ( 0 , n - 1 ) :\n        val = arr [ i ] ^ arr [ i + 1 ] ;\n        minXor = min ( minXor , val ) ;\n    return minXor\n", "MINIMUM_SUM_PRODUCT_TWO_ARRAYS": "def minproduct ( a , b , n , k ) :\n    diff = 0\n    res = 0\n    for i in range ( n ) :\n        pro = a [ i ] * b [ i ]\n        res = res + pro\n        if ( pro < 0 and b [ i ] < 0 ) :\n            temp = ( a [ i ] + 2 * k ) * b [ i ]\n        elif ( pro < 0 and a [ i ] < 0 ) :\n            temp = ( a [ i ] - 2 * k ) * b [ i ]\n        elif ( pro > 0 and a [ i ] < 0 ) :\n            temp = ( a [ i ] + 2 * k ) * b [ i ]\n        elif ( pro > 0 and a [ i ] > 0 ) :\n            temp = ( a [ i ] - 2 * k ) * b [ i ]\n        d = abs ( pro - temp )\n        if ( d > diff ) :\n            diff = d\n    return res - diff\n", "FAST_MULTIPLICATION_METHOD_WITHOUT_USING_MULTIPLICATION_OPERATOR_RUSSIAN_PEASANTS_ALGORITHM": "def russianPeasant ( a , b ) :\n    res = 0\n    while ( b > 0 ) :\n        if ( b & 1 ) :\n            res = res + a\n        a = a << 1\n        b = b >> 1\n    return res\n", "DIVISIBILITY_9_USING_BITWISE_OPERATORS": "def isDivBy9 ( n ) :\n    if ( n == 0 or n == 9 ) :\n        return True\n    if ( n < 9 ) :\n        return False\n    return isDivBy9 ( ( int ) ( n >> 3 ) - ( int ) ( n & 7 ) )\n", "CHECK_ARRAY_REPRESENTS_INORDER_BINARY_SEARCH_TREE_NOT": "def isInorder ( arr , n ) :\n    if ( n == 0 or n == 1 ) :\n        return True\n    for i in range ( 1 , n , 1 ) :\n        if ( arr [ i - 1 ] > arr [ i ] ) :\n            return False\n    return True\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X": "def findPairs ( arr1 , arr2 , n , m , x ) :\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , m ) :\n            if ( arr1 [ i ] + arr2 [ j ] == x ) :\n                print ( arr1 [ i ] , arr2 [ j ] )\n", "BINARY_REPRESENTATION_OF_NEXT_NUMBER": "def nextGreater ( num1 ) :\n    l = len ( num1 ) ;\n    num = list ( num1 ) ;\n    i = l - 1 ;\n    while ( i >= 0 ) :\n        if ( num [ i ] == '0' ) :\n            num [ i ] = '1' ;\n            break ;\n        else :\n            num [ i ] = '0' ;\n        i -= 1 ;\n    num1 = ''.join ( num ) ;\n    if ( i < 0 ) :\n        num1 = '1' + num1 ;\n    return num1 ;\n", "LARGEST_SUBARRAY_WITH_EQUAL_NUMBER_OF_0S_AND_1S": "def findSubArray ( arr , n ) :\n    sum = 0\n    maxsize = - 1\n    for i in range ( 0 , n - 1 ) :\n        sum = - 1 if ( arr [ i ] == 0 ) else 1\n        for j in range ( i + 1 , n ) :\n            sum = sum + ( - 1 ) if ( arr [ j ] == 0 ) else sum + 1\n            if ( sum == 0 and maxsize < j - i + 1 ) :\n                maxsize = j - i + 1\n                startindex = i\n    if ( maxsize == - 1 ) :\n        print ( \"No such subarray\" ) ;\n    else :\n        print ( startindex , \"to\" , startindex + maxsize - 1 ) ;\n    return maxsize\n", "COUNT_PAIRS_WHOSE_PRODUCTS_EXIST_IN_ARRAY_1": "def countPairs ( arr , n ) :\n    result = 0\n    Hash = set ( )\n    for i in range ( n ) :\n        Hash.add ( arr [ i ] )\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            product = arr [ i ] * arr [ j ]\n            if product in ( Hash ) :\n                result += 1\n    return result\n", "DYNAMIC_PROGRAMMING_SET_12_LONGEST_PALINDROMIC_SUBSEQUENCE": "def lps ( str ) :\n    n = len ( str )\n    L = [ [ 0 for x in range ( n ) ] for x in range ( n ) ]\n    for i in range ( n ) :\n        L [ i ] [ i ] = 1\n    for cl in range ( 2 , n + 1 ) :\n        for i in range ( n - cl + 1 ) :\n            j = i + cl - 1\n            if str [ i ] == str [ j ] and cl == 2 :\n                L [ i ] [ j ] = 2\n            elif str [ i ] == str [ j ] :\n                L [ i ] [ j ] = L [ i + 1 ] [ j - 1 ] + 2\n            else :\n                L [ i ] [ j ] = max ( L [ i ] [ j - 1 ] , L [ i + 1 ] [ j ] ) ;\n    return L [ 0 ] [ n - 1 ]\n", "COUNT_INVERSIONS_OF_SIZE_THREE_IN_A_GIVE_ARRAY_1": "def getInvCount ( arr , n ) :\n    invcount = 0\n    for i in range ( 1 , n - 1 ) :\n        small = 0\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] > arr [ j ] ) :\n                small += 1\n        great = 0 ;\n        for j in range ( i - 1 , - 1 , - 1 ) :\n            if ( arr [ i ] < arr [ j ] ) :\n                great += 1\n        invcount += great * small\n    return invcount\n", "DECIMAL_REPRESENTATION_GIVEN_BINARY_STRING_DIVISIBLE_10_NOT": "def isDivisibleBy10 ( bin ) :\n    n = len ( bin )\n    if ( bin [ n - 1 ] == '1' ) :\n        return False\n    sum = 0\n    i = n - 2\n    while i >= 0 :\n        if ( bin [ i ] == '1' ) :\n            posFromRight = n - i - 1\n            if ( posFromRight % 4 == 1 ) :\n                sum = sum + 2\n            elif ( posFromRight % 4 == 2 ) :\n                sum = sum + 4\n            elif ( posFromRight % 4 == 3 ) :\n                sum = sum + 8\n            elif ( posFromRight % 4 == 0 ) :\n                sum = sum + 6\n        i = i - 1\n    if ( sum % 10 == 0 ) :\n        return True\n    return False\n", "FIND_WHETHER_AN_ARRAY_IS_SUBSET_OF_ANOTHER_ARRAY_SET_1_1": "def isSubset ( arr1 , arr2 , m , n ) :\n    i = 0\n    j = 0\n    if m < n :\n        return 0\n    arr1.sort ( )\n    arr2.sort ( )\n    while i < n and j < m :\n        if arr1 [ j ] < arr2 [ i ] :\n            j += 1\n        elif arr1 [ j ] == arr2 [ i ] :\n            j += 1\n            i += 1\n        elif arr1 [ j ] > arr2 [ i ] :\n            return 0\n    return False if i < n else True\n", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM_1": "def isSubsetSum ( set , n , sum ) :\n    subset = ( [ [ False for i in range ( sum + 1 ) ] for i in range ( n + 1 ) ] )\n    for i in range ( n + 1 ) :\n        subset [ i ] [ 0 ] = True\n        for i in range ( 1 , sum + 1 ) :\n            subset [ 0 ] [ i ] = False\n        for i in range ( 1 , n + 1 ) :\n            for j in range ( 1 , sum + 1 ) :\n                if j < set [ i - 1 ] :\n                    subset [ i ] [ j ] = subset [ i - 1 ] [ j ]\n                if j >= set [ i - 1 ] :\n                    subset [ i ] [ j ] = ( subset [ i - 1 ] [ j ] or subset [ i - 1 ] [ j - set [ i - 1 ] ] )\n    return subset [ n ] [ sum ]\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS_1": "def kthgroupsum ( k ) :\n    return k * k * k\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS": "def thirdLargest ( arr , arr_size ) :\n    if ( arr_size < 3 ) :\n        print ( \" Invalid Input \" )\n        return\n    first = arr [ 0 ]\n    for i in range ( 1 , arr_size ) :\n        if ( arr [ i ] > first ) :\n            first = arr [ i ]\n    second = - sys.maxsize\n    for i in range ( 0 , arr_size ) :\n        if ( arr [ i ] > second and arr [ i ] < first ) :\n            second = arr [ i ]\n    third = - sys.maxsize\n    for i in range ( 0 , arr_size ) :\n        if ( arr [ i ] > third and arr [ i ] < second ) :\n            third = arr [ i ]\n    print ( \"The Third Largest\" , \"element is\" , third )\n", "FIND_SUM_NODES_GIVEN_PERFECT_BINARY_TREE_1": "def sumNodes ( l ) :\n    leafNodeCount = math.pow ( 2 , l - 1 ) ;\n    sumLastLevel = 0 ;\n    sumLastLevel = ( ( leafNodeCount * ( leafNodeCount + 1 ) ) / 2 ) ;\n    sum = sumLastLevel * l ;\n    return int ( sum ) ;\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS_2": "def middleOfThree ( a , b , c ) :\n    x = a - b\n    y = b - c\n    z = a - c\n    if x * y > 0 :\n        return b\n    elif ( x * z > 0 ) :\n        return\n    else :\n        return a\n", "MAXIMUM_TRIPLET_SUM_ARRAY_2": "def maxTripletSum ( arr , n ) :\n    maxA = - 100000000\n    maxB = - 100000000\n    maxC = - 100000000\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] > maxA ) :\n            maxC = maxB\n            maxB = maxA\n            maxA = arr [ i ]\n        elif ( arr [ i ] > maxB ) :\n            maxC = maxB\n            maxB = arr [ i ]\n        elif ( arr [ i ] > maxC ) :\n            maxC = arr [ i ]\n    return ( maxA + maxB + maxC )\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X_1": "def countPairs ( arr1 , arr2 , m , n , x ) :\n    count = 0\n    us = set ( )\n    for i in range ( m ) :\n        us.add ( arr1 [ i ] )\n    for j in range ( n ) :\n        if x - arr2 [ j ] in us :\n            count += 1\n    return count\n", "MINIMUM_STEPS_REACH_END_ARRAY_CONSTRAINTS": "def getMinStepToReachEnd ( arr , N ) :\n    visit = [ False for i in range ( N ) ]\n    distance = [ 0 for i in range ( N ) ]\n    digit = [ [ 0 for i in range ( N ) ] for j in range ( 10 ) ]\n    for i in range ( 1 , N ) :\n        digit [ arr [ i ] ].append ( i )\n    distance [ 0 ] = 0\n    visit [ 0 ] = True\n    q = [ ]\n    q.append ( 0 )\n    while ( len ( q ) > 0 ) :\n        idx = q [ 0 ]\n        q.remove ( q [ 0 ] )\n        if ( idx == N - 1 ) :\n            break\n        d = arr [ idx ]\n        for i in range ( len ( digit [ d ] ) ) :\n            nextidx = digit [ d ] [ i ]\n            if ( visit [ nextidx ] == False ) :\n                visit [ nextidx ] = True\n                q.append ( nextidx )\n                distance [ nextidx ] = distance [ idx ] + 1\n        if ( idx - 1 >= 0 and visit [ idx - 1 ] == False ) :\n            visit [ idx - 1 ] = True\n            q.append ( idx - 1 )\n            distance [ idx - 1 ] = distance [ idx ] + 1\n        if ( idx + 1 < N and visit [ idx + 1 ] == False ) :\n            visit [ idx + 1 ] = True\n            q.append ( idx + 1 )\n            distance [ idx + 1 ] = distance [ idx ] + 1\n    return distance [ N - 1 ]\n", "LEXICOGRAPHICALLY_SMALLEST_ARRAY_K_CONSECUTIVE_SWAPS": "def minimizeWithKSwaps ( arr , n , k ) :\n    for i in range ( n - 1 ) :\n        pos = i\n        for j in range ( i + 1 , n ) :\n            if ( j - i > k ) :\n                break\n            if ( arr [ j ] < arr [ pos ] ) :\n                pos = j\n        for j in range ( pos , i , - 1 ) :\n            arr [ j ] , arr [ j - 1 ] = arr [ j - 1 ] , arr [ j ]\n        k -= pos - i\n", "CONVERT_SENTENCE_EQUIVALENT_MOBILE_NUMERIC_KEYPAD_SEQUENCE": "def printSequence ( arr , input ) :\n    n = len ( input )\n    output = \"\"\n    for i in range ( n ) :\n        if ( input [ i ] == ' ' ) :\n            output = output + \"0\"\n        else :\n            position = ord ( input [ i ] ) - ord ( 'A' )\n            output = output + arr [ position ]\n    return output\n", "PROGRAM_CHECK_ARRAY_SORTED_NOT_ITERATIVE_RECURSIVE": "def arraySortedOrNot ( arr ) :\n    n = len ( arr )\n    if n == 1 or n == 0 :\n        return True\n    return arr [ 0 ] <= arr [ 1 ] and arraySortedOrNot ( arr [ 1 : ] )\n", "CHECK_TWO_GIVEN_CIRCLES_TOUCH_INTERSECT": "def circle ( x1 , y1 , x2 , y2 , r1 , r2 ) :\n    distSq = ( x1 - x2 ) * ( x1 - x2 ) + ( y1 - y2 ) * ( y1 - y2 ) ;\n    radSumSq = ( r1 + r2 ) * ( r1 + r2 ) ;\n    if ( distSq == radSumSq ) :\n        return 1\n    elif ( distSq > radSumSq ) :\n        return - 1\n    else :\n        return 0\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N_2": "def nextPowerOf2 ( n ) :\n    n -= 1\n    n |= n >> 1\n    n |= n >> 2\n    n |= n >> 4\n    n |= n >> 8\n    n |= n >> 16\n    n += 1\n    return n\n", "PADOVAN_SEQUENCE": "def pad ( n ) :\n    pPrevPrev , pPrev , pCurr , pNext = 1 , 1 , 1 , 1\n    for i in range ( 3 , n + 1 ) :\n        pNext = pPrevPrev + pPrev\n        pPrevPrev = pPrev\n        pPrev = pCurr\n        pCurr = pNext\n    return pNext ;\n", "CHECK_GIVEN_STRING_CAN_SPLIT_FOUR_DISTINCT_STRINGS": "def check ( s ) :\n    if ( len ( s ) >= 10 ) :\n        return True\n    for i in range ( 1 , len ( s ) ) :\n        for j in range ( i + 1 , len ( s ) ) :\n            for k in range ( j + 1 , len ( s ) ) :\n                s1 = s [ 0 : i ]\n                s2 = s [ i : j - i ]\n                s3 = s [ j : k - j ]\n                s4 = s [ k : len ( s ) - k ]\n                if ( s1 != s2 and s1 != s3 and s1 != s4 and s2 != s3 and s2 != s4 and s3 != s4 ) :\n                    return True\n    return False\n", "PERMUTE_TWO_ARRAYS_SUM_EVERY_PAIR_GREATER_EQUAL_K": "def isPossible ( a , b , n , k ) :\n    a.sort ( reverse = True )\n    b.sort ( )\n    for i in range ( n ) :\n        if ( a [ i ] + b [ i ] < k ) :\n            return False\n    return True\n", "ARRAY_ELEMENT_MOVED_K_USING_SINGLE_MOVES": "def winner ( a , n , k ) :\n    if k >= n - 1 :\n        return n\n    best = 0\n    times = 0\n    for i in range ( n ) :\n        if a [ i ] > best :\n            best = a [ i ]\n            if i == True :\n                times = 1\n        else :\n            times += 1\n        if times >= k :\n            return best\n    return best\n", "DIRECTION_LAST_SQUARE_BLOCK": "def direction ( R , C ) :\n    if ( R != C and R % 2 == 0 and C % 2 != 0 and R < C ) :\n        print ( \"Left\" )\n        return\n    if ( R != C and R % 2 == 0 and C % 2 == 0 and R > C ) :\n        print ( \"Up\" )\n        return\n    if R == C and R % 2 != 0 and C % 2 != 0 :\n        print ( \"Right\" )\n        return\n    if R == C and R % 2 == 0 and C % 2 == 0 :\n        print ( \"Left\" )\n        return\n    if ( R != C and R % 2 != 0 and C % 2 != 0 and R < C ) :\n        print ( \"Right\" )\n        return\n    if ( R != C and R % 2 != 0 and C % 2 != 0 and R > C ) :\n        print ( \"Down\" )\n        return\n    if ( R != C and R % 2 == 0 and C % 2 != 0 and R < C ) :\n        print ( \"Left\" )\n        return\n    if ( R != C and R % 2 == 0 and C % 2 == 0 and R > C ) :\n        print ( \"Up\" )\n        return\n    if ( R != C and R % 2 != 0 and C % 2 != 0 and R > C ) :\n        print ( \"Down\" )\n        return\n    if ( R != C and R % 2 != 0 and C % 2 != 0 and R < C ) :\n        print ( \"Right\" )\n        return\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N": "def countIntegralSolutions ( n ) :\n    result = 0\n    for i in range ( n + 1 ) :\n        for j in range ( n + 1 ) :\n            for k in range ( n + 1 ) :\n                if i + j + k == n :\n                    result += 1\n    return result\n", "SWAP_MAJOR_MINOR_DIAGONALS_SQUARE_MATRIX": "def swapDiagonal ( matrix ) :\n    for i in range ( N ) :\n        matrix [ i ] [ i ] , matrix [ i ] [ N - i - 1 ] = \\\n            matrix [ i ] [ N - i - 1 ] , matrix [ i ] [ i ]\n", "MINIMUM_OPERATIONS_MAKE_GCD_ARRAY_MULTIPLE_K": "def MinOperation ( a , n , k ) :\n    result = 0\n    for i in range ( n ) :\n        if ( a [ i ] != 1 and a [ i ] > k ) :\n            result = ( result + min ( a [ i ] % k , k - a [ i ] % k ) )\n        else :\n            result = result + k - a [ i ]\n    return result\n", "MAXIMUM_DECIMAL_VALUE_PATH_IN_A_BINARY_MATRIX": "def maxDecimalValue ( mat , i , j , p ) :\n    if i >= N or j >= N :\n        return 0\n    result = max ( maxDecimalValue ( mat , i , j + 1 , p + 1 ) , maxDecimalValue ( mat , i + 1 , j , p + 1 ) )\n    if mat [ i ] [ j ] == 1 :\n        return pow ( 2 , p ) + result\n    else :\n        return result\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE_1": "def squareRoot ( n ) :\n    x = n ;\n    y = 1 ;\n    while ( x > y ) :\n        x = ( x + y ) / 2 ;\n        y = n / x ;\n    return x ;\n", "FIND_MINIMUM_SHIFT_LONGEST_COMMON_PREFIX": "def KMP ( m , n , str2 , str1 ) :\n    pos = 0\n    Len = 0\n    p = [ 0 for i in range ( m + 1 ) ]\n    k = 0\n    for i in range ( 2 , n + 1 ) :\n        while ( k > 0 and str1 [ k ] != str1 [ i - 1 ] ) :\n            k = p [ k ]\n        if ( str1 [ k ] == str1 [ i - 1 ] ) :\n            k += 1\n        p [ i ] = k\n    j = 0\n    for i in range ( m ) :\n        while ( j > 0 and j < n and str1 [ j ] != str2 [ i ] ) :\n            j = p [ j ]\n        if ( j < n and str1 [ j ] == str2 [ i ] ) :\n            j += 1\n        if ( j > Len ) :\n            Len = j\n            pos = i - j + 1\n    print ( \"Shift = \" , pos )\n    print ( \"Prefix = \" , str1 [ : Len ] )\n", "SORTED_ORDER_PRINTING_OF_AN_ARRAY_THAT_REPRESENTS_A_BST": "def printSorted ( arr , start , end ) :\n    if start > end :\n        return\n    printSorted ( arr , start * 2 + 1 , end )\n    print ( arr [ start ] , end = \" \" )\n    printSorted ( arr , start * 2 + 2 , end )\n", "CHECK_WHETHER_GIVEN_DEGREES_VERTICES_REPRESENT_GRAPH_TREE": "def check ( degree , n ) :\n    deg_sum = sum ( degree )\n    if ( 2 * ( n - 1 ) == deg_sum ) :\n        return True\n    else :\n        return False\n", "MOVE_ZEROES_END_ARRAY": "def pushZerosToEnd ( arr , n ) :\n    count = 0\n    for i in range ( n ) :\n        if arr [ i ] != 0 :\n            arr [ count ] = arr [ i ]\n            count += 1\n    while count < n :\n        arr [ count ] = 0\n        count += 1\n", "COUNT_ELEMENTS_WHICH_DIVIDE_ALL_NUMBERS_IN_RANGE_L_R": "def answerQuery ( a , n , l , r ) :\n    count = 0\n    l = l - 1\n    for i in range ( l , r , 1 ) :\n        element = a [ i ]\n        divisors = 0\n        for j in range ( l , r , 1 ) :\n            if ( a [ j ] % a [ i ] == 0 ) :\n                divisors += 1\n            else :\n                break\n        if ( divisors == ( r - l ) ) :\n            count += 1\n    return count\n", "SUM_LARGEST_PRIME_FACTOR_NUMBER_LESS_EQUAL_N": "def sumOfLargePrimeFactor ( n ) :\n    prime = [ 0 ] * ( n + 1 )\n    sum = 0\n    max = int ( n / 2 )\n    for p in range ( 2 , max + 1 ) :\n        if prime [ p ] == 0 :\n            for i in range ( p * 2 , n + 1 , p ) :\n                prime [ i ] = p\n    for p in range ( 2 , n + 1 ) :\n        if prime [ p ] :\n            sum += prime [ p ]\n        else :\n            sum += p\n    return sum\n", "REARRANGE_A_STRING_IN_SORTED_ORDER_FOLLOWED_BY_THE_INTEGER_SUM": "def arrangeString ( string ) :\n    char_count = [ 0 ] * MAX_CHAR\n    s = 0\n    for i in range ( len ( string ) ) :\n        if string [ i ] >= \"A\" and string [ i ] <= \"Z\" :\n            char_count [ ord ( string [ i ] ) - ord ( \"A\" ) ] += 1\n        else :\n            s += ord ( string [ i ] ) - ord ( \"0\" )\n    res = \"\"\n    for i in range ( MAX_CHAR ) :\n        ch = chr ( ord ( \"A\" ) + i )\n        while char_count [ i ] :\n            res += ch\n            char_count [ i ] -= 1\n    if s > 0 :\n        res += str ( s )\n    return res\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_1": "def numberOfPaths ( m , n ) :\n    count = [ [ 0 for x in range ( m ) ] for y in range ( n ) ]\n    for i in range ( m ) :\n        count [ i ] [ 0 ] = 1 ;\n    for j in range ( n ) :\n        count [ 0 ] [ j ] = 1 ;\n    for i in range ( 1 , m ) :\n        for j in range ( n ) :\n            count [ i ] [ j ] = count [ i - 1 ] [ j ] + count [ i ] [ j - 1 ]\n    return count [ m - 1 ] [ n - 1 ]\n", "DYNAMIC_PROGRAMMING_SET_5_EDIT_DISTANCE_1": "def editDistDP ( str1 , str2 , m , n ) :\n    dp = [ [ 0 for x in range ( n + 1 ) ] for x in range ( m + 1 ) ]\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            if i == 0 :\n                dp [ i ] [ j ] = j\n            elif j == 0 :\n                dp [ i ] [ j ] = i\n            elif str1 [ i - 1 ] == str2 [ j - 1 ] :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = 1 + min ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] , dp [ i - 1 ] [ j - 1 ] )\n    return dp [ m ] [ n ]\n", "FIND_NUMBER_OF_SOLUTIONS_OF_A_LINEAR_EQUATION_OF_N_VARIABLES": "def countSol ( coeff , start , end , rhs ) :\n    if ( rhs == 0 ) :\n        return 1\n    result = 0\n    for i in range ( start , end + 1 ) :\n        if ( coeff [ i ] <= rhs ) :\n            result += countSol ( coeff , i , end , rhs - coeff [ i ] )\n    return result\n", "SUM_ELEMENTS_K1TH_K2TH_SMALLEST_ELEMENTS_1": "def minheapify ( a , index ) :\n    small = index\n    l = 2 * index + 1\n    r = 2 * index + 2\n    if ( l < n and a [ l ] < a [ small ] ) :\n        small = l\n    if ( r < n and a [ r ] < a [ small ] ) :\n        small = r\n    if ( small != index ) :\n        ( a [ small ] , a [ index ] ) = ( a [ index ] , a [ small ] )\n        minheapify ( a , small )\n", "SEARCHING_FOR_PATTERNS_SET_2_KMP_ALGORITHM": "def computeLPSArray ( pat , M , lps ) :\n    len = 0\n    lps [ 0 ]\n    i = 1\n    while i < M :\n        if pat [ i ] == pat [ len ] :\n            len += 1\n            lps [ i ] = len\n            i += 1\n        else :\n            if len != 0 :\n                len = lps [ len - 1 ]\n            else :\n                lps [ i ] = 0\n                i += 1\n", "FIND_MINIMUM_DIFFERENCE_PAIR": "def findMinDiff ( arr , n ) :\n    diff = 10 ** 20\n    for i in range ( n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            if abs ( arr [ i ] - arr [ j ] ) < diff :\n                diff = abs ( arr [ i ] - arr [ j ] )\n    return diff\n", "PRINT_FIRST_K_DIGITS_1N_N_POSITIVE_INTEGER": "def Print ( n , k ) :\n    rem = 1\n    for i in range ( 0 , k ) :\n        print ( math.floor ( ( ( 10 * rem ) / n ) ) , end = \"\" )\n        rem = ( 10 * rem ) % n\n", "GROUP_MULTIPLE_OCCURRENCE_OF_ARRAY_ELEMENTS_ORDERED_BY_FIRST_OCCURRENCE": "def groupElements ( arr , n ) :\n    visited = [ False ] * n\n    for i in range ( 0 , n ) :\n        visited [ i ] = False\n    for i in range ( 0 , n ) :\n        if ( visited [ i ] == False ) :\n            print ( arr [ i ] , end = \" \" )\n            for j in range ( i + 1 , n ) :\n                if ( arr [ i ] == arr [ j ] ) :\n                    print ( arr [ i ] , end = \" \" )\n                    visited [ j ] = True\n", "CHECK_WHETHER_ARITHMETIC_PROGRESSION_CAN_FORMED_GIVEN_ARRAY": "def checkIsAP ( arr , n ) :\n    if ( n == 1 ) : return True\n    arr.sort ( )\n    d = arr [ 1 ] - arr [ 0 ]\n    for i in range ( 2 , n ) :\n        if ( arr [ i ] - arr [ i - 1 ] != d ) :\n            return False\n    return True\n", "NTH_MULTIPLE_NUMBER_FIBONACCI_SERIES": "def findPosition ( k , n ) :\n    f1 = 0\n    f2 = 1\n    i = 2 ;\n    while i != 0 :\n        f3 = f1 + f2 ;\n        f1 = f2 ;\n        f2 = f3 ;\n        if f2 % k == 0 :\n            return n * i\n        i += 1\n    return\n", "COUNT_PAIRS_DIFFERENCE_EQUAL_K_1": "def countPairsWithDiffK ( arr , n , k ) :\n    count = 0\n    arr.sort ( )\n    l = 0\n    r = 0\n    while r < n :\n        if arr [ r ] - arr [ l ] == k :\n            count += 1\n            l += 1\n            r += 1\n        elif arr [ r ] - arr [ l ] > k :\n            l += 1\n        else :\n            r += 1\n    return count\n", "ELEMENTS_TO_BE_ADDED_SO_THAT_ALL_ELEMENTS_OF_A_RANGE_ARE_PRESENT_IN_ARRAY": "def countNum ( arr , n ) :\n    count = 0\n    arr.sort ( )\n    for i in range ( 0 , n - 1 ) :\n        if ( arr [ i ] != arr [ i + 1 ] and arr [ i ] != arr [ i + 1 ] - 1 ) :\n            count += arr [ i + 1 ] - arr [ i ] - 1 ;\n    return count\n", "MAKE_LARGEST_PALINDROME_CHANGING_K_DIGITS": "def maximumPalinUsingKChanges ( strr , k ) :\n    palin = strr\n    l = 0\n    r = len ( strr ) - 1\n    while ( l <= r ) :\n        if ( strr [ l ] != strr [ r ] ) :\n            palin [ l ] = palin [ r ] = max ( strr [ l ] , strr [ r ] )\n            k -= 1\n        l += 1\n        r -= 1\n    if ( k < 0 ) :\n        return \"Not possible\"\n    l = 0\n    r = len ( strr ) - 1\n    while ( l <= r ) :\n        if ( l == r ) :\n            if ( k > 0 ) :\n                palin [ l ] = '9'\n        if ( palin [ l ] < '9' ) :\n            if ( k >= 2 and palin [ l ] == strr [ l ] and palin [ r ] == strr [ r ] ) :\n                k -= 1\n                palin [ l ] = palin [ r ] = '9'\n            elif ( k >= 1 and ( palin [ l ] != strr [ l ] or palin [ r ] != strr [ r ] ) ) :\n                k -= 1\n                palin [ l ] = palin [ r ] = '9'\n        l += 1\n        r -= 1\n    return palin\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM": "def subArray ( arr , n ) :\n    for i in range ( 0 , n ) :\n        for j in range ( i , n ) :\n            for k in range ( i , j + 1 ) :\n                print ( arr [ k ] , end = \"\" )\n            print ( \"\\n\" , end = \"\" )\n", "MAXIMUM_SUM_INCREASING_ORDER_ELEMENTS_N_ARRAYS": "def maximumSum ( a , n ) :\n    global M ;\n    for i in range ( 0 , n ) :\n        a [ i ].sort ( ) ;\n    sum = a [ n - 1 ] [ M - 1 ] ;\n    prev = a [ n - 1 ] [ M - 1 ] ;\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        for j in range ( M - 1 , - 1 , - 1 ) :\n            if ( a [ i ] [ j ] < prev ) :\n                prev = a [ i ] [ j ] ;\n                sum += prev ;\n                break ;\n        if ( j == - 1 ) :\n            return 0 ;\n    return sum ;\n", "C_PROGRAM_FACTORIAL_NUMBER": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 ) ;\n", "PRINT_SQUARES_FIRST_N_NATURAL_NUMBERS_WITHOUT_USING": "def printSquares ( n ) :\n    square = 0 ; prev_x = 0 ;\n    for x in range ( 0 , n ) :\n        square = ( square + x + prev_x )\n        print ( square , end = \" \" )\n        prev_x = x\n", "ROPES_DATA_STRUCTURE_FAST_STRING_CONCATENATION": "def concatenate ( a , b , c , n1 , n2 ) :\n    i = - 1\n    for i in range ( n1 ) :\n        c [ i ] = a [ i ]\n    for j in range ( n2 ) :\n        c [ i ] = b [ j ]\n        i += 1\n", "GIVEN_TWO_SORTED_ARRAYS_NUMBER_X_FIND_PAIR_WHOSE_SUM_CLOSEST_X": "def printClosest ( ar1 , ar2 , m , n , x ) :\n    diff = sys.maxsize\n    l = 0\n    r = n - 1\n    while ( l < m and r >= 0 ) :\n        if abs ( ar1 [ l ] + ar2 [ r ] - x ) < diff :\n            res_l = l\n            res_r = r\n            diff = abs ( ar1 [ l ] + ar2 [ r ] - x )\n        if ar1 [ l ] + ar2 [ r ] > x :\n            r = r - 1\n        else :\n            l = l + 1\n    print ( \"The closest pair is [\" , ar1 [ res_l ] , \",\" , ar2 [ res_r ] , \"]\" )\n", "CONVERT_STRICTLY_INCREASING_ARRAY_MINIMUM_CHANGES": "def minRemove ( arr , n ) :\n    LIS = [ 0 for i in range ( n ) ]\n    len = 0\n    for i in range ( n ) :\n        LIS [ i ] = 1\n    for i in range ( 1 , n ) :\n        for j in range ( i ) :\n            if ( arr [ i ] > arr [ j ] and ( i - j ) <= ( arr [ i ] - arr [ j ] ) ) :\n                LIS [ i ] = max ( LIS [ i ] , LIS [ j ] + 1 )\n        len = max ( len , LIS [ i ] )\n    return ( n - len )\n", "TAIL_RECURSION": "def fact ( n ) :\n    if ( n == 0 ) :\n        return 1\n    return n * fact ( n - 1 )\n", "RECURSIVE_FUNCTIONS": "def tower ( n , sourcePole , destinationPole , auxiliaryPole ) :\n    if ( 0 == n ) :\n        return\n    tower ( n - 1 , sourcePole , auxiliaryPole , destinationPole )\n    print ( \"Move the disk\" , sourcePole , \"from\" , sourcePole , \"to\" , destinationPole )\n    tower ( n - 1 , auxiliaryPole , destinationPole , sourcePole )\n", "FIND_X_Y_SATISFYING_AX_N": "def solution ( a , b , n ) :\n    i = 0\n    while i * a <= n :\n        if ( n - ( i * a ) ) % b == 0 :\n            print ( \"x = \" , i , \", y = \" , int ( ( n - ( i * a ) ) / b ) )\n            return 0\n        i = i + 1\n    print ( \"No solution\" )\n", "EXPONENTIAL_SQUARING_FAST_MODULO_MULTIPLICATION_1": "def exponentiation ( bas , exp ) :\n    t = 1 ;\n    while ( exp > 0 ) :\n        if ( exp % 2 != 0 ) :\n            t = ( t * bas ) % N ;\n        bas = ( bas * bas ) % N ;\n        exp = int ( exp / 2 ) ;\n    return t % N ;\n", "CHECK_OCCURRENCES_CHARACTER_APPEAR_TOGETHER": "def checkIfAllTogether ( s , c ) :\n    oneSeen = False\n    i = 0\n    n = len ( s )\n    while ( i < n ) :\n        if ( s [ i ] == c ) :\n            if ( oneSeen == True ) :\n                return False\n            while ( i < n and s [ i ] == c ) :\n                i = i + 1\n            oneSeen = True\n        else :\n            i = i + 1\n    return True\n", "MAXIMUM_AREA_RECTANGLE_PICKING_FOUR_SIDES_ARRAY": "def findArea ( arr , n ) :\n    arr.sort ( reverse = True )\n    dimension = [ 0 , 0 ]\n    i = 0\n    j = 0\n    while ( i < n - 1 and j < 2 ) :\n        if ( arr [ i ] == arr [ i + 1 ] ) :\n            dimension [ j ] = arr [ i ]\n            j += 1\n            i += 1\n        i += 1\n    return ( dimension [ 0 ] * dimension [ 1 ] )\n", "PYTHON_PROGRAM_FIND_PERIMETER_CIRCUMFERENCE_SQUARE_RECTANGLE": "def Circumference ( a ) :\n    return ( 4 * a )\n", "CYCLE_SORT": "def cycleSort ( array ) :\n    writes = 0\n    for cycleStart in range ( 0 , len ( array ) - 1 ) :\n        item = array [ cycleStart ]\n        pos = cycleStart\n        for i in range ( cycleStart + 1 , len ( array ) ) :\n            if array [ i ] < item :\n                pos += 1\n        if pos == cycleStart :\n            continue\n        while item == array [ pos ] :\n            pos += 1\n        array [ pos ] , item = item , array [ pos ]\n        writes += 1\n        while pos != cycleStart :\n            pos = cycleStart\n            for i in range ( cycleStart + 1 , len ( array ) ) :\n                if array [ i ] < item :\n                    pos += 1\n            while item == array [ pos ] :\n                pos += 1\n            array [ pos ] , item = item , array [ pos ]\n            writes += 1\n    return writes\n", "SELECT_A_RANDOM_NUMBER_FROM_STREAM_WITH_O1_SPACE": "def selectRandom ( x ) :\n    res = 0 ;\n    count = 0 ;\n    count += 1 ;\n    if ( count == 1 ) :\n        res = x ;\n    else :\n        i = random.randrange ( count ) ;\n        if ( i == count - 1 ) :\n            res = x ;\n    return res ;\n", "HOSOYAS_TRIANGLE": "def printHosoya ( n ) :\n    dp = [ [ 0 for i in range ( N ) ] for i in range ( N ) ]\n    dp [ 0 ] [ 0 ] = dp [ 1 ] [ 0 ] = dp [ 1 ] [ 1 ] = 1\n    for i in range ( 2 , n ) :\n        for j in range ( n ) :\n            if ( i > j ) :\n                dp [ i ] [ j ] = ( dp [ i - 1 ] [ j ] + dp [ i - 2 ] [ j ] )\n            else :\n                dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 2 ] [ j - 2 ] )\n    for i in range ( n ) :\n        for j in range ( i + 1 ) :\n            print ( dp [ i ] [ j ] , end = ' ' )\n        print ( )\n", "DISTRIBUTING_M_ITEMS_CIRCLE_SIZE_N_STARTING_K_TH_POSITION": "def lastPosition ( n , m , k ) :\n    if ( m <= n - k + 1 ) :\n        return m + k - 1\n    m = m - ( n - k + 1 )\n    if ( m % n == 0 ) :\n        return n\n    else :\n        return m % n\n", "PRINTING_LONGEST_INCREASING_CONSECUTIVE_SUBSEQUENCE": "def longestSubsequence ( a , n ) :\n    mp = { i : 0 for i in range ( 13 ) }\n    dp = [ 0 for i in range ( n ) ]\n    maximum = - sys.maxsize - 1\n    index = - 1\n    for i in range ( n ) :\n        if ( ( a [ i ] - 1 ) in mp ) :\n            lastIndex = mp [ a [ i ] - 1 ] - 1\n            dp [ i ] = 1 + dp [ lastIndex ]\n        else :\n            dp [ i ] = 1\n        mp [ a [ i ] ] = i + 1\n        if ( maximum < dp [ i ] ) :\n            maximum = dp [ i ]\n            index = i\n    for curr in range ( a [ index ] - maximum + 1 , a [ index ] + 1 , 1 ) :\n        print ( curr , end = \" \" )\n", "NUMBER_OF_TRIANGLES_IN_DIRECTED_AND_UNDIRECTED_GRAPHS": "def countTriangle ( g , isDirected ) :\n    nodes = len ( g )\n    count_Triangle = 0\n    for i in range ( nodes ) :\n        for j in range ( nodes ) :\n            for k in range ( nodes ) :\n                if ( i != j and i != k and j != k and g [ i ] [ j ] and g [ j ] [ k ] and g [ k ] [ i ] ) :\n                    count_Triangle += 1\n    return count_Triangle / 3 if isDirected else count_Triangle / 6\n", "CHECK_GIVEN_ARRAY_CONTAINS_DUPLICATE_ELEMENTS_WITHIN_K_DISTANCE": "def checkDuplicatesWithinK ( arr , n , k ) :\n    myset = [ ]\n    for i in range ( n ) :\n        if arr [ i ] in myset :\n            return True\n        myset.append ( arr [ i ] )\n        if ( i >= k ) :\n            myset.remove ( arr [ i - k ] )\n    return False\n", "MINIMUM_INSERTIONS_SORT_ARRAY": "def minInsertionStepToSortArray ( arr , N ) :\n    lis = [ 0 ] * N\n    for i in range ( N ) :\n        lis [ i ] = 1\n    for i in range ( 1 , N ) :\n        for j in range ( i ) :\n            if ( arr [ i ] >= arr [ j ] and lis [ i ] < lis [ j ] + 1 ) :\n                lis [ i ] = lis [ j ] + 1\n    max = 0\n    for i in range ( N ) :\n        if ( max < lis [ i ] ) :\n            max = lis [ i ]\n    return ( N - max )\n", "GENERATE_TWO_OUTPUT_STRINGS_DEPENDING_UPON_OCCURRENCE_CHARACTER_INPUT_STRING": "def printDuo ( string ) :\n    countChar = [ 0 for i in range ( MAX_CHAR ) ]\n    n = len ( string )\n    for i in range ( n ) :\n        countChar [ ord ( string [ i ] ) - ord ( 'a' ) ] += 1\n    str1 = \"\"\n    str2 = \"\"\n    for i in range ( MAX_CHAR ) :\n        if ( countChar [ i ] > 1 ) :\n            str2 = str2 + chr ( i + ord ( 'a' ) )\n        elif ( countChar [ i ] == 1 ) :\n            str1 = str1 + chr ( i + ord ( 'a' ) )\n    print ( \"String with characters occurring once:\" , \"\\n\" , str1 )\n    print ( \"String with characters occurring\" , \"multiple times:\" , \"\\n\" , str2 )\n", "NUMBER_DIGITS_PRODUCT_TWO_NUMBERS_1": "def countDigits ( a , b ) :\n    if ( a == 0 or b == 0 ) :\n        return 1\n    return math.floor ( math.log10 ( abs ( a ) ) + math.log10 ( abs ( b ) ) ) + 1\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS_1": "def countNonDecreasing ( n ) :\n    N = 10\n    count = 1\n    for i in range ( 1 , n + 1 ) :\n        count = int ( count * ( N + i - 1 ) )\n        count = int ( count / i )\n    return count\n", "COUNT_STRINGS_ADJACENT_CHARACTERS_DIFFERENCE_ONE": "def countStrs ( n ) :\n    dp = [ [ 0 for j in range ( 27 ) ] for i in range ( n + 1 ) ]\n    for i in range ( 0 , 26 ) :\n        dp [ 1 ] [ i ] = 1\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( 0 , 26 ) :\n            if ( j == 0 ) :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ] ;\n            else :\n                dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] )\n    sum = 0\n    for i in range ( 0 , 26 ) :\n        sum = sum + dp [ n ] [ i ]\n    return sum\n", "PROGRAM_TO_EFFICIENTLY_CALCULATE_EX": "def exponential ( n , x ) :\n    sum = 1.0\n    for i in range ( n , 0 , - 1 ) :\n        sum = 1 + x * sum / i\n    print ( \"e^x =\" , sum )\n", "EFFICIENTLY_COMPUTE_SUMS_OF_DIAGONALS_OF_A_MATRIX_1": "def printDiagonalSums ( mat , n ) :\n    principal = 0\n    secondary = 0\n    for i in range ( 0 , n ) :\n        principal += mat [ i ] [ i ]\n        secondary += mat [ i ] [ n - i - 1 ]\n    print ( \"Principal Diagonal:\" , principal )\n    print ( \"Secondary Diagonal:\" , secondary )\n", "PRINT_WAYS_BREAK_STRING_BRACKET_FORM": "def findCombinations ( string , index , out ) :\n    if index == len ( string ) :\n        print ( out )\n    for i in range ( index , len ( string ) , 1 ) :\n        findCombinations ( string , i + 1 , out + \"(\" + string [ index : i + 1 ] + \")\" )\n", "LINEAR_SEARCH": "def search ( arr , n , x ) :\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] == x ) :\n            return i ;\n    return - 1 ;\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_2": "def singleNumber ( nums ) :\n    return ( 3 * sum ( set ( nums ) ) - sum ( nums ) ) / 2\n", "SEARCH_ALMOST_SORTED_ARRAY": "def binarySearch ( arr , l , r , x ) :\n    if ( r >= l ) :\n        mid = int ( l + ( r - l ) / 2 )\n        if ( arr [ mid ] == x ) : return mid\n        if ( mid > l and arr [ mid - 1 ] == x ) :\n            return ( mid - 1 )\n        if ( mid < r and arr [ mid + 1 ] == x ) :\n            return ( mid + 1 )\n        if ( arr [ mid ] > x ) :\n            return binarySearch ( arr , l , mid - 2 , x )\n        return binarySearch ( arr , mid + 2 , r , x )\n    return - 1\n", "EULERS_TOTIENT_FUNCTION_FOR_ALL_NUMBERS_SMALLER_THAN_OR_EQUAL_TO_N": "def computeTotient ( n ) :\n    phi = [ ]\n    for i in range ( n + 2 ) :\n        phi.append ( 0 )\n    for i in range ( 1 , n + 1 ) :\n        phi [ i ] = i\n    for p in range ( 2 , n + 1 ) :\n        if ( phi [ p ] == p ) :\n            phi [ p ] = p - 1\n            for i in range ( 2 * p , n + 1 , p ) :\n                phi [ i ] = ( phi [ i ] // p ) * ( p - 1 )\n    for i in range ( 1 , n + 1 ) :\n        print ( \"Totient of \" , i , \" is \" , phi [ i ] )\n", "FIND_MINIMUM_NUMBER_DIVIDED_MAKE_NUMBER_PERFECT_SQUARE": "def findMinNumber ( n ) :\n    count = 0\n    ans = 1\n    while n % 2 == 0 :\n        count += 1\n        n //= 2\n    if count % 2 is not 0 :\n        ans *= 2\n    for i in range ( 3 , ( int ) ( math.sqrt ( n ) ) + 1 , 2 ) :\n        count = 0\n        while n % i == 0 :\n            count += 1\n            n //= i\n        if count % 2 is not 0 :\n            ans *= i\n    if n > 2 :\n        ans *= n\n    return ans\n", "COUNT_NUMBER_WAYS_JUMP_REACH_END": "def countWaysToJump ( arr , n ) :\n    count_jump = [ 0 for i in range ( n ) ]\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        if ( arr [ i ] >= n - i - 1 ) :\n            count_jump [ i ] += 1\n        j = i + 1\n        while ( j < n - 1 and j <= arr [ i ] + i ) :\n            if ( count_jump [ j ] != - 1 ) :\n                count_jump [ i ] += count_jump [ j ]\n            j += 1\n        if ( count_jump [ i ] == 0 ) :\n            count_jump [ i ] = - 1\n    for i in range ( n ) :\n        print ( count_jump [ i ] , end = \" \" )\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL_1": "def substringConversions ( str1 , k , b ) :\n    for i in range ( 0 , len ( str1 ) - k + 1 ) :\n        sub = str1 [ i : k + i ]\n        Sum = 0\n        counter = 0\n        for i in range ( len ( sub ) - 1 , - 1 , - 1 ) :\n            Sum = ( Sum + ( ( ord ( sub [ i ] ) - ord ( '0' ) ) * pow ( b , counter ) ) )\n            counter += 1\n        print ( Sum , end = \" \" )\n", "TWO_ELEMENTS_WHOSE_SUM_IS_CLOSEST_TO_ZERO": "def minAbsSumPair ( arr , arr_size ) :\n    inv_count = 0\n    if arr_size < 2 :\n        print ( \"Invalid Input\" )\n        return\n    min_l = 0\n    min_r = 1\n    min_sum = arr [ 0 ] + arr [ 1 ]\n    for l in range ( 0 , arr_size - 1 ) :\n        for r in range ( l + 1 , arr_size ) :\n            sum = arr [ l ] + arr [ r ]\n            if abs ( min_sum ) > abs ( sum ) :\n                min_sum = sum\n                min_l = l\n                min_r = r\n    print ( \"The two elements whose sum is minimum are\" , arr [ min_l ] , \"and \" , arr [ min_r ] )\n", "HOW_TO_PRINT_MAXIMUM_NUMBER_OF_A_USING_GIVEN_FOUR_KEYS": "def findoptimal ( N ) :\n    if ( N <= 6 ) :\n        return N\n    screen = [ 0 ] * N\n    for n in range ( 1 , 7 ) :\n        screen [ n - 1 ] = n\n    for n in range ( 7 , N + 1 ) :\n        screen [ n - 1 ] = max ( 2 * screen [ n - 4 ] , max ( 3 * screen [ n - 5 ] , 4 * screen [ n - 6 ] ) ) ;\n    return screen [ N - 1 ]\n", "PROGRAM_DECIMAL_BINARY_CONVERSION_2": "def decimalToBinary ( N ) :\n    B_Number = 0\n    cnt = 0\n    while ( N != 0 ) :\n        rem = N % 2\n        c = pow ( 10 , cnt )\n        B_Number += rem * c\n        N //= 2\n        cnt += 1\n    return B_Number\n", "COUNTS_PATHS_POINT_REACH_ORIGIN_1": "def countPaths ( n , m ) :\n    if ( n == 0 or m == 0 ) :\n        return 1\n    return ( countPaths ( n - 1 , m ) + countPaths ( n , m - 1 ) )\n", "SUM_ELEMENTS_K1TH_K2TH_SMALLEST_ELEMENTS": "def sumBetweenTwoKth ( arr , n , k1 , k2 ) :\n    arr.sort ( )\n    result = 0\n    for i in range ( k1 , k2 - 1 ) :\n        result += arr [ i ]\n    return result\n", "SMALLEST_SUBARRAY_K_DISTINCT_NUMBERS": "def minRange ( arr , n , k ) :\n    l = 0\n    r = n\n    for i in range ( n ) :\n        s = [ ]\n        for j in range ( i , n ) :\n            s.append ( arr [ j ] )\n            if ( len ( s ) == k ) :\n                if ( ( j - i ) < ( r - l ) ) :\n                    r = j\n                    l = i\n                break\n        if ( j == n ) :\n            break\n    if ( l == 0 and r == n ) :\n        print ( \"Invalid k\" )\n    else :\n        print ( l , r )\n", "AREA_OF_A_HEXAGON": "def hexagonArea ( s ) :\n    return ( ( 3 * math.sqrt ( 3 ) * ( s * s ) ) / 2 ) ;\n", "NEXT_POWER_OF_2_2": "def nextPowerOf2 ( n ) :\n    n -= 1\n    n |= n >> 1\n    n |= n >> 2\n    n |= n >> 4\n    n |= n >> 8\n    n |= n >> 16\n    n += 1\n    return n\n", "COUNT_SUBSTRINGS_BINARY_STRING_CONTAINING_K_ONES": "def countOfSubstringWithKOnes ( s , K ) :\n    N = len ( s )\n    res = 0\n    countOfOne = 0\n    freq = [ 0 for i in range ( N + 1 ) ]\n    freq [ 0 ] = 1\n    for i in range ( 0 , N , 1 ) :\n        countOfOne += ord ( s [ i ] ) - ord ( '0' )\n        if ( countOfOne >= K ) :\n            res += freq [ countOfOne - K ]\n        freq [ countOfOne ] += 1\n    return res\n", "NUMBER_INDEXES_EQUAL_ELEMENTS_GIVEN_RANGE": "def answer_query ( a , n , l , r ) :\n    count = 0\n    for i in range ( l , r ) :\n        if ( a [ i ] == a [ i + 1 ] ) :\n            count += 1\n    return count\n", "CHECK_WHETHER_NUMBER_DUCK_NUMBER_NOT": "def check_duck ( num ) :\n    l = len ( num )\n    count_zero = 0\n    i = 1\n    while i < l :\n        ch = num [ i ]\n        if ( ch == \"0\" ) :\n            count_zero = count_zero + 1\n        i = i + 1\n    return count_zero\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N_1": "def countIntegralSolutions ( n ) :\n    return int ( ( ( n + 1 ) * ( n + 2 ) ) / 2 )\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_K_TIMES_1": "def maxProfit ( price , n , k ) :\n    profit = [ [ 0 for i in range ( n + 1 ) ] for j in range ( k + 1 ) ]\n    for i in range ( 1 , k + 1 ) :\n        prevDiff = float ( '-inf' )\n        for j in range ( 1 , n ) :\n            prevDiff = max ( prevDiff , profit [ i - 1 ] [ j - 1 ] - price [ j - 1 ] )\n            profit [ i ] [ j ] = max ( profit [ i ] [ j - 1 ] , price [ j ] + prevDiff )\n    return profit [ k ] [ n - 1 ]\n", "COUNT_CHARACTERS_POSITION_ENGLISH_ALPHABETS": "def findCount ( str ) :\n    result = 0\n    for i in range ( len ( str ) ) :\n        if ( ( i == ord ( str [ i ] ) - ord ( 'a' ) ) or ( i == ord ( str [ i ] ) - ord ( 'A' ) ) ) :\n            result += 1\n    return result\n", "COUNT_GFG_SUBSEQUENCES_GIVEN_STRING": "def countSubsequence ( s , n ) :\n    cntG = 0\n    cntF = 0\n    result = 0\n    C = 0\n    for i in range ( n ) :\n        if ( s [ i ] == 'G' ) :\n            cntG += 1\n            result += C\n            continue\n        if ( s [ i ] == 'F' ) :\n            cntF += 1\n            C += cntG\n            continue\n        else :\n            continue\n    print ( result )\n", "FIND_SMALLEST_VALUE_REPRESENTED_SUM_SUBSET_GIVEN_ARRAY": "def findSmallest ( arr , n ) :\n    res = 1\n    for i in range ( 0 , n ) :\n        if arr [ i ] <= res :\n            res = res + arr [ i ]\n        else :\n            break\n    return res\n", "MAXIMUM_POINTS_COLLECTED_BY_TWO_PERSONS_ALLOWED_TO_MEET_ONCE": "def findMaxPoints ( A ) :\n    P1S = [ [ 0 for i in range ( N + 2 ) ] for j in range ( M + 2 ) ]\n    P1E = [ [ 0 for i in range ( N + 2 ) ] for j in range ( M + 2 ) ]\n    P2S = [ [ 0 for i in range ( N + 2 ) ] for j in range ( M + 2 ) ]\n    P2E = [ [ 0 for i in range ( N + 2 ) ] for j in range ( M + 2 ) ]\n    for i in range ( 1 , N + 1 ) :\n        for j in range ( 1 , M + 1 ) :\n            P1S [ i ] [ j ] = max ( P1S [ i - 1 ] [ j ] , P1S [ i ] [ j - 1 ] ) + A [ i - 1 ] [ j - 1 ]\n    for i in range ( N , 0 , - 1 ) :\n        for j in range ( M , 0 , - 1 ) :\n            P1E [ i ] [ j ] = max ( P1E [ i + 1 ] [ j ] , P1E [ i ] [ j + 1 ] ) + A [ i - 1 ] [ j - 1 ]\n    for i in range ( N , 0 , - 1 ) :\n        for j in range ( 1 , M + 1 ) :\n            P2S [ i ] [ j ] = max ( P2S [ i + 1 ] [ j ] , P2S [ i ] [ j - 1 ] ) + A [ i - 1 ] [ j - 1 ]\n    for i in range ( 1 , N + 1 ) :\n        for j in range ( M , 0 , - 1 ) :\n            P2E [ i ] [ j ] = max ( P2E [ i - 1 ] [ j ] , P2E [ i ] [ j + 1 ] ) + A [ i - 1 ] [ j - 1 ]\n    ans = 0\n    for i in range ( 2 , N ) :\n        for j in range ( 2 , M ) :\n            op1 = P1S [ i ] [ j - 1 ] + P1E [ i ] [ j + 1 ] + \\\n                P2S [ i + 1 ] [ j ] + P2E [ i - 1 ] [ j ]\n            op2 = P1S [ i - 1 ] [ j ] + P1E [ i + 1 ] [ j ] + \\\n                P2S [ i ] [ j - 1 ] + P2E [ i ] [ j + 1 ]\n            ans = max ( ans , max ( op1 , op2 ) )\n    return ans\n", "PROGRAM_FIND_CIRCUMFERENCE_CIRCLE": "def circumference ( r ) :\n    return ( 2 * PI * r )\n", "QUICKLY_FIND_MULTIPLE_LEFT_ROTATIONS_OF_AN_ARRAY": "def leftRotate ( arr , n , k ) :\n    for i in range ( k , k + n ) :\n        print ( str ( arr [ i % n ] ) , end = \" \" )\n", "MINIMUM_SUM_CHOOSING_MINIMUM_PAIRS_ARRAY": "def minSum ( A ) :\n    min_val = min ( A ) ;\n    return min_val * ( len ( A ) - 1 )\n", "RECURSIVE_PROGRAM_PRIME_NUMBER": "def isPrime ( n , i = 2 ) :\n    if ( n <= 2 ) :\n        return True if ( n == 2 ) else False\n    if ( n % i == 0 ) :\n        return False\n    if ( i * i > n ) :\n        return true\n    return isPrime ( n , i + 1 )\n", "SPARSE_SEARCH": "def sparseSearch ( arr , key , low , high ) :\n    left = 0 ; right = 0\n    while low <= high :\n        mid = ( low + high ) // 2\n        if arr [ mid ] == '' :\n            left = mid - 1\n            right = mid + 1\n            if left < low and right > high :\n                return - 1\n            elif right <= high and arr [ right ] != '' :\n                mid = right\n            elif left >= low and arr [ left ] != '' :\n                mid = left\n        if arr [ mid ] == key :\n            print ( 'Found string {} at index {}'.format ( arr [ mid ] , mid ) )\n            return\n        elif arr [ mid ] > key :\n            high = mid - 1\n        elif arr [ mid ] < key :\n            low = mid + 1\n        left -= 1\n        right += 1\n    return - 1\n", "FIND_NUMBER_TIMES_STRING_OCCURS_GIVEN_STRING": "def count ( a , b , m , n ) :\n    if ( ( m == 0 and n == 0 ) or n == 0 ) :\n        return 1\n    if ( m == 0 ) :\n        return 0\n    if ( a [ m - 1 ] == b [ n - 1 ] ) :\n        return ( count ( a , b , m - 1 , n - 1 ) + count ( a , b , m - 1 , n ) )\n    else :\n        return count ( a , b , m - 1 , n )\n", "PROGRAM_CHECK_ARRAY_SORTED_NOT_ITERATIVE_RECURSIVE_1": "def arraySortedOrNot ( arr , n ) :\n    if ( n == 0 or n == 1 ) :\n        return True\n    for i in range ( 1 , n ) :\n        if ( arr [ i - 1 ] > arr [ i ] ) :\n            return False\n    return True\n", "FIND_INDEX_0_REPLACED_1_GET_LONGEST_CONTINUOUS_SEQUENCE_1S_BINARY_ARRAY": "def maxOnesIndex ( arr , n ) :\n    max_count = 0\n    max_index = 0\n    prev_zero = - 1\n    prev_prev_zero = - 1\n    for curr in range ( n ) :\n        if ( arr [ curr ] == 0 ) :\n            if ( curr - prev_prev_zero > max_count ) :\n                max_count = curr - prev_prev_zero\n                max_index = prev_zero\n            prev_prev_zero = prev_zero\n            prev_zero = curr\n    if ( n - prev_prev_zero > max_count ) :\n        max_index = prev_zero\n    return max_index\n", "FIND_MAXIMUM_PRODUCT_OF_A_TRIPLET_IN_ARRAY_1": "def maxProduct ( arr , n ) :\n    if n < 3 :\n        return - 1\n    arr.sort ( )\n    return max ( arr [ 0 ] * arr [ 1 ] * arr [ n - 1 ] , arr [ n - 1 ] * arr [ n - 2 ] * arr [ n - 3 ] )\n", "COORDINATES_RECTANGLE_GIVEN_POINTS_LIE_INSIDE": "def printRect ( X , Y , n ) :\n    Xmax = max ( X )\n    Xmin = min ( X )\n    Ymax = max ( Y )\n    Ymin = min ( Y )\n    print ( \"{\" , Xmin , \", \" , Ymin , \"}\" , sep = \"\" )\n    print ( \"{\" , Xmin , \", \" , Ymax , \"}\" , sep = \"\" )\n    print ( \"{\" , Xmax , \", \" , Ymax , \"}\" , sep = \"\" )\n    print ( \"{\" , Xmax , \", \" , Ymin , \"}\" , sep = \"\" )\n", "COUNT_BINARY_DIGIT_NUMBERS_SMALLER_N": "def countOfBinaryNumberLessThanN ( N ) :\n    q = deque ( )\n    q.append ( 1 )\n    cnt = 0\n    while ( q ) :\n        t = q.popleft ( )\n        if ( t <= N ) :\n            cnt = cnt + 1\n            q.append ( t * 10 )\n            q.append ( t * 10 + 1 )\n    return cnt\n", "CONVERT_DECIMAL_FRACTION_BINARY_NUMBER": "def decimalToBinary ( num , k_prec ) :\n    binary = \"\"\n    Integral = int ( num )\n    fractional = num - Integral\n    while ( Integral ) :\n        rem = Integral % 2\n        binary += str ( rem ) ;\n        Integral //= 2\n    binary = binary [ : : - 1 ]\n    binary += '.'\n    while ( k_prec ) :\n        fractional *= 2\n        fract_bit = int ( fractional )\n        if ( fract_bit == 1 ) :\n            fractional -= fract_bit\n            binary += '1'\n        else :\n            binary += '0'\n        k_prec -= 1\n    return binary\n", "MAXIMUM_NUMBER_OF_TRAILING_ZEROS_IN_THE_PRODUCT_OF_THE_SUBSETS_OF_SIZE_K": "def maximumZeros ( arr , n , k ) :\n    global MAX5\n    subset = [ [ - 1 ] * ( MAX5 + 5 ) for _ in range ( k + 1 ) ]\n    subset [ 0 ] [ 0 ] = 0\n    for p in arr :\n        pw2 , pw5 = 0 , 0\n        while not p % 2 :\n            pw2 += 1\n            p //= 2\n        while not p % 5 :\n            pw5 += 1\n            p //= 5\n        for i in range ( k - 1 , - 1 , - 1 ) :\n            for j in range ( MAX5 ) :\n                if subset [ i ] [ j ] != - 1 :\n                    subset [ i + 1 ] [ j + pw5 ] = ( max ( subset [ i + 1 ] [ j + pw5 ] , ( subset [ i ] [ j ] + pw2 ) ) )\n    ans = 0\n    for i in range ( MAX5 ) :\n        ans = max ( ans , min ( i , subset [ k ] [ i ] ) )\n    return ans\n", "SEARCH_AN_ELEMENT_IN_A_SORTED_AND_PIVOTED_ARRAY": "def search ( arr , l , h , key ) :\n    if l > h :\n        return - 1\n    mid = ( l + h ) // 2\n    if arr [ mid ] == key :\n        return mid\n    if arr [ l ] <= arr [ mid ] :\n        if key >= arr [ l ] and key <= arr [ mid ] :\n            return search ( arr , l , mid - 1 , key )\n        return search ( arr , mid + 1 , h , key )\n    if key >= arr [ mid ] and key <= arr [ h ] :\n        return search ( a , mid + 1 , h , key )\n    return search ( arr , l , mid - 1 , key )\n", "PROGRAM_FIND_AREA_CIRCULAR_SEGMENT": "def area_of_segment ( radius , angle ) :\n    area_of_sector = pi *\n        ( radius * radius )\n        * ( angle / 360 )\n    area_of_triangle = 1 / 2 *\n        ( radius * radius ) *\n        math.sin ( ( angle * pi ) / 180 )\n    return area_of_sector - area_of_triangle ;\n", "K_SMALLEST_ELEMENTS_ORDER_USING_O1_EXTRA_SPACE": "def printSmall ( arr , n , k ) :\n    for i in range ( k , n ) :\n        max_var = arr [ k - 1 ]\n        pos = k - 1\n        for j in range ( k - 2 , - 1 , - 1 ) :\n            if ( arr [ j ] > max_var ) :\n                max_var = arr [ j ]\n                pos = j\n        if ( max_var > arr [ i ] ) :\n            j = pos\n            while ( j < k - 1 ) :\n                arr [ j ] = arr [ j + 1 ]\n                j += 1\n            arr [ k - 1 ] = arr [ i ]\n    for i in range ( 0 , k ) :\n        print ( arr [ i ] , end = \" \" )\n", "NTH_NON_FIBONACCI_NUMBER": "def nonFibonacci ( n ) :\n    prevPrev = 1\n    prev = 2\n    curr = 3\n    while n > 0 :\n        prevPrev = prev\n        prev = curr\n        curr = prevPrev + prev\n        n = n - ( curr - prev - 1 )\n    n = n + ( curr - prev - 1 )\n    return prev + n\n", "ANALYSIS_OF_ALGORITHMS_SET_2_ASYMPTOTIC_ANALYSIS": "def search ( arr , n , x ) :\n    i = 0\n    for i in range ( i , n ) :\n        if ( arr [ i ] == x ) :\n            return i\n    return - 1\n", "ZECKENDORFS_THEOREM_NON_NEIGHBOURING_FIBONACCI_REPRESENTATION": "def nearestSmallerEqFib ( n ) :\n    if ( n == 0 or n == 1 ) :\n        return n\n    f1 , f2 , f3 = 0 , 1 , 1\n    while ( f3 <= n ) :\n        f1 = f2 ;\n        f2 = f3 ;\n        f3 = f1 + f2 ;\n    return f2 ;\n", "PRINT_MAXIMUM_SHORTEST_DISTANCE": "def find_maximum ( a , n , k ) :\n    b = dict ( )\n    for i in range ( n ) :\n        x = a [ i ]\n        d = min ( 1 + i , n - i )\n        if x not in b.keys ( ) :\n            b [ x ] = d\n        else :\n            b [ x ] = min ( d , b [ x ] )\n    ans = 10 ** 9\n    for i in range ( n ) :\n        x = a [ i ]\n        if ( x != ( k - x ) and ( k - x ) in b.keys ( ) ) :\n            ans = min ( max ( b [ x ] , b [ k - x ] ) , ans )\n    return ans\n", "GENERATING_DISTINCT_SUBSEQUENCES_OF_A_GIVEN_STRING_IN_LEXICOGRAPHIC_ORDER": "def generate ( st , s ) :\n    if len ( s ) == 0 :\n        return\n    if s not in st :\n        st.add ( s )\n        for i in range ( len ( s ) ) :\n            t = list ( s ).copy ( )\n            t.remove ( s [ i ] )\n            t = ''.join ( t )\n            generate ( st , t )\n    return\n", "WRITE_YOU_OWN_POWER_WITHOUT_USING_MULTIPLICATION_AND_DIVISION": "def pow ( a , b ) :\n    if ( b == 0 ) :\n        return 1\n    answer = a\n    increment = a\n    for i in range ( 1 , b ) :\n        for j in range ( 1 , a ) :\n            answer += increment\n        increment = answer\n    return answer\n", "MAXIMIZE_VOLUME_CUBOID_GIVEN_SUM_SIDES_1": "def maxvolume ( s ) :\n    length = int ( s / 3 )\n    s -= length\n    breadth = s / 2\n    height = s - breadth\n    return int ( length * breadth * height )\n", "HORNERS_METHOD_POLYNOMIAL_EVALUATION": "def horner ( poly , n , x ) :\n    result = poly [ 0 ]\n    for i in range ( 1 , n ) :\n        result = result * x + poly [ i ]\n    return result\n", "MINIMUM_TIME_REQUIRED_PRODUCE_M_ITEMS": "def minTime ( arr , n , m ) :\n    t = 0\n    while ( 1 ) :\n        items = 0\n        for i in range ( n ) :\n            items += ( t // arr [ i ] )\n        if ( items >= m ) :\n            return t\n        t += 1\n", "FIND_DIFFERENCE_BETWEEN_SUMS_OF_TWO_DIAGONALS": "def difference ( arr , n ) :\n    d1 = 0\n    d2 = 0\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            if ( i == j ) :\n                d1 += arr [ i ] [ j ]\n            if ( i == n - j - 1 ) :\n                d2 += arr [ i ] [ j ]\n    return abs ( d1 - d2 ) ;\n", "SHORTEST_UNCOMMON_SUBSEQUENCE": "def shortestSeq ( S : list , T : list ) :\n    m = len ( S )\n    n = len ( T )\n    dp = [ [ 0 for i in range ( n + 1 ) ] for j in range ( m + 1 ) ]\n    for i in range ( m + 1 ) :\n        dp [ i ] [ 0 ] = 1\n    for i in range ( n + 1 ) :\n        dp [ 0 ] [ i ] = MAX\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            ch = S [ i - 1 ]\n            k = j - 1\n            while k >= 0 :\n                if T [ k ] == ch :\n                    break\n                k -= 1\n            if k == - 1 :\n                dp [ i ] [ j ] = 1\n            else :\n                dp [ i ] [ j ] = min ( dp [ i - 1 ] [ j ] , dp [ i - 1 ] [ k ] + 1 )\n    ans = dp [ m ] [ n ]\n    if ans >= MAX :\n        ans = - 1\n    return ans\n", "MIN_FLIPS_OF_CONTINUOUS_CHARACTERS_TO_MAKE_ALL_CHARACTERS_SAME_IN_A_STRING": "def findFlips ( str , n ) :\n    last = ' '\n    res = 0\n    for i in range ( n ) :\n        if ( last != str [ i ] ) :\n            res += 1\n        last = str [ i ]\n    return res // 2\n", "DYNAMIC_PROGRAMMING_SET_28_MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME": "def findMinInsertions ( str , l , h ) :\n    if ( l > h ) :\n        return sys.maxsize\n    if ( l == h ) :\n        return 0\n    if ( l == h - 1 ) :\n        return 0 if ( str [ l ] == str [ h ] ) else 1\n    if ( str [ l ] == str [ h ] ) :\n        return findMinInsertions ( str , l + 1 , h - 1 )\n    else :\n        return ( min ( findMinInsertions ( str , l , h - 1 ) , findMinInsertions ( str , l + 1 , h ) ) + 1 )\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS": "def countPairs ( str1 ) :\n    result = 0 ;\n    n = len ( str1 )\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if ( abs ( ord ( str1 [ i ] ) - ord ( str1 [ j ] ) ) == abs ( i - j ) ) :\n                result += 1 ;\n    return result ;\n", "MULTISTAGE_GRAPH_SHORTEST_PATH": "def shortestDist ( graph ) :\n    global INF\n    dist = [ 0 ] * N\n    dist [ N - 1 ] = 0\n    for i in range ( N - 2 , - 1 , - 1 ) :\n        dist [ i ] = INF\n        for j in range ( N ) :\n            if graph [ i ] [ j ] == INF :\n                continue\n            dist [ i ] = min ( dist [ i ] , graph [ i ] [ j ] + dist [ j ] )\n    return dist [ 0 ]\n", "MAXIMUM_SIZE_SUB_MATRIX_WITH_ALL_1S_IN_A_BINARY_MATRIX": "def printMaxSubSquare ( M ) :\n    R = len ( M )\n    C = len ( M [ 0 ] )\n    S = [ [ 0 for k in range ( C ) ] for l in range ( R ) ]\n    for i in range ( 1 , R ) :\n        for j in range ( 1 , C ) :\n            if ( M [ i ] [ j ] == 1 ) :\n                S [ i ] [ j ] = min ( S [ i ] [ j - 1 ] , S [ i - 1 ] [ j ] , S [ i - 1 ] [ j - 1 ] ) + 1\n            else :\n                S [ i ] [ j ] = 0\n    max_of_s = S [ 0 ] [ 0 ]\n    max_i = 0\n    max_j = 0\n    for i in range ( R ) :\n        for j in range ( C ) :\n            if ( max_of_s < S [ i ] [ j ] ) :\n                max_of_s = S [ i ] [ j ]\n                max_i = i\n                max_j = j\n    print ( \"Maximum size sub-matrix is: \" )\n    for i in range ( max_i , max_i - max_of_s , - 1 ) :\n        for j in range ( max_j , max_j - max_of_s , - 1 ) :\n            print ( M [ i ] [ j ] , end = \"\" )\n        print ( \"\" )\n", "GIVEN_SORTED_ARRAY_NUMBER_X_FIND_PAIR_ARRAY_WHOSE_SUM_CLOSEST_X": "def printClosest ( arr , n , x ) :\n    res_l , res_r = 0 , 0\n    l , r , diff = 0 , n - 1 , MAX_VAL\n    while r > l :\n        if abs ( arr [ l ] + arr [ r ] - x ) < diff :\n            res_l = l\n            res_r = r\n            diff = abs ( arr [ l ] + arr [ r ] - x )\n        if arr [ l ] + arr [ r ] > x :\n            r -= 1\n        else :\n            l += 1\n    print ( 'The closest pair is {} and {}'.format ( arr [ res_l ] , arr [ res_r ] ) )\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS_1": "def sortedAfterSwap ( A , B , n ) :\n    for i in range ( 0 , n - 1 ) :\n        if B [ i ] :\n            if A [ i ] != i + 1 :\n                A [ i ] , A [ i + 1 ] = A [ i + 1 ] , A [ i ]\n    for i in range ( n ) :\n        if A [ i ] != i + 1 :\n            return False\n    return True\n", "TILE_STACKING_PROBLEM": "def possibleWays ( n , m , k ) :\n    dp = [ [ 0 for i in range ( 10 ) ] for j in range ( 10 ) ]\n    presum = [ [ 0 for i in range ( 10 ) ] for j in range ( 10 ) ]\n    for i in range ( 1 , n + 1 ) :\n        dp [ 0 ] [ i ] = 0\n        presum [ 0 ] [ i ] = 1\n    for i in range ( 0 , m + 1 ) :\n        presum [ i ] [ 0 ] = 1\n        dp [ i ] [ 0 ] = 1\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            dp [ i ] [ j ] = presum [ i - 1 ] [ j ]\n            if j > k :\n                dp [ i ] [ j ] -= presum [ i - 1 ] [ j - k - 1 ]\n        for j in range ( 1 , n + 1 ) :\n            presum [ i ] [ j ] = dp [ i ] [ j ] + presum [ i ] [ j - 1 ]\n    return dp [ m ] [ n ]\n", "NUMBER_OF_PAIRS_IN_AN_ARRAY_HAVING_SUM_EQUAL_TO_PRODUCT": "def sumEqualProduct ( a , n ) :\n    zero = 0\n    two = 0\n    for i in range ( n ) :\n        if a [ i ] == 0 :\n            zero += 1\n        if a [ i ] == 2 :\n            two += 1\n    cnt = ( zero * ( zero - 1 ) ) // 2 + \\\n        ( two * ( two - 1 ) ) // 2\n    return cnt\n", "DYNAMIC_PROGRAMMING_SET_17_PALINDROME_PARTITIONING": "def minPalPartion ( str ) :\n    n = len ( str )\n    C = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    P = [ [ False for i in range ( n ) ] for i in range ( n ) ]\n    j = 0\n    k = 0\n    L = 0\n    for i in range ( n ) :\n        P [ i ] [ i ] = True ;\n        C [ i ] [ i ] = 0 ;\n    for L in range ( 2 , n + 1 ) :\n        for i in range ( n - L + 1 ) :\n            j = i + L - 1\n            if L == 2 :\n                P [ i ] [ j ] = ( str [ i ] == str [ j ] )\n            else :\n                P [ i ] [ j ] = ( ( str [ i ] == str [ j ] ) and P [ i + 1 ] [ j - 1 ] )\n            if P [ i ] [ j ] == True :\n                C [ i ] [ j ] = 0\n            else :\n                C [ i ] [ j ] = 100000000\n                for k in range ( i , j ) :\n                    C [ i ] [ j ] = min ( C [ i ] [ j ] , C [ i ] [ k ] + C [ k + 1 ] [ j ] + 1 )\n    return C [ 0 ] [ n - 1 ]\n", "FIND_ONE_MULTIPLE_REPEATING_ELEMENTS_READ_ARRAY": "def findRepeatingNumber ( arr , n ) :\n    sq = sqrt ( n )\n    range__ = int ( ( n / sq ) + 1 )\n    count = [ 0 for i in range ( range__ ) ]\n    for i in range ( 0 , n + 1 , 1 ) :\n        count [ int ( ( arr [ i ] - 1 ) / sq ) ] += 1\n    selected_block = range__ - 1\n    for i in range ( 0 , range__ - 1 , 1 ) :\n        if ( count [ i ] > sq ) :\n            selected_block = i\n            break\n    m = { i : 0 for i in range ( n ) }\n    for i in range ( 0 , n + 1 , 1 ) :\n        if ( ( ( selected_block * sq ) < arr [ i ] ) and ( arr [ i ] <= ( ( selected_block + 1 ) * sq ) ) ) :\n            m [ arr [ i ] ] += 1\n            if ( m [ arr [ i ] ] > 1 ) :\n                return arr [ i ]\n    return - 1\n", "MINIMUM_SUM_PATH_TRIANGLE": "def minSumPath ( A ) :\n    memo = [ None ] * len ( A )\n    n = len ( A ) - 1\n    for i in range ( len ( A [ n ] ) ) :\n        memo [ i ] = A [ n ] [ i ]\n    for i in range ( len ( A ) - 2 , - 1 , - 1 ) :\n        for j in range ( len ( A [ i ] ) ) :\n            memo [ j ] = A [ i ] [ j ] + min ( memo [ j ] , memo [ j + 1 ] ) ;\n    return memo [ 0 ]\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT_1": "def getSum ( n ) :\n    sum = 0\n    while ( n > 0 ) :\n        sum += int ( n % 10 )\n        n = int ( n / 10 )\n    return sum\n", "RECURSION": "def printFun ( test ) :\n    if ( test < 1 ) :\n        return\n    else :\n        print ( test , end = \" \" )\n        printFun ( test - 1 )\n        print ( test , end = \" \" )\n        return\n", "MAXIMUM_TRIPLET_SUM_ARRAY": "def maxTripletSum ( arr , n ) :\n    sm = - 1000000\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            for k in range ( j + 1 , n ) :\n                if ( sm < ( arr [ i ] + arr [ j ] + arr [ k ] ) ) :\n                    sm = arr [ i ] + arr [ j ] + arr [ k ]\n    return sm\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY_1": "def minJumps ( arr , n ) :\n    jumps = [ 0 for i in range ( n ) ]\n    if ( n == 0 ) or ( arr [ 0 ] == 0 ) :\n        return float ( 'inf' )\n    jumps [ 0 ] = 0\n    for i in range ( 1 , n ) :\n        jumps [ i ] = float ( 'inf' )\n        for j in range ( i ) :\n            if ( i <= j + arr [ j ] ) and ( jumps [ j ] != float ( 'inf' ) ) :\n                jumps [ i ] = min ( jumps [ i ] , jumps [ j ] + 1 )\n                break\n    return jumps [ n - 1 ]\n", "MAXIMIZE_ARRAY_ELEMENTS_UPTO_GIVEN_NUMBER": "def findMaxVal ( arr , n , num , maxLimit ) :\n    ind = - 1 ;\n    val = - 1 ;\n    dp = [ [ 0 for i in range ( maxLimit + 1 ) ] for j in range ( n ) ] ;\n    for ind in range ( n ) :\n        for val in range ( maxLimit + 1 ) :\n            if ( ind == 0 ) :\n                if ( num - arr [ ind ] == val or num + arr [ ind ] == val ) :\n                    dp [ ind ] [ val ] = 1 ;\n                else :\n                    dp [ ind ] [ val ] = 0 ;\n            else :\n                if ( val - arr [ ind ] >= 0 and val + arr [ ind ] <= maxLimit ) :\n                    if ( dp [ ind - 1 ] [ val - arr [ ind ] ] == 1 or dp [ ind - 1 ] [ val + arr [ ind ] ] == 1 ) :\n                        dp [ ind ] [ val ] = 1 ;\n                elif ( val - arr [ ind ] >= 0 ) :\n                    dp [ ind ] [ val ] = dp [ ind - 1 ] [ val - arr [ ind ] ] ;\n                elif ( val + arr [ ind ] <= maxLimit ) :\n                    dp [ ind ] [ val ] = dp [ ind - 1 ] [ val + arr [ ind ] ] ;\n                else :\n                    dp [ ind ] [ val ] = 0 ;\n    for val in range ( maxLimit , - 1 , - 1 ) :\n        if ( dp [ n - 1 ] [ val ] == 1 ) :\n            return val ;\n    return - 1 ;\n", "PROGRAM_FOR_DEADLOCK_FREE_CONDITION_IN_OPERATING_SYSTEM": "def Resources ( process , need ) :\n    minResources = 0\n    minResources = process * ( need - 1 ) + 1\n    return minResources\n", "NUMBER_DIGITS_PRODUCT_TWO_NUMBERS": "def countDigits ( a , b ) :\n    count = 0\n    p = abs ( a * b )\n    if ( p == 0 ) :\n        return 1\n    while ( p > 0 ) :\n        count = count + 1\n        p = p // 10\n    return count\n", "FLOOR_IN_A_SORTED_ARRAY": "def floorSearch ( arr , low , high , x ) :\n    if ( low > high ) :\n        return - 1\n    if ( x >= arr [ high ] ) :\n        return high\n    mid = int ( ( low + high ) / 2 )\n    if ( arr [ mid ] == x ) :\n        return mid\n    if ( mid > 0 and arr [ mid - 1 ] <= x and x < arr [ mid ] ) :\n        return mid - 1\n    if ( x < arr [ mid ] ) :\n        return floorSearch ( arr , low , mid - 1 , x )\n    return floorSearch ( arr , mid + 1 , high , x )\n", "CHECK_WHETHER_TRIANGLE_VALID_NOT_SIDES_GIVEN": "def checkValidity ( a , b , c ) :\n    if ( a + b <= c ) or ( a + c <= b ) or ( b + c <= a ) :\n        return False\n    else :\n        return True\n", "PRINT_N_X_N_SPIRAL_MATRIX_USING_O1_EXTRA_SPACE": "def printSpiral ( n ) :\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            x = min ( min ( i , j ) , min ( n - 1 - i , n - 1 - j ) )\n            if ( i <= j ) :\n                print ( ( n - 2 * x ) * ( n - 2 * x ) - ( i - x ) - ( j - x ) , end = \"\\t\" )\n            else :\n                print ( ( ( n - 2 * x - 2 ) * ( n - 2 * x - 2 ) + ( i - x ) + ( j - x ) ) , end = \"\\t\" )\n        print ( )\n", "POSITION_ELEMENT_STABLE_SORT": "def getIndexInSortedArray ( arr , n , idx ) :\n    result = 0\n    for i in range ( n ) :\n        if ( arr [ i ] < arr [ idx ] ) :\n            result += 1\n        if ( arr [ i ] == arr [ idx ] and i < idx ) :\n            result += 1\n    return result ;\n", "MAXIMUM_SEGMENT_VALUE_PUTTING_K_BREAKPOINTS_NUMBER": "def findMaxSegment ( s , k ) :\n    seg_len = len ( s ) - k\n    res = 0\n    for i in range ( seg_len ) :\n        res = res * 10 + ( ord ( s [ i ] ) - ord ( '0' ) )\n    seg_len_pow = pow ( 10 , seg_len - 1 )\n    curr_val = res\n    for i in range ( 1 , len ( s ) - seg_len ) :\n        curr_val = curr_val - ( ord ( s [ i - 1 ] ) - ord ( '0' ) ) * seg_len_pow\n        curr_val = ( curr_val * 10 + ( ord ( s [ i + seg_len - 1 ] ) - ord ( '0' ) ) )\n        res = max ( res , curr_val )\n    return res\n", "FINDING_POWER_PRIME_NUMBER_P_N_1": "def PowerOFPINnfactorial ( n , p ) :\n    ans = 0\n    temp = p\n    while ( temp <= n ) :\n        ans += n / temp\n        temp = temp * p\n    return int ( ans )\n", "PROGRAM_PRINT_IDENTITY_MATRIX": "def Identity ( size ) :\n    for row in range ( 0 , size ) :\n        for col in range ( 0 , size ) :\n            if ( row == col ) :\n                print ( \"1 \" , end = \" \" )\n            else :\n                print ( \"0 \" , end = \" \" )\n        print ( )\n", "SUM_MATRIX_ELEMENT_ELEMENT_INTEGER_DIVISION_ROW_COLUMN": "def findSum ( N ) :\n    ans = 0\n    for i in range ( 1 , N + 1 ) :\n        for j in range ( 1 , N + 1 ) :\n            ans += i // j\n    return ans\n", "TILING_WITH_DOMINOES": "def countWays ( n ) :\n    A = [ 0 ] * ( n + 1 )\n    B = [ 0 ] * ( n + 1 )\n    A [ 0 ] = 1\n    A [ 1 ] = 0\n    B [ 0 ] = 0\n    B [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        A [ i ] = A [ i - 2 ] + 2 * B [ i - 1 ]\n        B [ i ] = A [ i - 1 ] + B [ i - 2 ]\n    return A [ n ]\n", "COUNT_DERANGEMENTS_PERMUTATION_SUCH_THAT_NO_ELEMENT_APPEARS_IN_ITS_ORIGINAL_POSITION": "def countDer ( n ) :\n    if ( n == 1 ) : return 0\n    if ( n == 0 ) : return 1\n    if ( n == 2 ) : return 1\n    return ( n - 1 ) * ( countDer ( n - 1 ) + countDer ( n - 2 ) )\n", "FREQUENCY_ELEMENT_UNSORTED_ARRAY_1": "def countFreq ( a , n ) :\n    hm = dict ( )\n    for i in range ( n ) :\n        hm [ a [ i ] ] = hm.get ( a [ i ] , 0 ) + 1\n    cumul = 0\n    for i in range ( n ) :\n        cumul += hm [ a [ i ] ]\n        if ( hm [ a [ i ] ] > 0 ) :\n            print ( a [ i ] , \"->\" , cumul )\n        hm [ a [ i ] ] = 0\n", "MINIMIZE_THE_SUM_OF_DIGITS_OF_A_AND_B_SUCH_THAT_A_B_N": "def minSum ( n ) :\n    sum = 0 ;\n    while ( n > 0 ) :\n        sum += ( n % 10 ) ;\n        n //= 10 ;\n    if ( sum == 1 ) :\n        return 10 ;\n    return sum ;\n", "DIVIDE_CUBOID_CUBES_SUM_VOLUMES_MAXIMUM": "def maximizecube ( l , b , h ) :\n    side = gcd ( l , gcd ( b , h ) )\n    num = int ( l / side )\n    num = int ( num * b / side )\n    num = int ( num * h / side )\n    print ( side , num )\n", "CHECK_NUMBER_POWER_K_USING_BASE_CHANGING_METHOD": "def isPowerOfK ( n , k ) :\n    oneSeen = False\n    while ( n > 0 ) :\n        digit = n % k\n        if ( digit > 1 ) :\n            return False\n        if ( digit == 1 ) :\n            if ( oneSeen ) :\n                return False\n            oneSeen = True\n        n //= k\n    return True\n", "POSITION_OF_RIGHTMOST_SET_BIT_1": "def PositionRightmostSetbit ( n ) :\n    position = 1\n    m = 1\n    while ( not ( n & m ) ) :\n        m = m << 1\n        position += 1\n    return position\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY_1": "def insertSorted ( arr , n , key , capacity ) :\n    if ( n >= capacity ) :\n        return n\n    i = n - 1\n    while i >= 0 and arr [ i ] > key :\n        arr [ i + 1 ] = arr [ i ]\n        i -= 1\n    arr [ i + 1 ] = key\n    return ( n + 1 )\n", "FIND_THE_MAXIMUM_OF_MINIMUMS_FOR_EVERY_WINDOW_SIZE_IN_A_GIVEN_ARRAY_1": "def printMaxOfMin ( arr , n ) :\n    s = [ ]\n    left = [ - 1 ] * ( n + 1 )\n    right = [ n ] * ( n + 1 )\n    for i in range ( n ) :\n        while ( len ( s ) != 0 and arr [ s [ - 1 ] ] >= arr [ i ] ) :\n            s.pop ( )\n        if ( len ( s ) != 0 ) :\n            left [ i ] = s [ - 1 ]\n        s.append ( i )\n    while ( len ( s ) != 0 ) :\n        s.pop ( )\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        while ( len ( s ) != 0 and arr [ s [ - 1 ] ] >= arr [ i ] ) :\n            s.pop ( )\n        if ( len ( s ) != 0 ) :\n            right [ i ] = s [ - 1 ]\n        s.append ( i )\n    ans = [ 0 ] * ( n + 1 )\n    for i in range ( n + 1 ) :\n        ans [ i ] = 0\n    for i in range ( n ) :\n        Len = right [ i ] - left [ i ] - 1\n        ans [ Len ] = max ( ans [ Len ] , arr [ i ] )\n    for i in range ( n - 1 , 0 , - 1 ) :\n        ans [ i ] = max ( ans [ i ] , ans [ i + 1 ] )\n    for i in range ( 1 , n + 1 ) :\n        print ( ans [ i ] , end = \" \" )\n", "MAXIMUM_DECIMAL_VALUE_PATH_IN_A_BINARY_MATRIX_1": "def MaximumDecimalValue ( mat , n ) :\n    dp = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    if ( mat [ 0 ] [ 0 ] == 1 ) :\n        dp [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , n ) :\n        if ( mat [ 0 ] [ i ] == 1 ) :\n            dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ] + 2 ** i\n        else :\n            dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ]\n    for i in range ( 1 , n ) :\n        if ( mat [ i ] [ 0 ] == 1 ) :\n            dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ] + 2 ** i\n    else :\n        dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ]\n    for i in range ( 1 , n ) :\n        for j in range ( 1 , n ) :\n            if ( mat [ i ] [ j ] == 1 ) :\n                dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] ) + ( 2 ** ( i + j ) )\n            else :\n                dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] )\n    return dp [ n - 1 ] [ n - 1 ]\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE": "def printCountRec ( dist ) :\n    if dist < 0 :\n        return 0\n    if dist == 0 :\n        return 1\n    return ( printCountRec ( dist - 1 ) + printCountRec ( dist - 2 ) + printCountRec ( dist - 3 ) )\n", "MOVE_VE_ELEMENTS_END_ORDER_EXTRA_SPACE_ALLOWED": "def segregateElements ( arr , n ) :\n    temp = [ 0 for k in range ( n ) ]\n    j = 0\n    for i in range ( n ) :\n        if ( arr [ i ] >= 0 ) :\n            temp [ j ] = arr [ i ]\n            j += 1\n    if ( j == n or j == 0 ) :\n        return\n    for i in range ( n ) :\n        if ( arr [ i ] < 0 ) :\n            temp [ j ] = arr [ i ]\n            j += 1\n    for k in range ( n ) :\n        arr [ k ] = temp [ k ]\n", "MINIMUM_PERIMETER_N_BLOCKS": "def minPerimeter ( n ) :\n    l = math.sqrt ( n )\n    sq = l * l\n    if ( sq == n ) :\n        return l * 4\n    else :\n        row = n / l\n        perimeter = 2 * ( l + row )\n        if ( n % l != 0 ) :\n            perimeter += 2\n        return perimeter\n", "DYNAMIC_PROGRAMMING_SET_36_CUT_A_ROPE_TO_MAXIMIZE_PRODUCT": "def maxProd ( n ) :\n    if ( n == 0 or n == 1 ) :\n        return 0\n    max_val = 0\n    for i in range ( 1 , n - 1 ) :\n        max_val = max ( max_val , max ( i * ( n - i ) , maxProd ( n - i ) * i ) )\n    return max_val ;\n", "LONGEST_COMMON_SUBSTRING_SPACE_OPTIMIZED_DP_SOLUTION": "def LCSubStr ( X , Y ) :\n    m = len ( X )\n    n = len ( Y )\n    result = 0\n    len_mat = np.zeros ( ( 2 , n ) )\n    currRow = 0\n    for i in range ( m ) :\n        for j in range ( n ) :\n            if ( i == 0 | j == 0 ) :\n                len_mat [ currRow ] [ j ] = 0\n            elif ( X [ i - 1 ] == Y [ j - 1 ] ) :\n                len_mat [ currRow ] [ j ] = len_mat [ 1 - currRow ] [ j - 1 ] + 1\n                result = max ( result , len_mat [ currRow ] [ j ] )\n            else :\n                len_mat [ currRow ] [ j ] = 0\n        currRow = 1 - currRow\n    return result\n", "CHECK_GIVEN_STRING_ROTATION_PALINDROME": "def isPalindrome ( string ) :\n    l = 0\n    h = len ( string ) - 1\n    while h > l :\n        l += 1\n        h -= 1\n        if string [ l - 1 ] != string [ h + 1 ] :\n            return False\n    return True\n", "FIND_NUMBER_OF_SOLUTIONS_OF_A_LINEAR_EQUATION_OF_N_VARIABLES_1": "def countSol ( coeff , n , rhs ) :\n    dp = [ 0 for i in range ( rhs + 1 ) ]\n    dp [ 0 ] = 1\n    for i in range ( n ) :\n        for j in range ( coeff [ i ] , rhs + 1 ) :\n            dp [ j ] += dp [ j - coeff [ i ] ]\n    return dp [ rhs ]\n", "FIND_THE_LARGEST_PAIR_SUM_IN_AN_UNSORTED_ARRAY": "def findLargestSumPair ( arr , n ) :\n    if arr [ 0 ] > arr [ 1 ] :\n        first = arr [ 0 ]\n        second = arr [ 1 ]\n    else :\n        first = arr [ 1 ]\n        second = arr [ 0 ]\n    for i in range ( 2 , n ) :\n        if arr [ i ] > first :\n            second = first\n            first = arr [ i ]\n        elif arr [ i ] > second and arr [ i ] != first :\n            second = arr [ i ]\n    return ( first + second )\n", "FIND_BITONIC_POINT_GIVEN_BITONIC_SEQUENCE": "def binarySearch ( arr , left , right ) :\n    if ( left <= right ) :\n        mid = ( left + right ) // 2 ;\n        if ( arr [ mid - 1 ] < arr [ mid ] and arr [ mid ] > arr [ mid + 1 ] ) :\n            return mid ;\n        if ( arr [ mid ] < arr [ mid + 1 ] ) :\n            return binarySearch ( arr , mid + 1 , right ) ;\n        else :\n            return binarySearch ( arr , left , mid - 1 ) ;\n    return - 1 ;\n", "PRINT_ALL_DISTINCT_CHARACTERS_OF_A_STRING_IN_ORDER_3_METHODS_1": "def printDistinct ( Str ) :\n    n = len ( Str )\n    count = [ 0 for i in range ( MAX_CHAR ) ]\n    index = [ n for i in range ( MAX_CHAR ) ]\n    for i in range ( n ) :\n        x = ord ( Str [ i ] )\n        count [ x ] += 1\n        if ( count [ x ] == 1 and x != ' ' ) :\n            index [ x ] = i\n        if ( count [ x ] == 2 ) :\n            index [ x ] = n\n    index = sorted ( index )\n    for i in range ( MAX_CHAR ) :\n        if index [ i ] == n :\n            break\n        print ( Str [ index [ i ] ] , end = \"\" )\n", "FIND_TWO_SIDES_RIGHT_ANGLE_TRIANGLE": "def printOtherSides ( n ) :\n    if ( n & 1 ) :\n        if ( n == 1 ) :\n            print ( - 1 )\n        else :\n            b = ( n * n - 1 ) // 2\n            c = ( n * n + 1 ) // 2\n            print ( \"b =\" , b , \", c =\" , c )\n    else :\n        if ( n == 2 ) :\n            print ( - 1 )\n        else :\n            b = n * n // 4 - 1\n            c = n * n // 4 + 1\n            print ( \"b =\" , b \", c =\" , c )\n", "COUNT_NUMBER_OF_STRINGS_MADE_OF_R_G_AND_B_USING_GIVEN_COMBINATION": "def possibleStrings ( n , r , b , g ) :\n    fact = [ 0 for i in range ( n + 1 ) ]\n    fact [ 0 ] = 1\n    for i in range ( 1 , n + 1 , 1 ) :\n        fact [ i ] = fact [ i - 1 ] * i\n    left = n - ( r + g + b )\n    sum = 0\n    for i in range ( 0 , left + 1 , 1 ) :\n        for j in range ( 0 , left - i + 1 , 1 ) :\n            k = left - ( i + j )\n            sum = ( sum + fact [ n ] / ( fact [ i + r ] * fact [ j + b ] * fact [ k + g ] ) )\n    return sum\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM_SET_2_O1_EXTRA_SPACE_1": "def rearrange ( arr , n ) :\n    max_ele = arr [ n - 1 ]\n    min_ele = arr [ 0 ]\n    for i in range ( n ) :\n        if i % 2 == 0 :\n            arr [ i ] = max_ele\n            max_ele -= 1\n        else :\n            arr [ i ] = min_ele\n            min_ele += 1\n", "EVALUATE_AN_ARRAY_EXPRESSION_WITH_NUMBERS_AND": "def calculateSum ( arr , n ) :\n    if ( n == 0 ) :\n        return 0\n    s = arr [ 0 ]\n    value = int ( s )\n    sum = value\n    for i in range ( 2 , n , 2 ) :\n        s = arr [ i ]\n        value = int ( s )\n        operation = arr [ i - 1 ] [ 0 ]\n        if ( operation == '+' ) :\n            sum += value\n        else :\n            sum -= value\n    return sum\n", "SUM_MATRIX_ELEMENT_ELEMENT_INTEGER_DIVISION_ROW_COLUMN_1": "def findSum ( n ) :\n    ans = 0 ; temp = 0 ;\n    for i in range ( 1 , n + 1 ) :\n        if temp < n :\n            temp = i - 1\n            num = 1\n            while temp < n :\n                if temp + i <= n :\n                    ans += i * num\n                else :\n                    ans += ( n - temp ) * num\n                temp += i\n                num += 1\n    return ans\n", "SHUFFLE_A_DECK_OF_CARDS_3": "def shuffle ( card , n ) :\n    for i in range ( n ) :\n        r = i + ( random.randint ( 0 , 55 ) % ( 52 - i ) )\n        tmp = card [ i ]\n        card [ i ] = card [ r ]\n        card [ r ] = tmp\n", "DOOLITTLE_ALGORITHM_LU_DECOMPOSITION": "def luDecomposition ( mat , n ) :\n    lower = [ [ 0 for x in range ( n ) ] for y in range ( n ) ] ;\n    upper = [ [ 0 for x in range ( n ) ] for y in range ( n ) ] ;\n    for i in range ( n ) :\n        for k in range ( i , n ) :\n            sum = 0 ;\n            for j in range ( i ) :\n                sum += ( lower [ i ] [ j ] * upper [ j ] [ k ] ) ;\n            upper [ i ] [ k ] = mat [ i ] [ k ] - sum ;\n        for k in range ( i , n ) :\n            if ( i == k ) :\n                lower [ i ] [ i ] = 1 ;\n            else :\n                sum = 0 ;\n                for j in range ( i ) :\n                    sum += ( lower [ k ] [ j ] * upper [ j ] [ i ] ) ;\n                lower [ k ] [ i ] = int ( ( mat [ k ] [ i ] - sum ) / upper [ i ] [ i ] ) ;\n    print ( \"Lower Triangular\\t\\tUpper Triangular\" ) ;\n    for i in range ( n ) :\n        for j in range ( n ) :\n            print ( lower [ i ] [ j ] , end = \"\\t\" ) ;\n        print ( \"\" , end = \"\\t\" ) ;\n        for j in range ( n ) :\n            print ( upper [ i ] [ j ] , end = \"\\t\" ) ;\n        print ( \"\" ) ;\n", "PROGRAM_NTH_CATALAN_NUMBER": "def catalan ( n ) :\n    if n <= 1 :\n        return 1\n    res = 0\n    for i in range ( n ) :\n        res += catalan ( i ) * catalan ( n - i - 1 )\n    return res\n", "NUMBER_DIGITS_REMOVED_MAKE_NUMBER_DIVISIBLE_3": "def divisible ( num ) :\n    n = len ( num ) ;\n    sum = 0 ;\n    for i in range ( n ) :\n        sum += int ( num [ i ] ) ;\n    if ( sum % 3 == 0 ) :\n        return 0 ;\n    if ( n == 1 ) :\n        return - 1 ;\n    for i in range ( n ) :\n        if ( sum % 3 == int ( num [ i ] ) % 3 ) :\n            return 1 ;\n    if ( n == 2 ) :\n        return - 1 ;\n    return 2 ;\n", "CHECK_IF_A_NUMBER_IS_POWER_OF_ANOTHER_NUMBER_1": "def isPower ( x , y ) :\n    res1 = math.log ( y ) / math.log ( x ) ;\n    res2 = math.log ( y ) / math.log ( x ) ;\n    return 1 if ( res1 == res2 ) else 0 ;\n", "LARGEST_SUBSEQUENCE_GCD_GREATER_1": "def largestGCDSubsequence ( arr , n ) :\n    ans = 0\n    maxele = max ( arr )\n    for i in range ( 2 , maxele + 1 ) :\n        count = 0\n        for j in range ( n ) :\n            if ( arr [ j ] % i == 0 ) :\n                count += 1\n        ans = max ( ans , count )\n    return ans\n", "FIND_COMMON_ELEMENT_ROWS_ROW_WISE_SORTED_MATRIX": "def findCommon ( mat ) :\n    column = [ N - 1 ] * M\n    min_row = 0\n    while ( column [ min_row ] >= 0 ) :\n        for i in range ( M ) :\n            if ( mat [ i ] [ column [ i ] ] < mat [ min_row ] [ column [ min_row ] ] ) :\n                min_row = i\n        eq_count = 0\n        for i in range ( M ) :\n            if ( mat [ i ] [ column [ i ] ] > mat [ min_row ] [ column [ min_row ] ] ) :\n                if ( column [ i ] == 0 ) :\n                    return - 1\n                column [ i ] -= 1\n            else :\n                eq_count += 1\n        if ( eq_count == M ) :\n            return mat [ min_row ] [ column [ min_row ] ]\n    return - 1\n", "CHECK_GIVEN_CIRCLE_LIES_COMPLETELY_INSIDE_RING_FORMED_TWO_CONCENTRIC_CIRCLES": "def checkcircle ( r , R , r1 , x1 , y1 ) :\n    dis = int ( math.sqrt ( x1 * x1 + y1 * y1 ) )\n    return ( dis - r1 >= R and dis + r1 <= r )\n", "COUNT_TOTAL_SET_BITS_IN_ALL_NUMBERS_FROM_1_TO_N": "def countSetBits ( n ) :\n    i = 0\n    ans = 0\n    while ( ( 1 << i ) <= n ) :\n        k = 0\n        change = 1 << i\n        for j in range ( 0 , n + 1 ) :\n            ans += k\n            if change == 1 :\n                k = not k\n                change = 1 << i\n            else :\n                change -= 1\n        i += 1\n    return ans\n", "LONGEST_REPEATING_SUBSEQUENCE": "def findLongestRepeatingSubSeq ( str ) :\n    n = len ( str )\n    dp = [ [ 0 ] * ( n + 1 ) ] * ( n + 1 )\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if ( str [ i - 1 ] == str [ j - 1 ] and i != j ) :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] )\n    return dp [ n ] [ n ]\n", "FIND_THE_FIRST_MISSING_NUMBER": "def findFirstMissing ( array , start , end ) :\n    if ( start > end ) :\n        return end + 1\n    if ( start != array [ start ] ) :\n        return start ;\n    mid = int ( ( start + end ) / 2 )\n    if ( array [ mid ] == mid ) :\n        return findFirstMissing ( array , mid + 1 , end )\n    return findFirstMissing ( array , start , mid )\n", "SORT_ARRAY_CONVERTING_ELEMENTS_SQUARES_1": "def sortSquares ( arr , n ) :\n    K = 0\n    for K in range ( n ) :\n        if ( arr [ K ] >= 0 ) :\n            break\n    i = K - 1\n    j = K\n    ind = 0\n    temp = [ 0 ] * n\n    while ( i >= 0 and j < n ) :\n        if ( arr [ i ] * arr [ i ] < arr [ j ] * arr [ j ] ) :\n            temp [ ind ] = arr [ i ] * arr [ i ]\n            i -= 1\n        else :\n            temp [ ind ] = arr [ j ] * arr [ j ]\n            j += 1\n        ind += 1\n    while ( i >= 0 ) :\n        temp [ ind ] = arr [ i ] * arr [ i ]\n        i -= 1\n        ind += 1\n    while ( j < n ) :\n        temp [ ind ] = arr [ j ] * arr [ j ]\n        j += 1\n        ind += 1\n    for i in range ( n ) :\n        arr [ i ] = temp [ i ]\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR": "def getRemainder ( num , divisor ) :\n    return ( num - divisor * ( num // divisor ) )\n", "MINIMUM_COST_TO_FILL_GIVEN_WEIGHT_IN_A_BAG": "def MinimumCost ( cost , n , W ) :\n    val = list ( )\n    wt = list ( )\n    size = 0\n    for i in range ( n ) :\n        if ( cost [ i ] != - 1 ) :\n            val.append ( cost [ i ] )\n            wt.append ( i + 1 )\n            size += 1\n    n = size\n    min_cost = [ [ 0 for i in range ( W + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( W + 1 ) :\n        min_cost [ 0 ] [ i ] = INF\n    for i in range ( 1 , n + 1 ) :\n        min_cost [ i ] [ 0 ] = 0\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , W + 1 ) :\n            if ( wt [ i - 1 ] > j ) :\n                min_cost [ i ] [ j ] = min_cost [ i - 1 ] [ j ]\n            else :\n                min_cost [ i ] [ j ] = min ( min_cost [ i - 1 ] [ j ] , min_cost [ i ] [ j - wt [ i - 1 ] ] + val [ i - 1 ] )\n    if ( min_cost [ n ] [ W ] == INF ) :\n        return - 1\n    else :\n        return min_cost [ n ] [ W ]\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS_1": "def countPairs ( str1 ) :\n    result = 0 ;\n    n = len ( str1 )\n    for i in range ( 0 , n ) :\n        for j in range ( 1 , MAX_CHAR + 1 ) :\n            if ( ( i + j ) < n ) :\n                if ( ( abs ( ord ( str1 [ i + j ] ) - ord ( str1 [ i ] ) ) == j ) ) :\n                    result += 1 ;\n    return result\n", "A_PRODUCT_ARRAY_PUZZLE": "def productArray ( arr , n ) :\n    if ( n == 1 ) :\n        print ( 0 )\n        return\n    left = [ 0 ] * n\n    right = [ 0 ] * n\n    prod = [ 0 ] * n\n    left [ 0 ] = 1\n    right [ n - 1 ] = 1\n    for i in range ( 1 , n ) :\n        left [ i ] = arr [ i - 1 ] * left [ i - 1 ]\n    for j in range ( n - 2 , - 1 , - 1 ) :\n        right [ j ] = arr [ j + 1 ] * right [ j + 1 ]\n    for i in range ( n ) :\n        prod [ i ] = left [ i ] * right [ i ]\n    for i in range ( n ) :\n        print ( prod [ i ] , end = ' ' )\n", "FREQUENT_ELEMENT_ARRAY_1": "def mostFrequent ( arr , n ) :\n    Hash = dict ( )\n    for i in range ( n ) :\n        if arr [ i ] in Hash.keys ( ) :\n            Hash [ arr [ i ] ] += 1\n        else :\n            Hash [ arr [ i ] ] = 1\n    max_count = 0\n    res = - 1\n    for i in Hash :\n        if ( max_count < Hash [ i ] ) :\n            res = i\n            max_count = Hash [ i ]\n    return res\n", "PRINT_UNIQUE_ROWS": "def printArray ( matrix ) :\n    rowCount = len ( matrix )\n    if rowCount == 0 :\n        return\n    columnCount = len ( matrix [ 0 ] )\n    if columnCount == 0 :\n        return\n    row_output_format = \" \".join ( [ \"%s\" ] * columnCount )\n    printed = { }\n    for row in matrix :\n        routput = row_output_format % tuple ( row )\n        if routput not in printed :\n            printed [ routput ] = True\n            print ( routput )\n", "COUNT_1S_SORTED_BINARY_ARRAY": "def countOnes ( arr , low , high ) :\n    if high >= low :\n        mid = low + ( high - low ) / 2\n        if ( ( mid == high or arr [ mid + 1 ] == 0 ) and ( arr [ mid ] == 1 ) ) :\n            return mid + 1\n        if arr [ mid ] == 1 :\n            return countOnes ( arr , ( mid + 1 ) , high )\n        return countOnes ( arr , low , mid - 1 )\n    return 0\n", "POSSIBLE_MOVES_KNIGHT": "def findPossibleMoves ( mat , p , q ) :\n    global n , m ;\n    X = [ 2 , 1 , - 1 , - 2 , - 2 , - 1 , 1 , 2 ] ;\n    Y = [ 1 , 2 , 2 , 1 , - 1 , - 2 , - 2 , - 1 ] ;\n    count = 0 ;\n    for i in range ( 8 ) :\n        x = p + X [ i ] ;\n        y = q + Y [ i ] ;\n        if ( x >= 0 and y >= 0 and x < n and y < m and mat [ x ] [ y ] == 0 ) :\n            count += 1 ;\n    return count ;\n", "ROTATE_MATRIX_ELEMENTS": "def rotateMatrix ( mat ) :\n    if not len ( mat ) :\n        return\n    top = 0\n    bottom = len ( mat ) - 1\n    left = 0\n    right = len ( mat [ 0 ] ) - 1\n    while left < right and top < bottom :\n        prev = mat [ top + 1 ] [ left ]\n        for i in range ( left , right + 1 ) :\n            curr = mat [ top ] [ i ]\n            mat [ top ] [ i ] = prev\n            prev = curr\n        top += 1\n        for i in range ( top , bottom + 1 ) :\n            curr = mat [ i ] [ right ]\n            mat [ i ] [ right ] = prev\n            prev = curr\n        right -= 1\n        for i in range ( right , left - 1 , - 1 ) :\n            curr = mat [ bottom ] [ i ]\n            mat [ bottom ] [ i ] = prev\n            prev = curr\n        bottom -= 1\n        for i in range ( bottom , top - 1 , - 1 ) :\n            curr = mat [ i ] [ left ]\n            mat [ i ] [ left ] = prev\n            prev = curr\n        left += 1\n    return mat\n", "FIND_KTH_CHARACTER_OF_DECRYPTED_STRING": "def encodedChar ( str , k ) :\n    expand = \"\"\n    freq = 0\n    i = 0\n    while ( i < len ( str ) ) :\n        temp = \"\"\n        freq = 0\n        while ( i < len ( str ) and ord ( str [ i ] ) >= ord ( 'a' ) and ord ( str [ i ] ) <= ord ( 'z' ) ) :\n            temp += str [ i ]\n            i += 1\n        while ( i < len ( str ) and ord ( str [ i ] ) >= ord ( '1' ) and ord ( str [ i ] ) <= ord ( '9' ) ) :\n            freq = freq * 10 + ord ( str [ i ] ) - ord ( '0' )\n            i += 1\n        for j in range ( 1 , freq + 1 , 1 ) :\n            expand += temp\n    if ( freq == 0 ) :\n        expand += temp\n    return expand [ k - 1 ]\n", "EFFICIENT_SEARCH_IN_AN_ARRAY_WHERE_DIFFERENCE_BETWEEN_ADJACENT_IS_1": "def search ( arr , n , x ) :\n    i = 0\n    while ( i <= n - 1 ) :\n        if ( arr [ i ] == x ) :\n            return i\n        i += abs ( arr [ i ] - x )\n    return - 1\n", "MAXIMUM_POSSIBLE_SUM_WINDOW_ARRAY_ELEMENTS_WINDOW_ARRAY_UNIQUE": "def returnMaxSum ( A , B , n ) :\n    mp = set ( )\n    result = 0\n    curr_sum = curr_begin = 0\n    for i in range ( 0 , n ) :\n        while A [ i ] in mp :\n            mp.remove ( A [ curr_begin ] )\n            curr_sum -= B [ curr_begin ]\n            curr_begin += 1\n        mp.add ( A [ i ] )\n        curr_sum += B [ i ]\n        result = max ( result , curr_sum )\n    return result\n", "WRITE_AN_EFFICIENT_METHOD_TO_CHECK_IF_A_NUMBER_IS_MULTIPLE_OF_3": "def isMultipleOf3 ( n ) :\n    odd_count = 0\n    even_count = 0\n    if ( n < 0 ) :\n        n = - n\n    if ( n == 0 ) :\n        return 1\n    if ( n == 1 ) :\n        return 0\n    while ( n ) :\n        if ( n & 1 ) :\n            odd_count += 1\n        if ( n & 2 ) :\n            even_count += 1\n        n = n >> 2\n    return isMultipleOf3 ( abs ( odd_count - even_count ) )\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY_1": "def maxSum ( arr , n ) :\n    cum_sum = 0\n    for i in range ( 0 , n ) :\n        cum_sum += arr [ i ]\n    curr_val = 0\n    for i in range ( 0 , n ) :\n        curr_val += i * arr [ i ]\n    res = curr_val\n    for i in range ( 1 , n ) :\n        next_val = ( curr_val - ( cum_sum - arr [ i - 1 ] ) + arr [ i - 1 ] * ( n - 1 ) )\n        curr_val = next_val\n        res = max ( res , next_val )\n    return res\n", "DYNAMIC_PROGRAMMING_SET_34_ASSEMBLY_LINE_SCHEDULING": "def carAssembly ( a , t , e , x ) :\n    NUM_STATION = len ( a [ 0 ] )\n    T1 = [ 0 for i in range ( NUM_STATION ) ]\n    T2 = [ 0 for i in range ( NUM_STATION ) ]\n    T1 [ 0 ] = e [ 0 ] + a [ 0 ] [ 0 ]\n    T2 [ 0 ] = e [ 1 ] + a [ 1 ] [ 0 ]\n    for i in range ( 1 , NUM_STATION ) :\n        T1 [ i ] = min ( T1 [ i - 1 ] + a [ 0 ] [ i ] , T2 [ i - 1 ] + t [ 1 ] [ i ] + a [ 0 ] [ i ] )\n        T2 [ i ] = min ( T2 [ i - 1 ] + a [ 1 ] [ i ] , T1 [ i - 1 ] + t [ 0 ] [ i ] + a [ 1 ] [ i ] )\n    return min ( T1 [ NUM_STATION - 1 ] + x [ 0 ] , T2 [ NUM_STATION - 1 ] + x [ 1 ] )\n", "PRINT_MATRIX_SPIRAL_FORM_STARTING_POINT": "def printSpiral ( mat , r , c ) :\n    a = 0\n    b = 2\n    low_row = 0 if ( 0 > a ) else a\n    low_column = 0 if ( 0 > b ) else b - 1\n    high_row = r - 1 if ( ( a + 1 ) >= r ) else a + 1\n    high_column = c - 1 if ( ( b + 1 ) >= c ) else b + 1\n    while ( ( low_row > 0 - r and low_column > 0 - c ) ) :\n        i = low_column + 1\n        while ( i <= high_column and i < c and low_row >= 0 ) :\n            print ( mat [ low_row ] [ i ] , end = \" \" )\n            i += 1\n        low_row -= 1\n        i = low_row + 2\n        while ( i <= high_row and i < r and high_column < c ) :\n            print ( mat [ i ] [ high_column ] , end = \" \" )\n            i += 1\n        high_column += 1\n        i = high_column - 2\n        while ( i >= low_column and i >= 0 and high_row < r ) :\n            print ( mat [ high_row ] [ i ] , end = \" \" )\n            i -= 1\n        high_row += 1\n        i = high_row - 2\n        while ( i > low_row and i >= 0 and low_column >= 0 ) :\n            print ( mat [ i ] [ low_column ] , end = \" \" )\n            i -= 1\n        low_column -= 1\n    print ( )\n", "MID_POINT_CIRCLE_DRAWING_ALGORITHM": "def midPointCircleDraw ( x_centre , y_centre , r ) :\n    x = r\n    y = 0\n    print ( \"(\" , x + x_centre , \", \" , y + y_centre , \")\" , sep = \"\" , end = \"\" )\n    if ( r > 0 ) :\n        print ( \"(\" , x + x_centre , \", \" , - y + y_centre , \")\" , sep = \"\" , end = \"\" )\n        print ( \"(\" , y + x_centre , \", \" , x + y_centre , \")\" , sep = \"\" , end = \"\" )\n        print ( \"(\" , - y + x_centre , \", \" , x + y_centre , \")\" , sep = \"\" )\n    P = 1 - r\n    while ( x > y ) :\n        y += 1\n        if ( P <= 0 ) :\n            P = P + 2 * y + 1\n        else :\n            x -= 1\n            P = P + 2 * y - 2 * x + 1\n        if ( x < y ) :\n            break\n        print ( \"(\" , x + x_centre , \", \" , y + y_centre , \")\" , sep = \"\" , end = \"\" )\n        print ( \"(\" , - x + x_centre , \", \" , y + y_centre , \")\" , sep = \"\" , end = \"\" )\n        print ( \"(\" , x + x_centre , \", \" , - y + y_centre , \")\" , sep = \"\" , end = \"\" )\n        print ( \"(\" , - x + x_centre , \", \" , - y + y_centre , \")\" , sep = \"\" )\n        if ( x != y ) :\n            print ( \"(\" , y + x_centre , \", \" , x + y_centre , \")\" , sep = \"\" , end = \"\" )\n            print ( \"(\" , - y + x_centre , \", \" , x + y_centre , \")\" , sep = \"\" , end = \"\" )\n            print ( \"(\" , y + x_centre , \", \" , - x + y_centre , \")\" , sep = \"\" , end = \"\" )\n            print ( \"(\" , - y + x_centre , \", \" , - x + y_centre , \")\" , sep = \"\" )\n", "SMALLEST_ELEMENT_REPEATED_EXACTLY_K_TIMES_NOT_LIMITED_SMALL_RANGE": "def smallestKFreq ( arr , n , k ) :\n    mp = defaultdict ( lambda : 0 )\n    for i in range ( n ) :\n        mp [ arr [ i ] ] += 1\n    res = sys.maxsize\n    res1 = sys.maxsize\n    for key , values in mp.items ( ) :\n        if values == k :\n            res = min ( res , key )\n    return res if res != res1 else - 1\n", "MINIMUM_XOR_VALUE_PAIR": "def minXOR ( arr , n ) :\n    arr.sort ( ) ;\n    min_xor = 999999\n    val = 0\n    for i in range ( 0 , n - 1 ) :\n        for j in range ( i + 1 , n - 1 ) :\n            val = arr [ i ] ^ arr [ j ]\n            min_xor = min ( min_xor , val )\n    return min_xor\n", "MIRROR_CHARACTERS_STRING": "def compute ( st , n ) :\n    reverseAlphabet = \"zyxwvutsrqponmlkjihgfedcba\"\n    l = len ( st )\n    answer = \"\"\n    for i in range ( 0 , n ) :\n        answer = answer + st [ i ] ;\n    for i in range ( n , l ) :\n        answer = ( answer + reverseAlphabet [ ord ( st [ i ] ) - ord ( 'a' ) ] ) ;\n    return answer ;\n", "PROGRAM_CHECK_PLUS_PERFECT_NUMBER": "def checkplusperfect ( x ) :\n    temp = x\n    n = 0\n    while ( x != 0 ) :\n        x = x // 10\n        n = n + 1\n    x = temp\n    sm = 0\n    while ( x != 0 ) :\n        sm = sm + ( int ) ( math.pow ( x % 10 , n ) )\n        x = x // 10\n    return ( sm == temp )\n", "ARC_LENGTH_ANGLE": "def arcLength ( diameter , angle ) :\n    if angle >= 360 :\n        print ( \"Angle cannot be formed\" )\n        return 0\n    else :\n        arc = ( 3.142857142857143 * diameter ) * ( angle / 360.0 )\n        return arc\n", "FIND_LAST_INDEX_CHARACTER_STRING": "def findLastIndex ( str , x ) :\n    index = - 1\n    for i in range ( 0 , len ( str ) ) :\n        if str [ i ] == x :\n            index = i\n    return index\n", "COUNT_TRAILING_ZEROES_FACTORIAL_NUMBER": "def findTrailingZeros ( n ) :\n    count = 0\n    i = 5\n    while ( n / i >= 1 ) :\n        count += int ( n / i )\n        i *= 5\n    return int ( count )\n", "ROTATE_MATRIX_180_DEGREE": "def rotateMatrix ( mat ) :\n    i = N - 1 ;\n    while ( i >= 0 ) :\n        j = N - 1 ;\n        while ( j >= 0 ) :\n            print ( mat [ i ] [ j ] , end = \" \" ) ;\n            j = j - 1 ;\n        print ( ) ;\n        i = i - 1 ;\n", "SUM_FIBONACCI_NUMBERS": "def calculateSum ( n ) :\n    if ( n <= 0 ) :\n        return 0\n    fibo = [ 0 ] * ( n + 1 )\n    fibo [ 1 ] = 1\n    sm = fibo [ 0 ] + fibo [ 1 ]\n    for i in range ( 2 , n + 1 ) :\n        fibo [ i ] = fibo [ i - 1 ] + fibo [ i - 2 ]\n        sm = sm + fibo [ i ]\n    return sm\n", "LARGEST_LEXICOGRAPHIC_ARRAY_WITH_AT_MOST_K_CONSECUTIVE_SWAPS": "def KSwapMaximum ( n , k ) :\n    global arr\n    for i in range ( 0 , n - 1 ) :\n        if ( k > 0 ) :\n            indexPosition = i\n            for j in range ( i + 1 , n ) :\n                if ( k <= j - i ) :\n                    break\n                if ( arr [ j ] > arr [ indexPosition ] ) :\n                    indexPosition = j\n            for j in range ( indexPosition , i , - 1 ) :\n                t = arr [ j ]\n                arr [ j ] = arr [ j - 1 ]\n                arr [ j - 1 ] = t\n            k = k - indexPosition - i\n", "FIND_WHETHER_GIVEN_INTEGER_POWER_3_NOT": "def check ( n ) :\n    return 1162261467 % n == 0\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY": "def printRepeating ( arr , size ) :\n    print ( \"Repeating elements are \" , end = '' )\n    for i in range ( 0 , size ) :\n        for j in range ( i + 1 , size ) :\n            if arr [ i ] == arr [ j ] :\n                print ( arr [ i ] , end = ' ' )\n", "C_PROGRAM_FIND_AREA_TRIANGLE": "def findArea ( a , b , c ) :\n    if ( a < 0 or b < 0 or c < 0 or ( a + b <= c ) or ( a + c <= b ) or ( b + c <= a ) ) :\n        print ( 'Not a valid trianglen' )\n        return\n    s = ( a + b + c ) / 2\n    area = ( s * ( s - a ) * ( s - b ) * ( s - c ) ) ** 0.5\n    print ( 'Area of a traingle is %f' % area )\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8_1": "def isSubSeqDivisible ( str ) :\n    n = len ( str )\n    dp = [ [ 0 for i in range ( 10 ) ] for i in range ( n + 1 ) ]\n    arr = [ 0 for i in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        arr [ i ] = int ( str [ i - 1 ] ) ;\n    for i in range ( 1 , n + 1 ) :\n        dp [ i ] [ arr [ i ] % 8 ] = 1 ;\n        for j in range ( 8 ) :\n            if ( dp [ i - 1 ] [ j ] > dp [ i ] [ ( j * 10 + arr [ i ] ) % 8 ] ) :\n                dp [ i ] [ ( j * 10 + arr [ i ] ) % 8 ] = dp [ i - 1 ] [ j ]\n            if ( dp [ i - 1 ] [ j ] > dp [ i ] [ j ] ) :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j ]\n    for i in range ( 1 , n + 1 ) :\n        if ( dp [ i ] [ 0 ] == 1 ) :\n            return True\n    return False\n", "DELETE_ARRAY_ELEMENTS_WHICH_ARE_SMALLER_THAN_NEXT_OR_BECOME_SMALLER": "def deleteElements ( arr , n , k ) :\n    st = [ ]\n    st.append ( arr [ 0 ] )\n    top = 0\n    count = 0\n    for i in range ( 1 , n ) :\n        while ( len ( st ) != 0 and count < k and st [ top ] < arr [ i ] ) :\n            st.pop ( )\n            count += 1\n            top -= 1\n        st.append ( arr [ i ] )\n        top += 1\n    for i in range ( 0 , len ( st ) ) :\n        print ( st [ i ] , \"\" , end = \"\" )\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE": "def smallestSubWithSum ( arr , n , x ) :\n    curr_sum = 0\n    min_len = n + 1\n    start = 0\n    end = 0\n    while ( end < n ) :\n        while ( curr_sum <= x and end < n ) :\n            curr_sum += arr [ end ]\n            end += 1\n        while ( curr_sum > x and start < n ) :\n            if ( end - start < min_len ) :\n                min_len = end - start\n            curr_sum -= arr [ start ]\n            start += 1\n    return min_len\n", "FIND_PAIRS_IN_ARRAY_WHOSE_SUMS_ALREADY_EXIST_IN_ARRAY_1": "def findPair ( arr , n ) :\n    s = { i : 1 for i in arr }\n    found = False\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if arr [ i ] + arr [ j ] in s.keys ( ) :\n                print ( arr [ i ] , arr [ j ] )\n                found = True\n    if found == False :\n        print ( \"Not exist\" )\n", "COUNT_ARITHMETIC_PROGRESSION_SUBSEQUENCES_ARRAY": "def numofAP ( a , n ) :\n    minarr = + 2147483647\n    maxarr = - 2147483648\n    for i in range ( n ) :\n        minarr = min ( minarr , a [ i ] )\n        maxarr = max ( maxarr , a [ i ] )\n    dp = [ 0 for i in range ( n + 1 ) ]\n    ans = n + 1\n    for d in range ( ( minarr - maxarr ) , ( maxarr - minarr ) + 1 ) :\n        sum = [ 0 for i in range ( MAX + 1 ) ]\n        for i in range ( n ) :\n            dp [ i ] = 1\n            if ( a [ i ] - d >= 1 and a [ i ] - d <= 1000000 ) :\n                dp [ i ] += sum [ a [ i ] - d ]\n            ans += dp [ i ] - 1\n            sum [ a [ i ] ] += dp [ i ]\n    return ans\n", "COUNT_NUMBERS_THAT_DONT_CONTAIN_3": "def count ( n ) :\n    if n < 3 :\n        return n\n    elif n >= 3 and n < 10 :\n        return n - 1\n    po = 1\n    while n / po > 9 :\n        po = po * 10\n    msd = n / po\n    if msd != 3 :\n        return count ( msd ) * count ( po - 1 ) + count ( msd ) + count ( n % po )\n    else :\n        return count ( msd * po - 1 )\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX_2": "def transpose ( A ) :\n    for i in range ( N ) :\n        for j in range ( i + 1 , N ) :\n            A [ i ] [ j ] , A [ j ] [ i ] = A [ j ] [ i ] , A [ i ] [ j ]\n", "SUM_DIAGONALS_SPIRAL_ODD_ORDER_SQUARE_MATRIX": "def spiralDiaSum ( n ) :\n    if n == 1 :\n        return 1\n    return ( 4 * n * n - 6 * n + 6 + spiralDiaSum ( n - 2 ) )\n", "COUNT_INVERSIONS_OF_SIZE_THREE_IN_A_GIVE_ARRAY": "def getInvCount ( arr ) :\n    n = len ( arr )\n    invcount = 0\n    for i in range ( 0 , n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            if arr [ i ] > arr [ j ] :\n                for k in range ( j + 1 , n ) :\n                    if arr [ j ] > arr [ k ] :\n                        invcount += 1\n    return invcount\n", "FIND_SUM_NODES_GIVEN_PERFECT_BINARY_TREE": "def SumNodes ( l ) :\n    leafNodeCount = pow ( 2 , l - 1 )\n    vec = [ [ ] for i in range ( l ) ]\n    for i in range ( 1 , leafNodeCount + 1 ) :\n        vec [ l - 1 ].append ( i )\n    for i in range ( l - 2 , - 1 , - 1 ) :\n        k = 0\n        while ( k < len ( vec [ i + 1 ] ) - 1 ) :\n            vec [ i ].append ( vec [ i + 1 ] [ k ] + vec [ i + 1 ] [ k + 1 ] )\n            k += 2\n    Sum = 0\n    for i in range ( l ) :\n        for j in range ( len ( vec [ i ] ) ) :\n            Sum += vec [ i ] [ j ]\n    return Sum\n", "SUM_OF_ALL_PROPER_DIVISORS_OF_A_NATURAL_NUMBER": "def divSum ( num ) :\n    result = 0\n    i = 2\n    while i <= ( math.sqrt ( num ) ) :\n        if ( num % i == 0 ) :\n            if ( i == ( num / i ) ) :\n                result = result + i ;\n            else :\n                result = result + ( i + num / i ) ;\n        i = i + 1\n    return ( result + 1 ) ;\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE_2": "def find3Numbers ( A , arr_size , sum ) :\n    for i in range ( 0 , arr_size - 1 ) :\n        s = set ( )\n        curr_sum = sum - A [ i ]\n        for j in range ( i + 1 , arr_size ) :\n            if ( curr_sum - A [ j ] ) in s :\n                print ( \"Triplet is\" , A [ i ] , \", \" , A [ j ] , \", \" , curr_sum - A [ j ] )\n                return True\n            s.add ( A [ j ] )\n    return False\n", "NTH_EVEN_LENGTH_PALINDROME": "def evenlength ( n ) :\n    res = n\n    for j in range ( len ( n ) - 1 , - 1 , - 1 ) :\n        res += n [ j ]\n    return res\n", "FINDING_POWER_PRIME_NUMBER_P_N": "def PowerOFPINnfactorial ( n , p ) :\n    ans = 0 ;\n    temp = p ;\n    while ( temp <= n ) :\n        ans += n / temp ;\n        temp = temp * p ;\n    return ans ;\n", "MINIMUM_COST_MAKE_LONGEST_COMMON_SUBSEQUENCE_LENGTH_K": "def solve ( X , Y , l , r , k , dp ) :\n    if k == 0 :\n        return 0\n    if l < 0 or r < 0 :\n        return 1000000000\n    if dp [ l ] [ r ] [ k ] != - 1 :\n        return dp [ l ] [ r ] [ k ]\n    cost = ( ( ord ( X [ l ] ) - ord ( 'a' ) ) ^ ( ord ( Y [ r ] ) - ord ( 'a' ) ) )\n    dp [ l ] [ r ] [ k ] = min ( [ cost + solve ( X , Y , l - 1 , r - 1 , k - 1 , dp ) , solve ( X , Y , l - 1 , r , k , dp ) , solve ( X , Y , l , r - 1 , k , dp ) ] )\n    return dp [ l ] [ r ] [ k ]\n", "PRINT_STRING_SPECIFIED_CHARACTER_OCCURRED_GIVEN_NO_TIMES": "def printString ( str , ch , count ) :\n    occ , i = 0 , 0\n    if ( count == 0 ) :\n        print ( str )\n    for i in range ( len ( str ) ) :\n        if ( str [ i ] == ch ) :\n            occ += 1\n        if ( occ == count ) :\n            break\n    if ( i < len ( str ) - 1 ) :\n        print ( str [ i + 1 : len ( str ) - i + 2 ] )\n    else :\n        print ( \"Empty string\" )\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS": "def sortedAfterSwap ( A , B , n ) :\n    for i in range ( 0 , n - 1 ) :\n        if ( B [ i ] == 1 ) :\n            j = i\n            while ( B [ j ] == 1 ) :\n                j = j + 1\n            A = A [ 0 : i ] + sorted ( A [ i : j + 1 ] ) + A [ j + 1 : ]\n            i = j\n    for i in range ( 0 , n ) :\n        if ( A [ i ] != i + 1 ) :\n            return False\n    return True\n", "GENERATE_PYTHAGOREAN_TRIPLETS": "def pythagoreanTriplets ( limits ) :\n    c , m = 0 , 2\n    while c < limits :\n        for n in range ( 1 , m ) :\n            a = m * m - n * n\n            b = 2 * m * n\n            c = m * m + n * n\n            if c > limits :\n                break\n            print ( a , b , c )\n        m = m + 1\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS": "def countSeq ( n , diff ) :\n    if ( abs ( diff ) > n ) :\n        return 0\n    if ( n == 1 and diff == 0 ) :\n        return 2\n    if ( n == 1 and abs ( diff ) == 1 ) :\n        return 1\n    res = ( countSeq ( n - 1 , diff + 1 ) + 2 * countSeq ( n - 1 , diff ) + countSeq ( n - 1 , diff - 1 ) )\n    return res\n", "POSSIBLE_FORM_TRIANGLE_ARRAY_VALUES": "def isPossibleTriangle ( arr , N ) :\n    if N < 3 :\n        return False\n    arr.sort ( )\n    for i in range ( N - 2 ) :\n        if arr [ i ] + arr [ i + 1 ] > arr [ i + 2 ] :\n            return True\n", "PRINT_ARRAY_STRINGS_SORTED_ORDER_WITHOUT_COPYING_ONE_STRING_ANOTHER": "def printInSortedOrder ( arr , n ) :\n    index = [ 0 ] * n\n    for i in range ( n ) :\n        index [ i ] = i\n    for i in range ( n - 1 ) :\n        min = i\n        for j in range ( i + 1 , n ) :\n            if ( arr [ index [ min ] ] > arr [ index [ j ] ] ) :\n                min = j\n        if ( min != i ) :\n            index [ min ] , index [ i ] = index [ i ] , index [ min ]\n    for i in range ( n ) :\n        print ( arr [ index [ i ] ] , end = \" \" )\n", "GAME_REPLACING_ARRAY_ELEMENTS": "def playGame ( arr , n ) :\n    s = set ( )\n    for i in range ( n ) :\n        s.add ( arr [ i ] )\n    return 1 if len ( s ) % 2 == 0 else 2\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS": "def gcd ( a , b ) :\n    if a == 0 :\n        return b\n    return gcd ( b % a , a )\n", "SORT_ARRAY_WAVE_FORM_2_1": "def sortInWave ( arr , n ) :\n    for i in range ( 0 , n , 2 ) :\n        if ( i > 0 and arr [ i ] < arr [ i - 1 ] ) :\n            arr [ i ] , arr [ i - 1 ] = arr [ i - 1 ] , arr [ i ]\n        if ( i < n - 1 and arr [ i ] < arr [ i + 1 ] ) :\n            arr [ i ] , arr [ i + 1 ] = arr [ i + 1 ] , arr [ i ]\n", "MAXIMUM_SUBARRAY_SUM_USING_PREFIX_SUM": "def maximumSumSubarray ( arr , n ) :\n    min_prefix_sum = 0\n    res = - math.inf\n    prefix_sum = [ ]\n    prefix_sum.append ( arr [ 0 ] )\n    for i in range ( 1 , n ) :\n        prefix_sum.append ( prefix_sum [ i - 1 ] + arr [ i ] )\n    for i in range ( n ) :\n        res = max ( res , prefix_sum [ i ] - min_prefix_sum )\n        min_prefix_sum = min ( min_prefix_sum , prefix_sum [ i ] )\n    return res\n", "STRING_CONTAINING_FIRST_LETTER_EVERY_WORD_GIVEN_STRING_SPACES": "def firstLetterWord ( str ) :\n    result = \"\"\n    v = True\n    for i in range ( len ( str ) ) :\n        if ( str [ i ] == ' ' ) :\n            v = True\n        elif ( str [ i ] != ' ' and v == True ) :\n            result += ( str [ i ] )\n            v = False\n    return result\n", "SUM_PAIRWISE_PRODUCTS_1": "def findSum ( n ) :\n    multiTerms = n * ( n + 1 ) // 2\n    sm = multiTerms\n    for i in range ( 2 , n + 1 ) :\n        multiTerms = multiTerms - ( i - 1 )\n        sm = sm + multiTerms * i\n    return sm\n", "CLUSTERINGPARTITIONING_AN_ARRAY_SUCH_THAT_SUM_OF_SQUARE_DIFFERENCES_IS_MINIMUM_1": "def minCost ( a , n , k ) :\n    dp = [ [ inf for i in range ( k + 1 ) ] for j in range ( n + 1 ) ] ;\n    dp [ 0 ] [ 0 ] = 0 ;\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , k + 1 ) :\n            for m in range ( i - 1 , - 1 , - 1 ) :\n                dp [ i ] [ j ] = min ( dp [ i ] [ j ] , dp [ m ] [ j - 1 ] + ( a [ i - 1 ] - a [ m ] ) * ( a [ i - 1 ] - a [ m ] ) ) ;\n    return dp [ n ] [ k ] ;\n", "LEIBNIZ_HARMONIC_TRIANGLE": "def LeibnizHarmonicTriangle ( n ) :\n    C = [ [ 0 for x in range ( n + 1 ) ] for y in range ( n + 1 ) ] ;\n    for i in range ( 0 , n + 1 ) :\n        for j in range ( 0 , min ( i , n ) + 1 ) :\n            if ( j == 0 or j == i ) :\n                C [ i ] [ j ] = 1 ;\n            else :\n                C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] ) ;\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , i + 1 ) :\n            print ( \"1/\" , end = \"\" ) ;\n            print ( i * C [ i - 1 ] [ j - 1 ] , end = \" \" ) ;\n        print ( ) ;\n", "CHECK_WHETHER_SECOND_STRING_CAN_FORMED_FIRST_STRING_USING_COUNT_ARRAY": "def canMakeStr2 ( s1 , s2 ) :\n    count = { s1 [ i ] : 0 for i in range ( len ( s1 ) ) }\n    for i in range ( len ( s1 ) ) :\n        count [ s1 [ i ] ] += 1\n    for i in range ( len ( s2 ) ) :\n        if count [ s2 [ i ] ] == 0 :\n            return False\n        count [ s2 [ i ] ] -= 1\n    return True\n", "SUM_MINIMUM_MAXIMUM_ELEMENTS_SUBARRAYS_SIZE_K": "def SumOfKsubArray ( arr , n , k ) :\n    Sum = 0\n    S = deque ( )\n    G = deque ( )\n    for i in range ( k ) :\n        while ( len ( S ) > 0 and arr [ S [ - 1 ] ] >= arr [ i ] ) :\n            S.pop ( )\n        while ( len ( G ) > 0 and arr [ G [ - 1 ] ] <= arr [ i ] ) :\n            G.pop ( )\n        G.append ( i )\n        S.append ( i )\n    for i in range ( k , n ) :\n        Sum += arr [ S [ 0 ] ] + arr [ G [ 0 ] ]\n        while ( len ( S ) > 0 and S [ 0 ] <= i - k ) :\n            S.popleft ( )\n        while ( len ( G ) > 0 and G [ 0 ] <= i - k ) :\n            G.popleft ( )\n        while ( len ( S ) > 0 and arr [ S [ - 1 ] ] >= arr [ i ] ) :\n            S.pop ( )\n        while ( len ( G ) > 0 and arr [ G [ - 1 ] ] <= arr [ i ] ) :\n            G.pop ( )\n        G.append ( i )\n        S.append ( i )\n    Sum += arr [ S [ 0 ] ] + arr [ G [ 0 ] ]\n    return Sum\n", "LONGEST_COMMON_SUBSEQUENCE": "def lcs ( X , Y , m , n ) :\n    if m == 0 or n == 0 :\n        return 0 ;\n    elif X [ m - 1 ] == Y [ n - 1 ] :\n        return 1 + lcs ( X , Y , m - 1 , n - 1 ) ;\n    else :\n        return max ( lcs ( X , Y , m , n - 1 ) , lcs ( X , Y , m - 1 , n ) ) ;\n", "MINIMUM_SUM_ABSOLUTE_DIFFERENCE_PAIRS_TWO_ARRAYS": "def findMinSum ( a , b , n ) :\n    a.sort ( )\n    b.sort ( )\n    sum = 0\n    for i in range ( n ) :\n        sum = sum + abs ( a [ i ] - b [ i ] )\n    return sum\n", "COUNT_DISTINCT_NON_NEGATIVE_PAIRS_X_Y_SATISFY_INEQUALITY_XX_YY_N_2": "def countSolutions ( n ) :\n    res = 0\n    x = 0\n    while ( x * x < n ) :\n        y = 0\n        while ( x * x + y * y < n ) :\n            res = res + 1\n            y = y + 1\n        x = x + 1\n    return res\n", "FIND_NUMBER_TRANSFORMATION_MAKE_TWO_MATRIX_EQUAL": "def countOps ( A , B , m , n ) :\n    for i in range ( n ) :\n        for j in range ( m ) :\n            A [ i ] [ j ] -= B [ i ] [ j ] ;\n    for i in range ( 1 , n ) :\n        for j in range ( 1 , n ) :\n            if ( A [ i ] [ j ] - A [ i ] [ 0 ] - A [ 0 ] [ j ] + A [ 0 ] [ 0 ] != 0 ) :\n                return - 1 ;\n    result = 0 ;\n    for i in range ( n ) :\n        result += abs ( A [ i ] [ 0 ] ) ;\n    for j in range ( m ) :\n        result += abs ( A [ 0 ] [ j ] - A [ 0 ] [ 0 ] ) ;\n    return ( result ) ;\n", "EFFICIENTLY_FIND_FIRST_REPEATED_CHARACTER_STRING_WITHOUT_USING_ADDITIONAL_DATA_STRUCTURE_ONE_TRAVERSAL": "def FirstRepeated ( string ) :\n    checker = 0\n    pos = 0\n    for i in string :\n        val = ord ( i ) - ord ( 'a' ) ;\n        if ( ( checker & ( 1 << val ) ) > 0 ) :\n            return pos\n        checker |= ( 1 << val )\n        pos += 1\n    return - 1\n", "MAXIMUM_UNIQUE_ELEMENT_EVERY_SUBARRAY_SIZE_K": "def find_max ( A , N , K ) :\n    Count = dict ( )\n    for i in range ( K - 1 ) :\n        Count [ A [ i ] ] = Count.get ( A [ i ] , 0 ) + 1\n    Myset = dict ( )\n    for x in Count :\n        if ( Count [ x ] == 1 ) :\n            Myset [ x ] = 1\n    for i in range ( K - 1 , N ) :\n        Count [ A [ i ] ] = Count.get ( A [ i ] , 0 ) + 1\n        if ( Count [ A [ i ] ] == 1 ) :\n            Myset [ A [ i ] ] = 1\n        else :\n            del Myset [ A [ i ] ]\n        if ( len ( Myset ) == 0 ) :\n            print ( \"Nothing\" )\n        else :\n            maxm = - 10 ** 9\n            for i in Myset :\n                maxm = max ( i , maxm )\n            print ( maxm )\n        x = A [ i - K + 1 ]\n        if x in Count.keys ( ) :\n            Count [ x ] -= 1\n            if ( Count [ x ] == 1 ) :\n                Myset [ x ] = 1\n            if ( Count [ x ] == 0 ) :\n                del Myset [ x ]\n", "MINIMUM_COST_SORT_MATRIX_NUMBERS_0_N2_1": "def calculateEnergy ( mat , n ) :\n    tot_energy = 0\n    for i in range ( n ) :\n        for j in range ( n ) :\n            q = mat [ i ] [ j ] // n\n            i_des = q\n            j_des = mat [ i ] [ j ] - ( n * q )\n            tot_energy += ( abs ( i_des - i ) + abs ( j_des - j ) )\n    return tot_energy\n", "LONGEST_COMMON_SUBSTRING": "def LCSubStr ( X , Y , m , n ) :\n    LCSuff = [ [ 0 for k in range ( n + 1 ) ] for l in range ( m + 1 ) ]\n    result = 0\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            if ( i == 0 or j == 0 ) :\n                LCSuff [ i ] [ j ] = 0\n            elif ( X [ i - 1 ] == Y [ j - 1 ] ) :\n                LCSuff [ i ] [ j ] = LCSuff [ i - 1 ] [ j - 1 ] + 1\n                result = max ( result , LCSuff [ i ] [ j ] )\n            else :\n                LCSuff [ i ] [ j ] = 0\n    return result\n", "MAXIMUM_SUM_BITONIC_SUBARRAY": "def maxSumBitonicSubArr ( arr , n ) :\n    msis = [ None ] * n\n    msds = [ None ] * n\n    max_sum = 0\n    msis [ 0 ] = arr [ 0 ]\n    for i in range ( 1 , n ) :\n        if ( arr [ i ] > arr [ i - 1 ] ) :\n            msis [ i ] = msis [ i - 1 ] + arr [ i ]\n        else :\n            msis [ i ] = arr [ i ]\n    msds [ n - 1 ] = arr [ n - 1 ]\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        if ( arr [ i ] > arr [ i + 1 ] ) :\n            msds [ i ] = msds [ i + 1 ] + arr [ i ]\n        else :\n            msds [ i ] = arr [ i ]\n    for i in range ( n ) :\n        if ( max_sum < ( msis [ i ] + msds [ i ] - arr [ i ] ) ) :\n            max_sum = ( msis [ i ] + msds [ i ] - arr [ i ] )\n    return max_sum\n", "NEWMAN_CONWAY_SEQUENCE": "def sequence ( n ) :\n    if n == 1 or n == 2 :\n        return 1\n    else :\n        return sequence ( sequence ( n - 1 ) ) + sequence ( n - sequence ( n - 1 ) ) ;\n", "PRINT_TRIPLETS_SORTED_ARRAY_FORM_AP": "def printAllAPTriplets ( arr , n ) :\n    s = [ ] ;\n    for i in range ( 0 , n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            diff = arr [ j ] - arr [ i ] ;\n            if ( ( arr [ i ] - diff ) in arr ) :\n                print ( \"{} {} {}\".format ( ( arr [ i ] - diff ) , arr [ i ] , arr [ j ] ) , end = \"\\n\" ) ;\n    s.append ( arr [ i ] ) ;\n", "QUERIES_COUNTS_ARRAY_ELEMENTS_VALUES_GIVEN_RANGE": "def countInRange ( arr , n , x , y ) :\n    count = 0 ;\n    for i in range ( n ) :\n        if ( arr [ i ] >= x and arr [ i ] <= y ) :\n            count += 1\n    return count\n", "HIGHWAY_BILLBOARD_PROBLEM": "def maxRevenue ( m , x , revenue , n , t ) :\n    maxRev = [ 0 ] * ( m + 1 )\n    nxtbb = 0 ;\n    for i in range ( 1 , m + 1 ) :\n        if ( nxtbb < n ) :\n            if ( x [ nxtbb ] != i ) :\n                maxRev [ i ] = maxRev [ i - 1 ]\n            else :\n                if ( i <= t ) :\n                    maxRev [ i ] = max ( maxRev [ i - 1 ] , revenue [ nxtbb ] )\n                else :\n                    maxRev [ i ] = max ( maxRev [ i - t - 1 ] + revenue [ nxtbb ] , maxRev [ i - 1 ] ) ;\n                nxtbb += 1\n        else :\n            maxRev [ i ] = maxRev [ i - 1 ]\n    return maxRev [ m ]\n", "CONSTRUCT_GRAPH_GIVEN_DEGREES_VERTICES": "def printMat ( degseq , n ) :\n    mat = [ [ 0 ] * n for i in range ( n ) ]\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if ( degseq [ i ] > 0 and degseq [ j ] > 0 ) :\n                degseq [ i ] -= 1\n                degseq [ j ] -= 1\n                mat [ i ] [ j ] = 1\n                mat [ j ] [ i ] = 1\n    print ( \"      \" , end = \"\" )\n    for i in range ( n ) :\n        print ( \"\" , \"(\" , i , \")\" , end = \"\" )\n    print ( )\n    print ( )\n    for i in range ( n ) :\n        print ( \"\" , \"(\" , i , \")\" , end = \"\" )\n        for j in range ( n ) :\n            print ( \"     \" , mat [ i ] [ j ] , end = \"\" )\n        print ( )\n", "DETECT_IF_TWO_INTEGERS_HAVE_OPPOSITE_SIGNS": "def oppositeSigns ( x , y ) :\n    return ( ( x ^ y ) < 0 ) ;\n", "TRIANGULAR_NUMBERS_1": "def isTriangular ( num ) :\n    if ( num < 0 ) :\n        return False\n    c = ( - 2 * num )\n    b , a = 1 , 1\n    d = ( b * b ) - ( 4 * a * c )\n    if ( d < 0 ) :\n        return False\n    root1 = ( - b + math.sqrt ( d ) ) / ( 2 * a )\n    root2 = ( - b - math.sqrt ( d ) ) / ( 2 * a )\n    if ( root1 > 0 and math.floor ( root1 ) == root1 ) :\n        return True\n    if ( root2 > 0 and math.floor ( root2 ) == root2 ) :\n        return True\n    return False\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT": "def isPowerOfFour ( n ) :\n    if ( n == 0 ) :\n        return False\n    while ( n != 1 ) :\n        if ( n % 4 != 0 ) :\n            return False\n        n = n // 4\n    return True\n", "LAST_NON_ZERO_DIGIT_FACTORIAL": "def lastNon0Digit ( n ) :\n    if ( n < 10 ) :\n        return dig [ n ]\n    if ( ( ( n // 10 ) % 10 ) % 2 == 0 ) :\n        return ( 6 * lastNon0Digit ( n // 5 ) * dig [ n % 10 ] ) % 10\n    else :\n        return ( 4 * lastNon0Digit ( n // 5 ) * dig [ n % 10 ] ) % 10\n    return 0\n", "SORT_STRING_ACCORDING_ORDER_DEFINED_ANOTHER_STRING": "def sortByPattern ( str , pat ) :\n    global MAX_CHAR\n    count = [ 0 ] * MAX_CHAR\n    for i in range ( 0 , len ( str ) ) :\n        count [ ord ( str [ i ] ) - 97 ] += 1\n    index = 0 ;\n    str = \"\"\n    for i in range ( 0 , len ( pat ) ) :\n        j = 0\n        while ( j < count [ ord ( pat [ i ] ) - ord ( 'a' ) ] ) :\n            str += pat [ i ]\n            j = j + 1\n            index += 1\n    return str\n", "NUMBER_VISIBLE_BOXES_PUTTING_ONE_INSIDE_ANOTHER": "def minimumBox ( arr , n ) :\n    q = collections.deque ( [ ] )\n    arr.sort ( )\n    q.append ( arr [ 0 ] )\n    for i in range ( 1 , n ) :\n        now = q [ 0 ]\n        if ( arr [ i ] >= 2 * now ) :\n            q.popleft ( )\n        q.append ( arr [ i ] )\n    return len ( q )\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY": "def binarySearch ( arr , low , high , key ) :\n    if ( high < low ) :\n        return - 1\n    mid = ( low + high ) / 2\n    if ( key == arr [ int ( mid ) ] ) :\n        return mid\n    if ( key > arr [ int ( mid ) ] ) :\n        return binarySearch ( arr , ( mid + 1 ) , high , key )\n    return ( binarySearch ( arr , low , ( mid - 1 ) , key ) )\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_3": "def printRepeating ( arr , size ) :\n    print ( \" The repeating elements are\" , end = \" \" )\n    for i in range ( 0 , size ) :\n        if ( arr [ abs ( arr [ i ] ) ] > 0 ) :\n            arr [ abs ( arr [ i ] ) ] = ( - 1 ) * arr [ abs ( arr [ i ] ) ]\n        else :\n            print ( abs ( arr [ i ] ) , end = \" \" )\n", "COUNT_POSSIBLE_GROUPS_SIZE_2_3_SUM_MULTIPLE_3": "def findgroups ( arr , n ) :\n    c = [ 0 , 0 , 0 ]\n    res = 0\n    for i in range ( 0 , n ) :\n        c [ arr [ i ] % 3 ] += 1\n    res += ( ( c [ 0 ] * ( c [ 0 ] - 1 ) ) >> 1 )\n    res += c [ 1 ] * c [ 2 ]\n    res += ( c [ 0 ] * ( c [ 0 ] - 1 ) * ( c [ 0 ] - 2 ) ) / 6\n    res += ( c [ 1 ] * ( c [ 1 ] - 1 ) * ( c [ 1 ] - 2 ) ) / 6\n    res += ( ( c [ 2 ] * ( c [ 2 ] - 1 ) * ( c [ 2 ] - 2 ) ) / 6 )\n    res += c [ 0 ] * c [ 1 ] * c [ 2 ]\n    return res\n", "PRINT_STRING_IGNORING_ALTERNATE_OCCURRENCES_CHARACTER": "def printStringAlternate ( string ) :\n    occ = { }\n    for i in range ( 0 , len ( string ) ) :\n        temp = string [ i ].lower ( )\n        occ [ temp ] = occ.get ( temp , 0 ) + 1\n        if occ [ temp ] & 1 :\n            print ( string [ i ] , end = \"\" )\n    print ( )\n", "NUMBER_DAYS_TANK_WILL_BECOME_EMPTY": "def minDaysToEmpty ( C , l ) :\n    if ( l >= C ) : return C\n    eq_root = ( math.sqrt ( 1 + 8 * ( C - l ) ) - 1 ) / 2\n    return math.ceil ( eq_root ) + l\n", "REVERSE_STRING_WITHOUT_USING_ANY_TEMPORARY_VARIABLE": "def reversingString ( str , start , end ) :\n    while ( start < end ) :\n        str = ( str [ : start ] + chr ( ord ( str [ start ] ) ^ ord ( str [ end ] ) ) + str [ start + 1 : ] ) ;\n        str = ( str [ : end ] + chr ( ord ( str [ start ] ) ^ ord ( str [ end ] ) ) + str [ end + 1 : ] ) ;\n        str = ( str [ : start ] + chr ( ord ( str [ start ] ) ^ ord ( str [ end ] ) ) + str [ start + 1 : ] ) ;\n        start += 1 ;\n        end -= 1 ;\n    return str ;\n", "FREQUENCY_ELEMENT_UNSORTED_ARRAY": "def countFreq ( a , n ) :\n    hm = { }\n    for i in range ( 0 , n ) :\n        hm [ a [ i ] ] = hm.get ( a [ i ] , 0 ) + 1\n    st = set ( )\n    for x in hm :\n        st.add ( ( x , hm [ x ] ) )\n    cumul = 0\n    for x in sorted ( st ) :\n        cumul += x [ 1 ]\n        print ( x [ 0 ] , cumul )\n", "FIND_ROTATION_COUNT_ROTATED_SORTED_ARRAY": "def countRotations ( arr , n ) :\n    min = arr [ 0 ]\n    for i in range ( 0 , n ) :\n        if ( min > arr [ i ] ) :\n            min = arr [ i ]\n            min_index = i\n    return min_index ;\n", "LONGEST_INCREASING_SUBSEQUENCE_1": "def lis ( arr ) :\n    n = len ( arr )\n    lis = [ 1 ] * n\n    for i in range ( 1 , n ) :\n        for j in range ( 0 , i ) :\n            if arr [ i ] > arr [ j ] and lis [ i ] < lis [ j ] + 1 :\n                lis [ i ] = lis [ j ] + 1\n    maximum = 0\n    for i in range ( n ) :\n        maximum = max ( maximum , lis [ i ] )\n    return maximum\n", "MEDIAN_OF_TWO_SORTED_ARRAYS": "def getMedian ( ar1 , ar2 , n ) :\n    i = 0\n    j = 0\n    m1 = - 1\n    m2 = - 1\n    count = 0\n    while count < n + 1 :\n        count += 1\n        if i == n :\n            m1 = m2\n            m2 = ar2 [ 0 ]\n            break\n        elif j == n :\n            m1 = m2\n            m2 = ar1 [ 0 ]\n            break\n        if ar1 [ i ] < ar2 [ j ] :\n            m1 = m2\n            m2 = ar1 [ i ]\n            i += 1\n        else :\n            m1 = m2\n            m2 = ar2 [ j ]\n            j += 1\n    return ( m1 + m2 ) / 2\n", "LEXICOGRAPHICALLY_MINIMUM_STRING_ROTATION": "def minLexRotation ( str_ ) :\n    n = len ( str_ )\n    arr = [ 0 ] * n\n    concat = str_ + str_\n    for i in range ( n ) :\n        arr [ i ] = concat [ i : n + i ]\n    arr.sort ( )\n    return arr [ 0 ]\n", "INTERPOLATION_SEARCH": "def interpolationSearch ( arr , n , x ) :\n    lo = 0\n    hi = ( n - 1 )\n    while lo <= hi and x >= arr [ lo ] and x <= arr [ hi ] :\n        if lo == hi :\n            if arr [ lo ] == x :\n                return lo ;\n            return - 1 ;\n        pos = lo + int ( ( ( float ( hi - lo ) / ( arr [ hi ] - arr [ lo ] ) ) * ( x - arr [ lo ] ) ) )\n        if arr [ pos ] == x :\n            return pos\n        if arr [ pos ] < x :\n            lo = pos + 1 ;\n        else :\n            hi = pos - 1 ;\n    return - 1\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X_2": "def countPairs ( arr1 , arr2 , m , n , x ) :\n    count , l , r = 0 , 0 , n - 1\n    while ( l < m and r >= 0 ) :\n        if ( ( arr1 [ l ] + arr2 [ r ] ) == x ) :\n            l += 1\n            r -= 1\n            count += 1\n        elif ( ( arr1 [ l ] + arr2 [ r ] ) < x ) :\n            l += 1\n        else :\n            r -= 1\n    return count\n", "COUNT_SUBSETS_DISTINCT_EVEN_NUMBERS": "def countSubSets ( arr , n ) :\n    us = set ( )\n    even_count = 0\n    for i in range ( n ) :\n        if arr [ i ] % 2 == 0 :\n            us.add ( arr [ i ] )\n    for i in us :\n        even_count += 1\n    return pow ( 2 , even_count ) - 1\n", "COUNT_NUMBER_OF_OCCURRENCES_OR_FREQUENCY_IN_A_SORTED_ARRAY": "def countOccurrences ( arr , n , x ) :\n    res = 0\n    for i in range ( n ) :\n        if x == arr [ i ] :\n            res += 1\n    return res\n", "CONSTRUCT_THE_ROOTED_TREE_BY_USING_START_AND_FINISH_TIME_OF_ITS_DFS_TRAVERSAL": "def Restore_Tree ( S , E ) :\n    Identity = N * [ 0 ]\n    for i in range ( N ) :\n        Identity [ Start [ i ] ] = i\n    parent = N * [ - 1 ]\n    curr_parent = Identity [ 0 ]\n    for j in range ( 1 , N ) :\n        child = Identity [ j ]\n        if End [ child ] - j > 1 :\n            parent [ child ] = curr_parent\n            curr_parent = child\n        else :\n            parent [ child ] = curr_parent\n            while End [ child ] == End [ parent [ child ] ] :\n                child = parent [ child ]\n                curr_parent = parent [ child ]\n                if curr_parent == Identity [ 0 ] :\n                    break\n    for i in range ( N ) :\n        parent [ i ] += 1\n    return parent\n", "NUMBER_SUBSEQUENCES_AB_STRING_REPEATED_K_TIMES": "def countOccurrences ( s , K ) :\n    n = len ( s )\n    c1 = 0\n    c2 = 0\n    C = 0\n    for i in range ( n ) :\n        if s [ i ] == 'a' :\n            c1 += 1\n        if s [ i ] == 'b' :\n            c2 += 1\n            C += c1\n    return C * K + ( K * ( K - 1 ) / 2 ) * c1 * c2\n", "NUMBER_SUBSTRINGS_STRING": "def countNonEmptySubstr ( str ) :\n    n = len ( str ) ;\n    return int ( n * ( n + 1 ) / 2 ) ;\n", "MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING_1": "def maximumChars ( str1 ) :\n    n = len ( str1 )\n    res = - 1\n    firstInd = [ - 1 for i in range ( MAX_CHAR ) ]\n    for i in range ( n ) :\n        first_ind = firstInd [ ord ( str1 [ i ] ) ]\n        if ( first_ind == - 1 ) :\n            firstInd [ ord ( str1 [ i ] ) ] = i\n        else :\n            res = max ( res , abs ( i - first_ind - 1 ) )\n    return res\n", "SUM_SQUARES_BINOMIAL_COEFFICIENTS": "def sumofsquare ( n ) :\n    C = [ [ 0 for i in range ( n + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( 0 , n + 1 ) :\n        for j in range ( 0 , min ( i , n ) + 1 ) :\n            if ( j == 0 or j == i ) :\n                C [ i ] [ j ] = 1\n            else :\n                C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] )\n    sum = 0\n    for i in range ( 0 , n + 1 ) :\n        sum = sum + ( C [ n ] [ i ] * C [ n ] [ i ] )\n    return sum\n", "PRINT_POSSIBLE_STRINGS_CAN_MADE_PLACING_SPACES_2": "def printSubsequences ( str ) :\n    n = len ( str )\n    opsize = int ( pow ( 2 , n - 1 ) )\n    for counter in range ( opsize ) :\n        for j in range ( n ) :\n            print ( str [ j ] , end = \"\" )\n            if ( counter & ( 1 << j ) ) :\n                print ( \"\" , end = \"\" )\n        print ( \"\\n\" , end = \"\" )\n", "NON_REPEATING_ELEMENT": "def firstNonRepeating ( arr , n ) :\n    for i in range ( n ) :\n        j = 0\n        while ( j < n ) :\n            if ( i != j and arr [ i ] == arr [ j ] ) :\n                break\n            j += 1\n        if ( j == n ) :\n            return arr [ i ]\n    return - 1\n", "SUM_OF_ALL_ELEMENTS_UP_TO_NTH_ROW_IN_A_PASCALS_TRIANGLE": "def calculateSum ( n ) :\n    sum = 0\n    for row in range ( n ) :\n        sum = sum + ( 1 << row )\n    return sum\n", "CHECK_TWO_STRINGS_K_ANAGRAMS_NOT": "def arekAnagrams ( str1 , str2 , k ) :\n    n = len ( str1 )\n    if ( len ( str2 ) != n ) :\n        return False\n    count1 = [ 0 ] * MAX_CHAR\n    count2 = [ 0 ] * MAX_CHAR\n    for i in range ( n ) :\n        count1 [ ord ( str1 [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( n ) :\n        count2 [ ord ( str2 [ i ] ) - ord ( 'a' ) ] += 1\n    count = 0\n    for i in range ( MAX_CHAR ) :\n        if ( count1 [ i ] > count2 [ i ] ) :\n            count = count + abs ( count1 [ i ] - count2 [ i ] )\n    return ( count <= k )\n", "LONGEST_SPAN_SUM_TWO_BINARY_ARRAYS": "def longestCommonSum ( arr1 , arr2 , n ) :\n    maxLen = 0\n    for i in range ( 0 , n ) :\n        sum1 = 0\n        sum2 = 0\n        for j in range ( i , n ) :\n            sum1 += arr1 [ j ]\n            sum2 += arr2 [ j ]\n            if ( sum1 == sum2 ) :\n                len = j - i + 1\n                if ( len > maxLen ) :\n                    maxLen = len\n    return maxLen\n", "REMAINDER_7_LARGE_NUMBERS": "def remainderWith7 ( num ) :\n    series = [ 1 , 3 , 2 , - 1 , - 3 , - 2 ] ;\n    series_index = 0 ;\n    result = 0 ;\n    for i in range ( ( len ( num ) - 1 ) , - 1 , - 1 ) :\n        digit = ord ( num [ i ] ) - 48 ;\n        result += digit * series [ series_index ] ;\n        series_index = ( series_index + 1 ) % 6 ;\n        result %= 7 ;\n    if ( result < 0 ) :\n        result = ( result + 7 ) % 7 ;\n    return result ;\n", "LEXICOGRAPHICALLY_PREVIOUS_PERMUTATION_IN_C": "def prevPermutation ( str ) :\n    n = len ( str ) - 1\n    i = n\n    while ( i > 0 and str [ i - 1 ] <= str [ i ] ) :\n        i -= 1\n    if ( i <= 0 ) :\n        return False\n    j = i - 1\n    while ( j + 1 <= n and str [ j + 1 ] <= str [ i - 1 ] ) :\n        j += 1\n    str = list ( str )\n    temp = str [ i - 1 ]\n    str [ i - 1 ] = str [ j ]\n    str [ j ] = temp\n    str = ''.join ( str )\n    str [ : : - 1 ]\n    return True , str\n", "NUMBER_SUBSEQUENCES_FORM_AI_BJ_CK": "def countSubsequences ( s ) :\n    aCount = 0\n    bCount = 0\n    cCount = 0\n    for i in range ( len ( s ) ) :\n        if ( s [ i ] == 'a' ) :\n            aCount = ( 1 + 2 * aCount )\n        elif ( s [ i ] == 'b' ) :\n            bCount = ( aCount + 2 * bCount )\n        elif ( s [ i ] == 'c' ) :\n            cCount = ( bCount + 2 * cCount )\n    return cCount\n", "PROGRAM_PRINT_IDENTITY_MATRIX_1": "def isIdentity ( mat , N ) :\n    for row in range ( N ) :\n        for col in range ( N ) :\n            if ( row == col and mat [ row ] [ col ] != 1 ) :\n                return False ;\n            elif ( row != col and mat [ row ] [ col ] != 0 ) :\n                return False ;\n    return True ;\n", "MAXIMUM_POSSIBLE_DIFFERENCE_TWO_SUBSETS_ARRAY_1": "def maxDiff ( arr , n ) :\n    result = 0\n    arr.sort ( )\n    for i in range ( n - 1 ) :\n        if ( abs ( arr [ i ] ) != abs ( arr [ i + 1 ] ) ) :\n            result += abs ( arr [ i ] )\n        else :\n            pass\n    if ( arr [ n - 2 ] != arr [ n - 1 ] ) :\n        result += abs ( arr [ n - 1 ] )\n    return result\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM": "def summingSeries ( n ) :\n    S = 0\n    for i in range ( 1 , n + 1 ) :\n        S += i * i - ( i - 1 ) * ( i - 1 )\n    return S\n", "PREFIX_SUM_2D_ARRAY": "def prefixSum2D ( a ) :\n    global C , R\n    psa = [ [ 0 for x in range ( C ) ] for y in range ( R ) ]\n    psa [ 0 ] [ 0 ] = a [ 0 ] [ 0 ]\n    for i in range ( 1 , C ) :\n        psa [ 0 ] [ i ] = ( psa [ 0 ] [ i - 1 ] + a [ 0 ] [ i ] )\n    for i in range ( 0 , R ) :\n        psa [ i ] [ 0 ] = ( psa [ i - 1 ] [ 0 ] + a [ i ] [ 0 ] )\n    for i in range ( 1 , R ) :\n        for j in range ( 1 , C ) :\n            psa [ i ] [ j ] = ( psa [ i - 1 ] [ j ] + psa [ i ] [ j - 1 ] - psa [ i - 1 ] [ j - 1 ] + a [ i ] [ j ] )\n    for i in range ( 0 , R ) :\n        for j in range ( 0 , C ) :\n            print ( psa [ i ] [ j ] , end = \" \" )\n        print ( )\n", "MAXIMUM_NUMBER_2X2_SQUARES_CAN_FIT_INSIDE_RIGHT_ISOSCELES_TRIANGLE": "def numberOfSquares ( base ) :\n    base = ( base - 2 )\n    base = base / 2\n    return base * ( base + 1 ) / 2\n", "GIVEN_BINARY_STRING_COUNT_NUMBER_SUBSTRINGS_START_END_1_1": "def countSubStr ( st , n ) :\n    m = 0\n    for i in range ( 0 , n ) :\n        if ( st [ i ] == '1' ) :\n            m = m + 1\n    return m * ( m - 1 ) // 2\n", "CONVERTING_ONE_STRING_USING_APPEND_DELETE_LAST_OPERATIONS": "def isConvertible ( str1 , str2 , k ) :\n    if ( ( len ( str1 ) + len ( str2 ) ) < k ) :\n        return True\n    commonLength = 0\n    for i in range ( 0 , min ( len ( str1 ) , len ( str2 ) ) , 1 ) :\n        if ( str1 [ i ] == str2 [ i ] ) :\n            commonLength += 1\n        else :\n            break\n    if ( ( k - len ( str1 ) - len ( str2 ) + 2 * commonLength ) % 2 == 0 ) :\n        return True\n    return False\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES_2": "def getOddOccurrence ( arr ) :\n    res = 0\n    for element in arr :\n        res = res ^ element\n    return res\n", "SUM_MIDDLE_ROW_COLUMN_MATRIX": "def middlesum ( mat , n ) :\n    row_sum = 0\n    col_sum = 0\n    for i in range ( n ) :\n        row_sum += mat [ n // 2 ] [ i ]\n    print ( \"Sum of middle row = \" , row_sum )\n    for i in range ( n ) :\n        col_sum += mat [ i ] [ n // 2 ]\n    print ( \"Sum of middle column = \" , col_sum )\n", "K_TH_DISTINCT_OR_NON_REPEATING_ELEMENT_IN_AN_ARRAY": "def printKDistinct ( arr , n , k ) :\n    dist_count = 0\n    for i in range ( n ) :\n        j = 0\n        while j < n :\n            if ( i != j and arr [ j ] == arr [ i ] ) :\n                break\n            j += 1\n        if ( j == n ) :\n            dist_count += 1\n        if ( dist_count == k ) :\n            return arr [ i ]\n    return - 1\n", "MERGING_INTERVALS": "def mergeIntervals ( arr ) :\n    arr.sort ( key = lambda x : x [ 0 ] )\n    m = [ ]\n    s = - 10000\n    max = - 100000\n    for i in range ( len ( arr ) ) :\n        a = arr [ i ]\n        if a [ 0 ] > max :\n            if i != 0 :\n                m.append ( [ s , max ] )\n            max = a [ 1 ]\n            s = a [ 0 ]\n        else :\n            if a [ 1 ] >= max :\n                max = a [ 1 ]\n    if max != - 100000 and [ s , max ] not in m :\n        m.append ( [ s , max ] )\n    print ( \"The Merged Intervals are :\" , end = \" \" )\n    for i in range ( len ( m ) ) :\n        print ( m [ i ] , end = \" \" )\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS_1": "def CountSquares ( a , b ) :\n    return ( math.floor ( math.sqrt ( b ) ) - math.ceil ( math.sqrt ( a ) ) + 1 )\n", "LARGEST_SUBSET_WHOSE_ALL_ELEMENTS_ARE_FIBONACCI_NUMBERS": "def findFibSubset ( arr , n ) :\n    m = max ( arr )\n    a = 0\n    b = 1\n    hash = [ ]\n    hash.append ( a )\n    hash.append ( b )\n    while ( b < m ) :\n        c = a + b\n        a = b\n        b = c\n        hash.append ( b )\n    for i in range ( n ) :\n        if arr [ i ] in hash :\n            print ( arr [ i ] , end = \" \" )\n", "LEXICOGRAPHICAL_CONCATENATION_SUBSTRINGS_STRING": "def lexicographicSubConcat ( s ) :\n    n = len ( s ) ;\n    sub_count = ( n * ( n + 1 ) ) // 2 ;\n    arr = [ 0 ] * sub_count ;\n    index = 0 ;\n    for i in range ( n ) :\n        for j in range ( 1 , n - i + 1 ) :\n            arr [ index ] = s [ i : i + j ] ;\n            index += 1 ;\n    arr.sort ( ) ;\n    res = \"\" ;\n    for i in range ( sub_count ) :\n        res += arr [ i ] ;\n    return res ;\n", "COUNT_OPERATIONS_MAKE_STRINGAB_FREE": "def abFree ( s ) :\n    b_count = 0\n    res = 0\n    for i in range ( len ( s ) ) :\n        if s [ ~ i ] == 'a' :\n            res = ( res + b_count )\n            b_count = ( b_count * 2 )\n        else :\n            b_count += 1\n    return res\n", "MAXIMUM_HEIGHT_OF_TRIANGULAR_ARRANGEMENT_OF_ARRAY_VALUES_1": "def MaximumHeight ( a , n ) :\n    return ( - 1 + int ( math.sqrt ( 1 + ( 8 * n ) ) ) ) // 2\n", "MAXIMIZE_VOLUME_CUBOID_GIVEN_SUM_SIDES": "def maxvolume ( s ) :\n    maxvalue = 0\n    i = 1\n    for i in range ( s - 1 ) :\n        j = 1\n        for j in range ( s ) :\n            k = s - i - j\n            maxvalue = max ( maxvalue , i * j * k )\n    return maxvalue\n", "PROGRAM_DECIMAL_HEXADECIMAL_CONVERSION": "def decToHexa ( n ) :\n    hexaDeciNum = [ '0' ] * 100 ;\n    i = 0 ;\n    while ( n != 0 ) :\n        temp = 0 ;\n        temp = n % 16 ;\n        if ( temp < 10 ) :\n            hexaDeciNum [ i ] = chr ( temp + 48 ) ;\n            i = i + 1 ;\n        else :\n            hexaDeciNum [ i ] = chr ( temp + 55 ) ;\n            i = i + 1 ;\n        n = int ( n / 16 ) ;\n    j = i - 1 ;\n    while ( j >= 0 ) :\n        print ( ( hexaDeciNum [ j ] ) , end = \"\" ) ;\n        j = j - 1 ;\n", "SMALLEST_SUBARRAY_WITH_ALL_OCCURRENCES_OF_A_MOST_FREQUENT_ELEMENT": "def smallestSubsegment ( a , n ) :\n    left = dict ( )\n    count = dict ( )\n    mx = 0\n    mn , strindex = 0 , 0\n    for i in range ( n ) :\n        x = a [ i ]\n        if ( x not in count.keys ( ) ) :\n            left [ x ] = i\n            count [ x ] = 1\n        else :\n            count [ x ] += 1\n        if ( count [ x ] > mx ) :\n            mx = count [ x ]\n            mn = i - left [ x ] + 1\n            strindex = left [ x ]\n        elif ( count [ x ] == mx and i - left [ x ] + 1 < mn ) :\n            mn = i - left [ x ] + 1\n            strindex = left [ x ]\n    for i in range ( strindex , strindex + mn ) :\n        print ( a [ i ] , end = \" \" )\n", "FIND_LAST_INDEX_CHARACTER_STRING_1": "def findLastIndex ( str , x ) :\n    for i in range ( len ( str ) - 1 , - 1 , - 1 ) :\n        if ( str [ i ] == x ) :\n            return i\n    return - 1\n", "RECAMANS_SEQUENCE": "def recaman ( n ) :\n    arr = [ 0 ] * n\n    arr [ 0 ] = 0\n    print ( arr [ 0 ] , end = \", \" )\n    for i in range ( 1 , n ) :\n        curr = arr [ i - 1 ] - i\n        for j in range ( 0 , i ) :\n            if ( ( arr [ j ] == curr ) or curr < 0 ) :\n                curr = arr [ i - 1 ] + i\n                break\n        arr [ i ] = curr\n        print ( arr [ i ] , end = \", \" )\n", "C_PROGRAM_FIND_SECOND_FREQUENT_CHARACTER": "def getSecondMostFreq ( str ) :\n    NO_OF_CHARS = 256\n    count = [ 0 ] * NO_OF_CHARS\n    for i in range ( len ( str ) ) :\n        count [ ord ( str [ i ] ) ] += 1\n    first , second = 0 , 0\n    for i in range ( NO_OF_CHARS ) :\n        if count [ i ] > count [ first ] :\n            second = first\n            first = i\n        elif ( count [ i ] > count [ second ] and count [ i ] != count [ first ] ) :\n            second = i\n    return chr ( second )\n", "FIND_MAXIMUM_HEIGHT_PYRAMID_FROM_THE_GIVEN_ARRAY_OF_OBJECTS": "def maxLevel ( boxes , n ) :\n    boxes.sort ( )\n    ans = 1\n    prev_width = boxes [ 0 ]\n    prev_count = 1\n    curr_count = 0\n    curr_width = 0\n    for i in range ( 1 , n ) :\n        curr_width += boxes [ i ]\n        curr_count += 1\n        if ( curr_width > prev_width and curr_count > prev_count ) :\n            prev_width = curr_width\n            prev_count = curr_count\n            curr_count = 0\n            curr_width = 0\n            ans += 1\n    return ans\n", "COUNTING_INVERSIONS": "def getInvCount ( arr , n ) :\n    inv_count = 0\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] > arr [ j ] ) :\n                inv_count += 1\n    return inv_count\n", "SQUARES_OF_MATRIX_DIAGONAL_ELEMENTS": "def diagonalsquare ( mat , row , column ) :\n    print ( \"Diagonal one : \" , end = \"\" )\n    for i in range ( 0 , row ) :\n        for j in range ( 0 , column ) :\n            if ( i == j ) :\n                print ( \"{} \".format ( mat [ i ] [ j ] * mat [ i ] [ j ] ) , end = \"\" )\n    print ( \" \\n\\nDiagonal two : \" , end = \"\" )\n    for i in range ( 0 , row ) :\n        for j in range ( 0 , column ) :\n            if ( i + j == column - 1 ) :\n                print ( \"{} \".format ( mat [ i ] [ j ] * mat [ i ] [ j ] ) , end = \"\" )\n", "ROW_WISE_COMMON_ELEMENTS_TWO_DIAGONALS_SQUARE_MATRIX": "def countCommon ( mat , n ) :\n    res = 0\n    for i in range ( n ) :\n        if mat [ i ] [ i ] == mat [ i ] [ n - i - 1 ] :\n            res = res + 1\n    return res\n", "EULERIAN_NUMBER": "def eulerian ( n , m ) :\n    if ( m >= n or n == 0 ) :\n        return 0 ;\n    if ( m == 0 ) :\n        return 1 ;\n    return ( ( n - m ) * eulerian ( n - 1 , m - 1 ) + ( m + 1 ) * eulerian ( n - 1 , m ) )\n", "EULERS_CRITERION_CHECK_IF_SQUARE_ROOT_UNDER_MODULO_P_EXISTS": "def squareRootExists ( n , p ) :\n    n = n % p\n    for x in range ( 2 , p , 1 ) :\n        if ( ( x * x ) % p == n ) :\n            return True\n    return False\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_3": "def numberOfPaths ( m , n ) :\n    for i in range ( n , ( m + n - 1 ) ) :\n        path *= i ;\n        path //= ( i - n + 1 ) ;\n    return path ;\n", "MODIFY_ARRAY_TO_MAXIMIZE_SUM_OF_ADJACENT_DIFFERENCES": "def maximumDifferenceSum ( arr , N ) :\n    dp = [ [ 0 , 0 ] for i in range ( N ) ]\n    for i in range ( N ) :\n        dp [ i ] [ 0 ] = dp [ i ] [ 1 ] = 0\n    for i in range ( N - 1 ) :\n        dp [ i + 1 ] [ 0 ] = max ( dp [ i ] [ 0 ] , dp [ i ] [ 1 ] + abs ( 1 - arr [ i ] ) )\n        dp [ i + 1 ] [ 1 ] = max ( dp [ i ] [ 0 ] + abs ( arr [ i + 1 ] - 1 ) , dp [ i ] [ 1 ] + abs ( arr [ i + 1 ] - arr [ i ] ) )\n    return max ( dp [ N - 1 ] [ 0 ] , dp [ N - 1 ] [ 1 ] )\n", "STERN_BROCOT_SEQUENCE": "def SternSequenceFunc ( BrocotSequence , n ) :\n    for i in range ( 1 , n ) :\n        considered_element = BrocotSequence [ i ]\n        precedent = BrocotSequence [ i - 1 ]\n        BrocotSequence.append ( considered_element + precedent )\n        BrocotSequence.append ( considered_element )\n    for i in range ( 0 , 15 ) :\n        print ( BrocotSequence [ i ] , end = \" \" )\n", "NUMBER_SUBSEQUENCES_STRING_DIVISIBLE_N": "def countDivisibleSubseq ( str , n ) :\n    l = len ( str )\n    dp = [ [ 0 for x in range ( l ) ] for y in range ( n ) ]\n    dp [ 0 ] [ ( ord ( str [ 0 ] ) - ord ( '0' ) ) % n ] += 1\n    for i in range ( 1 , l ) :\n        dp [ i ] [ ( ord ( str [ i ] ) - ord ( '0' ) ) % n ] += 1\n        for j in range ( n ) :\n            dp [ i ] [ j ] += dp [ i - 1 ] [ j ]\n            dp [ i ] [ ( j * 10 + ( ord ( str [ i ] ) - ord ( '0' ) ) ) % n ] += dp [ i - 1 ] [ j ]\n    return dp [ l - 1 ] [ 0 ]\n", "HOW_TO_BEGIN_WITH_COMPETITIVE_PROGRAMMING": "def search ( arr , x ) :\n    n = len ( arr )\n    for j in range ( 0 , n ) :\n        if ( x == arr [ j ] ) :\n            return j\n    return - 1\n", "COUNT_PAIRS_WITH_GIVEN_SUM_1": "def getPairsCount ( arr , n , sum ) :\n    m = [ 0 ] * 1000\n    for i in range ( 0 , n ) :\n        m [ arr [ i ] ]\n        m [ arr [ i ] ] += 1\n    twice_count = 0\n    for i in range ( 0 , n ) :\n        twice_count += m [ sum - arr [ i ] ]\n        if ( sum - arr [ i ] == arr [ i ] ) :\n            twice_count -= 1\n    return int ( twice_count / 2 )\n", "FIND_THE_MINIMUM_DISTANCE_BETWEEN_TWO_NUMBERS": "def minDist ( arr , n , x , y ) :\n    min_dist = 99999999\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if ( x == arr [ i ] and y == arr [ j ] or y == arr [ i ] and x == arr [ j ] ) and min_dist > abs ( i - j ) :\n                min_dist = abs ( i - j )\n        return min_dist\n", "FIND_REPETITIVE_ELEMENT_1_N_1_2": "def findRepeating ( arr , n ) :\n    res = 0\n    for i in range ( 0 , n - 1 ) :\n        res = res ^ ( i + 1 ) ^ arr [ i ]\n    res = res ^ arr [ n - 1 ]\n    return res\n", "SHORTEST_PATH_EXACTLY_K_EDGES_DIRECTED_WEIGHTED_GRAPH_1": "def shortestPath ( graph , u , v , k ) :\n    global V , INF\n    sp = [ [ None ] * V for i in range ( V ) ]\n    for i in range ( V ) :\n        for j in range ( V ) :\n            sp [ i ] [ j ] = [ None ] * ( k + 1 )\n    for e in range ( k + 1 ) :\n        for i in range ( V ) :\n            for j in range ( V ) :\n                sp [ i ] [ j ] [ e ] = INF\n                if ( e == 0 and i == j ) :\n                    sp [ i ] [ j ] [ e ] = 0\n                if ( e == 1 and graph [ i ] [ j ] != INF ) :\n                    sp [ i ] [ j ] [ e ] = graph [ i ] [ j ]\n                if ( e > 1 ) :\n                    for a in range ( V ) :\n                        if ( graph [ i ] [ a ] != INF and i != a and j != a and sp [ a ] [ j ] [ e - 1 ] != INF ) :\n                            sp [ i ] [ j ] [ e ] = min ( sp [ i ] [ j ] [ e ] , graph [ i ] [ a ] + sp [ a ] [ j ] [ e - 1 ] )\n    return sp [ u ] [ v ] [ k ]\n", "LONGEST_SUBARRAY_NOT_K_DISTINCT_ELEMENTS": "def longest ( a , n , k ) :\n    freq = [ 0 ] * n\n    start = 0\n    end = 0\n    now = 0\n    l = 0\n    for i in range ( n ) :\n        freq [ a [ i ] ] += 1\n        if ( freq [ a [ i ] ] == 1 ) :\n            now += 1\n        while ( now > k ) :\n            freq [ a [ l ] ] -= 1\n            if ( freq [ a [ l ] ] == 0 ) :\n                now -= 1\n            l += 1\n        if ( i - l + 1 >= end - start + 1 ) :\n            end = i\n            start = l\n    for i in range ( start , end + 1 ) :\n        print ( a [ i ] , end = \" \" )\n", "MAXIMUM_XOR_VALUE_MATRIX": "def maxXOR ( mat , N ) :\n    max_xor = 0\n    for i in range ( N ) :\n        r_xor = 0\n        c_xor = 0\n        for j in range ( N ) :\n            r_xor = r_xor ^ mat [ i ] [ j ]\n            c_xor = c_xor ^ mat [ j ] [ i ]\n        if ( max_xor < max ( r_xor , c_xor ) ) :\n            max_xor = max ( r_xor , c_xor )\n    return max_xor\n", "LENGTH_LONGEST_SUB_STRING_CAN_MAKE_REMOVED": "def longestNull ( S ) :\n    arr = [ ]\n    arr.append ( [ '@' , - 1 ] )\n    maxlen = 0\n    for i in range ( len ( S ) ) :\n        arr.append ( [ S [ i ] , i ] )\n        while ( len ( arr ) >= 3 and arr [ len ( arr ) - 3 ] [ 0 ] == '1' and arr [ len ( arr ) - 2 ] [ 0 ] == '0' and arr [ len ( arr ) - 1 ] [ 0 ] == '0' ) :\n            arr.pop ( )\n            arr.pop ( )\n            arr.pop ( )\n        tmp = arr [ - 1 ]\n        maxlen = max ( maxlen , i - tmp [ 1 ] )\n    return maxlen\n", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY": "def alternateSubarray ( arr , n ) :\n    len = [ ]\n    for i in range ( n + 1 ) :\n        len.append ( 0 )\n    len [ n - 1 ] = 1\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        if ( arr [ i ] ^ arr [ i + 1 ] == True ) :\n            len [ i ] = len [ i + 1 ] + 1\n        else :\n            len [ i ] = 1\n    for i in range ( n ) :\n        print ( len [ i ] , \"\" , end = \"\" )\n", "WILDCARD_CHARACTER_MATCHING": "def match ( first , second ) :\n    if len ( first ) == 0 and len ( second ) == 0 :\n        return True\n    if len ( first ) > 1 and first [ 0 ] == '*' and len ( second ) == 0 :\n        return False\n    if ( len ( first ) > 1 and first [ 0 ] == '?' ) or ( len ( first ) != 0 and len ( second ) != 0 and first [ 0 ] == second [ 0 ] ) :\n        return match ( first [ 1 : ] , second [ 1 : ] ) ;\n    if len ( first ) != 0 and first [ 0 ] == '*' :\n        return match ( first [ 1 : ] , second ) or match ( first , second [ 1 : ] )\n    return False\n", "FIND_FACTORIAL_NUMBERS_LESS_EQUAL_N": "def printFactorialNums ( n ) :\n    fact = 1\n    x = 2\n    while fact <= n :\n        print ( fact , end = \" \" )\n        fact = fact * x\n        x += 1\n", "FRIENDS_PAIRING_PROBLEM_2": "def countFriendsPairings ( n ) :\n    a , b , c = 1 , 2 , 0 ;\n    if ( n <= 2 ) :\n        return n ;\n    for i in range ( 3 , n + 1 ) :\n        c = b + ( i - 1 ) * a ;\n        a = b ;\n        b = c ;\n    return c ;\n", "FIND_THE_LARGEST_RECTANGLE_OF_1S_WITH_SWAPPING_OF_COLUMNS_ALLOWED": "def maxArea ( mat ) :\n    hist = [ [ 0 for i in range ( C + 1 ) ] for i in range ( R + 1 ) ]\n    for i in range ( 0 , C , 1 ) :\n        hist [ 0 ] [ i ] = mat [ 0 ] [ i ]\n        for j in range ( 1 , R , 1 ) :\n            if ( ( mat [ j ] [ i ] == 0 ) ) :\n                hist [ j ] [ i ] = 0\n            else :\n                hist [ j ] [ i ] = hist [ j - 1 ] [ i ] + 1\n    for i in range ( 0 , R , 1 ) :\n        count = [ 0 for i in range ( R + 1 ) ]\n        for j in range ( 0 , C , 1 ) :\n            count [ hist [ i ] [ j ] ] += 1\n        col_no = 0\n        j = R\n        while ( j >= 0 ) :\n            if ( count [ j ] > 0 ) :\n                for k in range ( 0 , count [ j ] , 1 ) :\n                    hist [ i ] [ col_no ] = j\n                    col_no += 1\n            j -= 1\n    max_area = 0\n    for i in range ( 0 , R , 1 ) :\n        for j in range ( 0 , C , 1 ) :\n            curr_area = ( j + 1 ) * hist [ i ] [ j ]\n            if ( curr_area > max_area ) :\n                max_area = curr_area\n    return max_area\n", "SUM_SEQUENCE_2_22_222": "def sumOfSeries ( n ) :\n    return 0.0246 * ( math.pow ( 10 , n ) - 1 - ( 9 * n ) )\n", "PROGRAM_FIRST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "def firstFit ( blockSize , m , processSize , n ) :\n    allocation = [ - 1 ] * n\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if blockSize [ j ] >= processSize [ i ] :\n                allocation [ i ] = j\n                blockSize [ j ] -= processSize [ i ]\n                break\n    print ( \" Process No.Process Size      Block no.\" )\n    for i in range ( n ) :\n        print ( \" \" , i + 1 , \"         \" , processSize [ i ] , \"         \" , end = \" \" )\n        if allocation [ i ] != - 1 :\n            print ( allocation [ i ] + 1 )\n        else :\n            print ( \"Not Allocated\" )\n", "CHECK_IF_A_NUMBER_IS_POWER_OF_ANOTHER_NUMBER": "def isPower ( x , y ) :\n    if ( x == 1 ) :\n        return ( y == 1 )\n    pow = 1\n    while ( pow < y ) :\n        pow = pow * x\n    return ( pow == y )\n", "DIVIDE_LARGE_NUMBER_REPRESENTED_STRING": "def longDivision ( number , divisor ) :\n    ans = \"\" ;\n    idx = 0 ;\n    temp = ord ( number [ idx ] ) - ord ( '0' ) ;\n    while ( temp < divisor ) :\n        temp = ( temp * 10 + ord ( number [ idx + 1 ] ) - ord ( '0' ) ) ;\n        idx += 1 ;\n    idx += 1 ;\n    while ( ( len ( number ) ) > idx ) :\n        ans += chr ( math.floor ( temp // divisor ) + ord ( '0' ) ) ;\n        temp = ( ( temp % divisor ) * 10 + ord ( number [ idx ] ) - ord ( '0' ) ) ;\n        idx += 1 ;\n    ans += chr ( math.floor ( temp // divisor ) + ord ( '0' ) ) ;\n    if ( len ( ans ) == 0 ) :\n        return \"0\" ;\n    return ans ;\n", "FIND_ROW_NUMBER_BINARY_MATRIX_MAXIMUM_NUMBER_1S": "def findMax ( arr ) :\n    row = 0\n    j = N - 1\n    for i in range ( 0 , N ) :\n        while ( arr [ i ] [ j ] == 1 and j >= 0 ) :\n            row = i\n            j -= 1\n    print ( \"Row number = \" , row + 1 , \", MaxCount = \" , N - 1 - j )\n", "MINIMUM_ROTATIONS_REQUIRED_GET_STRING": "def findRotations ( str ) :\n    tmp = str + str\n    n = len ( str )\n    for i in range ( 1 , n + 1 ) :\n        substring = tmp [ i : n ]\n        if ( str == substring ) :\n            return i\n    return n\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX": "def numberOfPaths ( m , n ) :\n    if ( m == 1 or n == 1 ) :\n        return 1\n    return numberOfPaths ( m - 1 , n ) + numberOfPaths ( m , n - 1 )\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN_1": "def findNth ( n ) :\n    count = 0 ;\n    curr = 19 ;\n    while ( True ) :\n        sum = 0 ;\n        x = curr ;\n        while ( x > 0 ) :\n            sum = sum + x % 10 ;\n            x = int ( x / 10 ) ;\n        if ( sum == 10 ) :\n            count += 1 ;\n        if ( count == n ) :\n            return curr ;\n        curr += 9 ;\n    return - 1 ;\n", "SUM_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING_1": "def sumAtKthLevel ( tree , k , i , level ) :\n    if ( tree [ i [ 0 ] ] == '(' ) :\n        i [ 0 ] += 1\n        if ( tree [ i [ 0 ] ] == ')' ) :\n            return 0\n        sum = 0\n        if ( level == k ) :\n            sum = int ( tree [ i [ 0 ] ] )\n        i [ 0 ] += 1\n        leftsum = sumAtKthLevel ( tree , k , i , level + 1 )\n        i [ 0 ] += 1\n        rightsum = sumAtKthLevel ( tree , k , i , level + 1 )\n        i [ 0 ] += 1\n        return sum + leftsum + rightsum\n", "COUNT_OFDIFFERENT_WAYS_EXPRESS_N_SUM_1_3_4": "def countWays ( n ) :\n    DP = [ 0 for i in range ( 0 , n + 1 ) ]\n    DP [ 0 ] = DP [ 1 ] = DP [ 2 ] = 1\n    DP [ 3 ] = 2\n    for i in range ( 4 , n + 1 ) :\n        DP [ i ] = DP [ i - 1 ] + DP [ i - 3 ] + DP [ i - 4 ]\n    return DP [ n ]\n", "MAXIMUM_EQULIBRIUM_SUM_ARRAY": "def findMaxSum ( arr , n ) :\n    res = - sys.maxsize - 1\n    for i in range ( n ) :\n        prefix_sum = arr [ i ]\n        for j in range ( i ) :\n            prefix_sum += arr [ j ]\n        suffix_sum = arr [ i ]\n        j = n - 1\n        while ( j > i ) :\n            suffix_sum += arr [ j ]\n            j -= 1\n        if ( prefix_sum == suffix_sum ) :\n            res = max ( res , prefix_sum )\n    return res\n", "STEINS_ALGORITHM_FOR_FINDING_GCD_1": "def gcd ( a , b ) :\n    if ( a == b ) :\n        return a\n    if ( a == 0 ) :\n        return b\n    if ( b == 0 ) :\n        return a\n    if ( ( ~ a & 1 ) == 1 ) :\n        if ( ( b & 1 ) == 1 ) :\n            return gcd ( a >> 1 , b )\n        else :\n            return ( gcd ( a >> 1 , b >> 1 ) << 1 )\n    if ( ( ~ b & 1 ) == 1 ) :\n        return gcd ( a , b >> 1 )\n    if ( a > b ) :\n        return gcd ( ( a - b ) >> 1 , b )\n    return gcd ( ( b - a ) >> 1 , a )\n", "PROGRAM_TO_FIND_THE_VOLUME_OF_A_TRIANGULAR_PRISM": "def findVolume ( l , b , h ) :\n    return ( ( l * b * h ) / 2 )\n", "FIND_RECTANGLE_BINARY_MATRIX_CORNERS_1": "def isRectangle ( m ) :\n    rows = len ( m )\n    if ( rows == 0 ) :\n        return False\n    columns = len ( m [ 0 ] )\n    for y1 in range ( rows ) :\n        for x1 in range ( columns ) :\n            if ( m [ y1 ] [ x1 ] == 1 ) :\n                for y2 in range ( y1 + 1 , rows ) :\n                    for x2 in range ( x1 + 1 , columns ) :\n                        if ( m [ y1 ] [ x2 ] == 1 and m [ y2 ] [ x1 ] == 1 and m [ y2 ] [ x2 ] == 1 ) :\n                            return True\n    return False\n", "CHECK_IF_STRING_REMAINS_PALINDROME_AFTER_REMOVING_GIVEN_NUMBER_OF_CHARACTERS": "def isPossible ( str , n ) :\n    l = len ( str )\n    if ( l >= n ) :\n        return True\n    return False\n", "CHECK_STAR_GRAPH": "def checkStar ( mat ) :\n    global size\n    vertexD1 = 0\n    vertexDn_1 = 0\n    if ( size == 1 ) :\n        return ( mat [ 0 ] [ 0 ] == 0 )\n    if ( size == 2 ) :\n        return ( mat [ 0 ] [ 0 ] == 0 and mat [ 0 ] [ 1 ] == 1 and mat [ 1 ] [ 0 ] == 1 and mat [ 1 ] [ 1 ] == 0 )\n    for i in range ( 0 , size ) :\n        degreeI = 0\n        for j in range ( 0 , size ) :\n            if ( mat [ i ] [ j ] ) :\n                degreeI = degreeI + 1\n        if ( degreeI == 1 ) :\n            vertexD1 = vertexD1 + 1\n        elif ( degreeI == size - 1 ) :\n            vertexDn_1 = vertexDn_1 + 1\n    return ( vertexD1 == ( size - 1 ) and vertexDn_1 == 1 )\n", "ROOTS_OF_UNITY": "def printRoots ( n ) :\n    theta = math.pi * 2 / n\n    for k in range ( 0 , n ) :\n        real = math.cos ( k * theta )\n        img = math.sin ( k * theta )\n        print ( real , end = \" \" )\n        if ( img >= 0 ) :\n            print ( \" + i \" , end = \" \" )\n        else :\n            print ( \" - i \" , end = \" \" )\n        print ( abs ( img ) )\n", "FIND_LARGEST_D_IN_ARRAY_SUCH_THAT_A_B_C_D": "def findLargestd ( S , n ) :\n    found = False\n    S.sort ( )\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        for j in range ( 0 , n ) :\n            if ( i == j ) :\n                continue\n            for k in range ( j + 1 , n ) :\n                if ( i == k ) :\n                    continue\n                for l in range ( k + 1 , n ) :\n                    if ( i == l ) :\n                        continue\n                    if ( S [ i ] == S [ j ] + S [ k ] + S [ l ] ) :\n                        found = True\n                        return S [ i ]\n    if ( found == False ) :\n        return - 1\n", "GIVEN_NUMBER_STRING_FIND_NUMBER_CONTIGUOUS_SUBSEQUENCES_RECURSIVELY_ADD_9_SET_2": "def count9s ( number ) :\n    n = len ( number )\n    d = [ 0 for i in range ( 9 ) ]\n    d [ 0 ] = 1\n    result = 0\n    mod_sum = 0\n    continuous_zero = 0\n    for i in range ( n ) :\n        if ( ord ( number [ i ] ) - ord ( '0' ) == 0 ) :\n            continuous_zero += 1\n        else :\n            continuous_zero = 0\n        mod_sum += ord ( number [ i ] ) - ord ( '0' )\n        mod_sum %= 9\n        result += d [ mod_sum ]\n        d [ mod_sum ] += 1\n        result -= continuous_zero\n    return result\n", "LEXICOGRAPHICAL_MAXIMUM_SUBSTRING_STRING": "def LexicographicalMaxString ( str ) :\n    mx = \"\"\n    for i in range ( len ( str ) ) :\n        mx = max ( mx , str [ i : ] )\n    return mx\n", "CHECK_TWO_GIVEN_SETS_DISJOINT_1": "def areDisjoint ( set1 , set2 , m , n ) :\n    set1.sort ( )\n    set2.sort ( )\n    i = 0 ; j = 0\n    while ( i < m and j < n ) :\n        if ( set1 [ i ] < set2 [ j ] ) :\n            i += 1\n        elif ( set2 [ j ] < set1 [ i ] ) :\n            j += 1\n        else :\n            return False\n    return True\n", "EQUILIBRIUM_INDEX_OF_AN_ARRAY_1": "def equilibrium ( arr ) :\n    total_sum = sum ( arr )\n    leftsum = 0\n    for i , num in enumerate ( arr ) :\n        total_sum -= num\n        if leftsum == total_sum :\n            return i\n        leftsum += num\n    return - 1\n", "AREA_CIRCUMSCRIBED_CIRCLE_SQUARE": "def areacircumscribed ( a ) :\n    return ( a * a * ( PI / 2 ) )\n", "LONGEST_REPEATING_AND_NON_OVERLAPPING_SUBSTRING": "def longestRepeatedSubstring ( str ) :\n    n = len ( str )\n    LCSRe = [ [ 0 for x in range ( n + 1 ) ] for y in range ( n + 1 ) ]\n    res = \"\"\n    res_length = 0\n    index = 0\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( i + 1 , n + 1 ) :\n            if ( str [ i - 1 ] == str [ j - 1 ] and LCSRe [ i - 1 ] [ j - 1 ] < ( j - i ) ) :\n                LCSRe [ i ] [ j ] = LCSRe [ i - 1 ] [ j - 1 ] + 1\n                if ( LCSRe [ i ] [ j ] > res_length ) :\n                    res_length = LCSRe [ i ] [ j ]\n                    index = max ( i , index )\n            else :\n                LCSRe [ i ] [ j ] = 0\n    if ( res_length > 0 ) :\n        for i in range ( index - res_length + 1 , index + 1 ) :\n            res = res + str [ i - 1 ]\n    return res\n", "HOW_TO_AVOID_OVERFLOW_IN_MODULAR_MULTIPLICATION": "def mulmod ( a , b , mod ) :\n    res = 0 ;\n    a = a % mod ;\n    while ( b > 0 ) :\n        if ( b % 2 == 1 ) :\n            res = ( res + a ) % mod ;\n        a = ( a * 2 ) % mod ;\n        b //= 2 ;\n    return res % mod ;\n", "PAIR_WITH_GIVEN_PRODUCT_SET_1_FIND_IF_ANY_PAIR_EXISTS_1": "def isProduct ( arr , n , x ) :\n    if n < 2 :\n        return False\n    s = set ( )\n    for i in range ( 0 , n ) :\n        if arr [ i ] == 0 :\n            if x == 0 :\n                return True\n            else :\n                continue\n        if x % arr [ i ] == 0 :\n            if x // arr [ i ] in s :\n                return True\n            s.add ( arr [ i ] )\n    return False\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS": "def kthgroupsum ( k ) :\n    cur = int ( ( k * ( k - 1 ) ) + 1 )\n    sum = 0\n    while k :\n        sum += cur\n        cur += 2\n        k = k - 1\n    return sum\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS_1": "def findElements ( arr , n ) :\n    arr.sort ( )\n    for i in range ( 0 , n - 2 ) :\n        print ( arr [ i ] , end = \" \" )\n", "MINIMUM_STEPS_TO_DELETE_A_STRING_AFTER_REPEATED_DELETION_OF_PALINDROME_SUBSTRINGS": "def minStepToDeleteString ( str ) :\n    N = len ( str )\n    dp = [ [ 0 for x in range ( N + 1 ) ] for y in range ( N + 1 ) ]\n    for l in range ( 1 , N + 1 ) :\n        i = 0\n        j = l - 1\n        while j < N :\n            if ( l == 1 ) :\n                dp [ i ] [ j ] = 1\n            else :\n                dp [ i ] [ j ] = 1 + dp [ i + 1 ] [ j ]\n                if ( str [ i ] == str [ i + 1 ] ) :\n                    dp [ i ] [ j ] = min ( 1 + dp [ i + 2 ] [ j ] , dp [ i ] [ j ] )\n                for K in range ( i + 2 , j + 1 ) :\n                    if ( str [ i ] == str [ K ] ) :\n                        dp [ i ] [ j ] = min ( dp [ i + 1 ] [ K - 1 ] + dp [ K + 1 ] [ j ] , dp [ i ] [ j ] )\n            i += 1\n            j += 1\n    return dp [ 0 ] [ N - 1 ]\n", "CALCULATE_AREA_TETRAHEDRON": "def vol_tetra ( side ) :\n    volume = ( side ** 3 / ( 6 * math.sqrt ( 2 ) ) )\n    return round ( volume , 2 )\n", "SIEVE_OF_ATKIN": "def SieveOfAtkin ( limit ) :\n    if ( limit > 2 ) :\n        print ( 2 , end = \" \" )\n    if ( limit > 3 ) :\n        print ( 3 , end = \" \" )\n    sieve = [ False ] * limit\n    for i in range ( 0 , limit ) :\n        sieve [ i ] = False\n    x = 1\n    while ( x * x < limit ) :\n        y = 1\n        while ( y * y < limit ) :\n            n = ( 4 * x * x ) + ( y * y )\n            if ( n <= limit and ( n % 12 == 1 or n % 12 == 5 ) ) :\n                sieve [ n ] ^= True\n            n = ( 3 * x * x ) + ( y * y )\n            if ( n <= limit and n % 12 == 7 ) :\n                sieve [ n ] ^= True\n            n = ( 3 * x * x ) - ( y * y )\n            if ( x > y and n <= limit and n % 12 == 11 ) :\n                sieve [ n ] ^= True\n            y += 1\n        x += 1\n    r = 5\n    while ( r * r < limit ) :\n        if ( sieve [ r ] ) :\n            for i in range ( r * r , limit , r * r ) :\n                sieve [ i ] = False\n    for a in range ( 5 , limit ) :\n        if ( sieve [ a ] ) :\n            print ( a , end = \" \" )\n", "LENGTH_OF_THE_LONGEST_ARITHMATIC_PROGRESSION_IN_A_SORTED_ARRAY": "def lenghtOfLongestAP ( set , n ) :\n    if ( n <= 2 ) :\n        return n\n    L = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    llap = 2\n    for i in range ( n ) :\n        L [ i ] [ n - 1 ] = 2\n    for j in range ( n - 2 , 0 , - 1 ) :\n        i = j - 1\n        k = j + 1\n        while ( i >= 0 and k <= n - 1 ) :\n            if ( set [ i ] + set [ k ] < 2 * set [ j ] ) :\n                k += 1\n            elif ( set [ i ] + set [ k ] > 2 * set [ j ] ) :\n                L [ i ] [ j ] = 2\n                i -= 1\n            else :\n                L [ i ] [ j ] = L [ j ] [ k ] + 1\n                llap = max ( llap , L [ i ] [ j ] )\n                i -= 1\n                k += 1\n                while ( i >= 0 ) :\n                    L [ i ] [ j ] = 2\n                    i -= 1\n    return llap\n", "COUNT_GROUPINGS_NUMBER_SUM_DIGITS_EVERY_SUB_GROUP_LESS_EQUALS_IMMEDIATE_RIGHT_SUB_GROUP_1": "def countGroups ( position , previous_sum , length , num ) :\n    if ( position == length ) :\n        return 1\n    if ( dp [ position ] [ previous_sum ] != - 1 ) :\n        return dp [ position ] [ previous_sum ]\n    dp [ position ] [ previous_sum ] = 0\n    res = 0\n    sum = 0\n    for i in range ( position , length ) :\n        sum += ( ord ( num [ i ] ) - ord ( '0' ) )\n        if ( sum >= previous_sum ) :\n            res += countGroups ( i + 1 , sum , length , num )\n    dp [ position ] [ previous_sum ] = res\n    return res\n", "LONGEST_SPAN_SUM_TWO_BINARY_ARRAYS_1": "def longestCommonSum ( arr1 , arr2 , n ) :\n    maxLen = 0\n    presum1 = presum2 = 0\n    diff = { }\n    for i in range ( n ) :\n        presum1 += arr1 [ i ]\n        presum2 += arr2 [ i ]\n        curr_diff = presum1 - presum2\n        if curr_diff == 0 :\n            maxLen = i + 1\n        elif curr_diff not in diff :\n            diff [ curr_diff ] = i\n        else :\n            length = i - diff [ curr_diff ]\n            maxLen = max ( maxLen , length )\n    return maxLen\n", "PROGRAM_TO_PRINT_FIRST_N_FIBONACCI_NUMBERS": "def printFibonacciNumbers ( n ) :\n    f1 = 0\n    f2 = 1\n    if ( n < 1 ) :\n        return\n    for x in range ( 0 , n ) :\n        print ( f2 , end = \" \" )\n        next = f1 + f2\n        f1 = f2\n        f2 = next\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY_3": "def maxSubArraySum ( a , size ) :\n    max_so_far = - maxsize - 1\n    max_ending_here = 0\n    start = 0\n    end = 0\n    s = 0\n    for i in range ( 0 , size ) :\n        max_ending_here += a [ i ]\n        if max_so_far < max_ending_here :\n            max_so_far = max_ending_here\n            start = s\n            end = i\n        if max_ending_here < 0 :\n            max_ending_here = 0\n            s = i + 1\n    print ( \"Maximum contiguous sum is %d\" % ( max_so_far ) )\n    print ( \"Starting Index %d\" % ( start ) )\n    print ( \"Ending Index %d\" % ( end ) )\n", "FIND_EQUAL_POINT_STRING_BRACKETS": "def findIndex ( str ) :\n    l = len ( str )\n    open = [ None ] * ( l + 1 )\n    close = [ None ] * ( l + 1 )\n    index = - 1\n    open [ 0 ] = 0\n    close [ l ] = 0\n    if ( str [ 0 ] == '(' ) :\n        open [ 1 ] = 1\n    if ( str [ l - 1 ] == ')' ) :\n        close [ l - 1 ] = 1\n    for i in range ( 1 , l ) :\n        if ( str [ i ] == '(' ) :\n            open [ i + 1 ] = open [ i ] + 1\n        else :\n            open [ i + 1 ] = open [ i ]\n    for i in range ( l - 2 , - 1 , - 1 ) :\n        if ( str [ i ] == ')' ) :\n            close [ i ] = close [ i + 1 ] + 1\n        else :\n            close [ i ] = close [ i + 1 ]\n    if ( open [ l ] == 0 ) :\n        return len\n    if ( close [ 0 ] == 0 ) :\n        return 0\n    for i in range ( l + 1 ) :\n        if ( open [ i ] == close [ i ] ) :\n            index = i\n    return index\n", "COUNT_NUMBER_OF_WAYS_TO_PARTITION_A_SET_INTO_K_SUBSETS_1": "def countP ( n , k ) :\n    dp = [ [ 0 for i in range ( k + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        dp [ i ] [ 0 ] = 0\n    for i in range ( k + 1 ) :\n        dp [ 0 ] [ k ] = 0\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , k + 1 ) :\n            if ( j == 1 or i == j ) :\n                dp [ i ] [ j ] = 1\n            else :\n                dp [ i ] [ j ] = ( j * dp [ i - 1 ] [ j ] + dp [ i - 1 ] [ j - 1 ] )\n    return dp [ n ] [ k ]\n", "LONGEST_INCREASING_SUBSEQUENCE": "def lis ( arr ) :\n    global maximum\n    n = len ( arr )\n    maximum = 1\n    _lis ( arr , n )\n    return maximum\n", "FIND_REPEATED_CHARACTER_PRESENT_FIRST_STRING": "def findRepeatFirstN2 ( s ) :\n    p = - 1\n    for i in range ( len ( s ) ) :\n        for j in range ( i + 1 , len ( s ) ) :\n            if ( s [ i ] == s [ j ] ) :\n                p = i\n                break\n        if ( p != - 1 ) :\n            break\n    return p\n", "K_TH_SMALLEST_ELEMENT_REMOVING_INTEGERS_NATURAL_NUMBERS": "def ksmallest ( arr , n , k ) :\n    b = [ 0 ] * MAX ;\n    for i in range ( n ) :\n        b [ arr [ i ] ] = 1 ;\n    for j in range ( 1 , MAX ) :\n        if ( b [ j ] != 1 ) :\n            k -= 1 ;\n        if ( k is not 1 ) :\n            return j ;\n", "CHECK_IF_STACK_ELEMENTS_ARE_PAIRWISE_CONSECUTIVE": "def pairWiseConsecutive ( s ) :\n    aux = [ ]\n    while ( len ( s ) != 0 ) :\n        aux.append ( s [ - 1 ] )\n        s.pop ( )\n    result = True\n    while ( len ( aux ) > 1 ) :\n        x = aux [ - 1 ]\n        aux.pop ( )\n        y = aux [ - 1 ]\n        aux.pop ( )\n        if ( abs ( x - y ) != 1 ) :\n            result = False\n        s.append ( x )\n        s.append ( y )\n    if ( len ( aux ) == 1 ) :\n        s.append ( aux [ - 1 ] )\n    return result\n", "BINARY_SEARCH_1": "def binarySearch ( arr , l , r , x ) :\n    while l <= r :\n        mid = l + ( r - l ) // 2 ;\n        if arr [ mid ] == x :\n            return mid\n        elif arr [ mid ] < x :\n            l = mid + 1\n        else :\n            r = mid - 1\n    return - 1\n", "COUNT_DISTINCT_OCCURRENCES_AS_A_SUBSEQUENCE": "def findSubsequenceCount ( S , T ) :\n    m = len ( T )\n    n = len ( S )\n    if m > n :\n        return 0\n    mat = [ [ 0 for _ in range ( n + 1 ) ] for __ in range ( m + 1 ) ]\n    for i in range ( 1 , m + 1 ) :\n        mat [ i ] [ 0 ] = 0\n    for j in range ( n + 1 ) :\n        mat [ 0 ] [ j ] = 1\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if T [ i - 1 ] != S [ j - 1 ] :\n                mat [ i ] [ j ] = mat [ i ] [ j - 1 ]\n            else :\n                mat [ i ] [ j ] = ( mat [ i ] [ j - 1 ] + mat [ i - 1 ] [ j - 1 ] )\n    return mat [ m ] [ n ]\n", "SWAP_TWO_NUMBERS_WITHOUT_USING_TEMPORARY_VARIABLE": "def swap ( xp , yp ) :\n    xp [ 0 ] = xp [ 0 ] ^ yp [ 0 ]\n    yp [ 0 ] = xp [ 0 ] ^ yp [ 0 ]\n    xp [ 0 ] = xp [ 0 ] ^ yp [ 0 ]\n", "POLICEMEN_CATCH_THIEVES": "def policeThief ( arr , n , k ) :\n    i = 0\n    l = 0\n    r = 0\n    res = 0\n    thi = [ ]\n    pol = [ ]\n    while i < n :\n        if arr [ i ] == 'P' :\n            pol.append ( i )\n        elif arr [ i ] == 'T' :\n            thi.append ( i )\n        i += 1\n    while l < len ( thi ) and r < len ( pol ) :\n        if ( abs ( thi [ l ] - pol [ r ] ) <= k ) :\n            res += 1\n            l += 1\n            r += 1\n        elif thi [ l ] < pol [ r ] :\n            l += 1\n        else :\n            r += 1\n    return res\n", "LARGEST_SUBARRAY_WITH_EQUAL_NUMBER_OF_0S_AND_1S_1": "def maxLen ( arr , n ) :\n    hash_map = { } ;\n    curr_sum = 0 ;\n    max_len = 0 ;\n    ending_index = - 1 ;\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] == 0 ) :\n            arr [ i ] = - 1 ;\n        else :\n            arr [ i ] = 1 ;\n    for i in range ( 0 , n ) :\n        curr_sum = curr_sum + arr [ i ] ;\n        if ( curr_sum == 0 ) :\n            max_len = i + 1 ;\n            ending_index = i ;\n        if ( curr_sum + n ) in hash_map :\n            max_len = max ( max_len , i - hash_map [ curr_sum + n ] )\n        else :\n            hash_map [ curr_sum ] = i ;\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] == - 1 ) :\n            arr [ i ] = 0 ;\n        else :\n            arr [ i ] = 1 ;\n    print ( ending_index - max_len + 1 , end = \" \" ) ;\n    print ( \"to\" , end = \" \" ) ;\n    print ( ending_index ) ;\n    return max_len ;\n", "MAXIMUM_DIFFERENCE_ZEROS_ONES_BINARY_STRING_SET_2_TIME": "def findLength ( string , n ) :\n    current_sum = 0\n    max_sum = 0\n    for i in range ( n ) :\n        current_sum += ( 1 if string [ i ] == '0' else - 1 )\n        if current_sum < 0 :\n            current_sum = 0\n        max_sum = max ( current_sum , max_sum )\n    return max_sum if max_sum else 0\n", "MAXIMUM_CONSECUTIVE_NUMBERS_PRESENT_ARRAY": "def findLongestConseqSubseq ( arr , n ) :\n    S = set ( ) ;\n    for i in range ( n ) :\n        S.add ( arr [ i ] ) ;\n    ans = 0 ;\n    for i in range ( n ) :\n        if S.__contains__ ( arr [ i ] ) :\n            j = arr [ i ] ;\n            while ( S.__contains__ ( j ) ) :\n                j += 1 ;\n            ans = max ( ans , j - arr [ i ] ) ;\n    return ans ;\n", "LEXICOGRAPHICALLY_NEXT_STRING": "def nextWord ( s ) :\n    if ( s == \" \" ) :\n        return \"a\"\n    i = len ( s ) - 1\n    while ( s [ i ] == 'z' and i >= 0 ) :\n        i -= 1\n    if ( i == - 1 ) :\n        s = s + 'a'\n    else :\n        s = s.replace ( s [ i ] , chr ( ord ( s [ i ] ) + 1 ) , 1 )\n    return s\n", "SCHEDULE_JOBS_SERVER_GETS_EQUAL_LOAD": "def solve ( a , b , n ) :\n    s = 0\n    for i in range ( 0 , n ) :\n        s += a [ i ] + b [ i ]\n    if n == 1 :\n        return a [ 0 ] + b [ 0 ]\n    if s % n != 0 :\n        return - 1\n    x = s // n\n    for i in range ( 0 , n ) :\n        if a [ i ] > x :\n            return - 1\n        if i > 0 :\n            a [ i ] += b [ i - 1 ]\n            b [ i - 1 ] = 0\n        if a [ i ] == x :\n            continue\n        y = a [ i ] + b [ i ]\n        if i + 1 < n :\n            y += b [ i + 1 ]\n        if y == x :\n            a [ i ] = y\n            b [ i ] = 0\n            if i + 1 < n : b [ i + 1 ] = 0\n            continue\n        if a [ i ] + b [ i ] == x :\n            a [ i ] += b [ i ]\n            b [ i ] = 0\n            continue\n        if i + 1 < n and a [ i ] + b [ i + 1 ] == x :\n            a [ i ] += b [ i + 1 ]\n            b [ i + 1 ] = 0\n            continue\n        return - 1\n    for i in range ( 0 , n ) :\n        if b [ i ] != 0 :\n            return - 1\n    return x\n", "FORM_MINIMUM_NUMBER_FROM_GIVEN_SEQUENCE_1": "def getMinNumberForPattern ( seq ) :\n    n = len ( seq )\n    if ( n >= 9 ) :\n        return \"-1\"\n    result = [ None ] * ( n + 1 )\n    count = 1\n    for i in range ( n + 1 ) :\n        if ( i == n or seq [ i ] == 'I' ) :\n            for j in range ( i - 1 , - 2 , - 1 ) :\n                result [ j + 1 ] = int ( '0' + str ( count ) )\n                count += 1\n                if ( j >= 0 and seq [ j ] == 'I' ) :\n                    break\n    return result\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE": "def shuffleArray ( a , n ) :\n    i , q , k = 0 , 1 , n\n    while ( i < n ) :\n        j = k\n        while ( j > i + q ) :\n            a [ j - 1 ] , a [ j ] = a [ j ] , a [ j - 1 ]\n            j -= 1\n        i += 1\n        k += 1\n        q += 1\n", "FIND_REPETITIVE_ELEMENT_1_N_1_1": "def findRepeating ( arr , n ) :\n    s = set ( )\n    for i in range ( n ) :\n        if arr [ i ] in s :\n            return arr [ i ]\n        s.add ( arr [ i ] )\n    rteurn - 1\n", "C_PROGRAM_SUBTRACTION_MATICES": "def multiply ( A , B , C ) :\n    for i in range ( N ) :\n        for j in range ( N ) :\n            C [ i ] [ j ] = A [ i ] [ j ] - B [ i ] [ j ]\n", "FIRST_NEGATIVE_INTEGER_EVERY_WINDOW_SIZE_K": "def printFirstNegativeInteger ( arr , n , k ) :\n    for i in range ( 0 , ( n - k + 1 ) ) :\n        flag = False\n        for j in range ( 0 , k ) :\n            if ( arr [ i + j ] < 0 ) :\n                print ( arr [ i + j ] , end = \" \" )\n                flag = True\n                break\n        if ( not ( flag ) ) :\n            print ( \"0\" , end = \" \" )\n", "NUMBER_FULL_BINARY_TREES_NODE_PRODUCT_CHILDREN": "def numoffbt ( arr , n ) :\n    maxvalue = - 2147483647\n    minvalue = 2147483647\n    for i in range ( n ) :\n        maxvalue = max ( maxvalue , arr [ i ] )\n        minvalue = min ( minvalue , arr [ i ] )\n    mark = [ 0 for i in range ( maxvalue + 2 ) ]\n    value = [ 0 for i in range ( maxvalue + 2 ) ]\n    for i in range ( n ) :\n        mark [ arr [ i ] ] = 1\n        value [ arr [ i ] ] = 1\n    ans = 0\n    for i in range ( minvalue , maxvalue + 1 ) :\n        if ( mark [ i ] != 0 ) :\n            j = i + i\n            while ( j <= maxvalue and j // i <= i ) :\n                if ( mark [ j ] == 0 ) :\n                    continue\n                value [ j ] = value [ j ] + ( value [ i ] * value [ j // i ] )\n                if ( i != j // i ) :\n                    value [ j ] = value [ j ] + ( value [ i ] * value [ j // i ] )\n                j += i\n        ans += value [ i ]\n    return ans\n", "TRIANGULAR_MATCHSTICK_NUMBER": "def numberOfSticks ( x ) :\n    return ( 3 * x * ( x + 1 ) ) / 2\n", "K_MAXIMUM_SUM_COMBINATIONS_TWO_ARRAYS": "def KMaxCombinations ( A , B , N , K ) :\n    pq = PriorityQueue ( )\n    for i in range ( 0 , N ) :\n        for j in range ( 0 , N ) :\n            a = A [ i ] + B [ j ]\n            pq.put ( ( - a , a ) )\n    count = 0\n    while ( count < K ) :\n        print ( pq.get ( ) [ 1 ] )\n        count = count + 1\n", "CONSTRUCT_ARRAY_PAIR_SUM_ARRAY": "def constructArr ( arr , pair , n ) :\n    arr [ 0 ] = ( pair [ 0 ] + pair [ 1 ] - pair [ n - 1 ] ) // 2\n    for i in range ( 1 , n ) :\n        arr [ i ] = pair [ i - 1 ] - arr [ 0 ]\n", "CHECK_HALF_STRING_CHARACTER_FREQUENCY_CHARACTER": "def checkCorrectOrNot ( s ) :\n    global MAX_CHAR\n    count1 = [ 0 ] * MAX_CHAR\n    count2 = [ 0 ] * MAX_CHAR\n    n = len ( s )\n    if n == 1 :\n        return true\n    i = 0 ; j = n - 1\n    while ( i < j ) :\n        count1 [ ord ( s [ i ] ) - ord ( 'a' ) ] += 1\n        count2 [ ord ( s [ j ] ) - ord ( 'a' ) ] += 1\n        i += 1 ; j -= 1\n    for i in range ( MAX_CHAR ) :\n        if count1 [ i ] != count2 [ i ] :\n            return False\n    return True\n", "MINIMIZE_THE_MAXIMUM_DIFFERENCE_BETWEEN_THE_HEIGHTS": "def getMinDiff ( arr , n , k ) :\n    if ( n == 1 ) :\n        return 0\n    arr.sort ( )\n    ans = arr [ n - 1 ] - arr [ 0 ]\n    small = arr [ 0 ] + k\n    big = arr [ n - 1 ] - k\n    if ( small > big ) :\n        small , big = big , small\n    for i in range ( 1 , n - 1 ) :\n        subtract = arr [ i ] - k\n        add = arr [ i ] + k\n        if ( subtract >= small or add <= big ) :\n            continue\n        if ( big - subtract <= add - small ) :\n            small = subtract\n        else :\n            big = add\n    return min ( ans , big - small )\n", "MINIMUM_POSSIBLE_VALUE_AI_AJ_K_GIVEN_ARRAY_K": "def pairs ( arr , n , k ) :\n    smallest = 999999999999\n    count = 0\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if abs ( arr [ i ] + arr [ j ] - k ) < smallest :\n                smallest = abs ( arr [ i ] + arr [ j ] - k )\n                count = 1\n            elif abs ( arr [ i ] + arr [ j ] - k ) == smallest :\n                count += 1\n    print ( \"Minimal Value = \" , smallest )\n    print ( \"Total Pairs = \" , count )\n", "SIZE_SUBARRAY_MAXIMUM_SUM": "def maxSubArraySum ( a , size ) :\n    max_so_far = - maxsize - 1\n    max_ending_here = 0\n    start = 0\n    end = 0\n    s = 0\n    for i in range ( 0 , size ) :\n        max_ending_here += a [ i ]\n        if max_so_far < max_ending_here :\n            max_so_far = max_ending_here\n            start = s\n            end = i\n        if max_ending_here < 0 :\n            max_ending_here = 0\n            s = i + 1\n    return ( end - start + 1 )\n", "MINIMUM_NUMBER_OF_SQUARES_WHOSE_SUM_EQUALS_TO_GIVEN_NUMBER_N_1": "def getMinSquares ( n ) :\n    dp = [ 0 , 1 , 2 , 3 ]\n    for i in range ( 4 , n + 1 ) :\n        dp.append ( i )\n        for x in range ( 1 , int ( ceil ( sqrt ( i ) ) ) + 1 ) :\n            temp = x * x ;\n            if temp > i :\n                break\n            else :\n                dp [ i ] = min ( dp [ i ] , 1 + dp [ i - temp ] )\n    return dp [ n ]\n", "DIVISIBILITY_BY_7": "def isDivisibleBy7 ( num ) :\n    if num < 0 :\n        return isDivisibleBy7 ( - num )\n    if ( num == 0 or num == 7 ) :\n        return True\n    if ( num < 10 ) :\n        return False\n    return isDivisibleBy7 ( num / 10 - 2 * ( num - num / 10 * 10 ) )\n", "POSITION_OF_RIGHTMOST_SET_BIT_2": "def Right_most_setbit ( num ) :\n    pos = 1\n    for i in range ( INT_SIZE ) :\n        if not ( num & ( 1 << i ) ) :\n            pos += 1\n        else :\n            break\n    return pos\n", "EFFICIENT_WAY_TO_MULTIPLY_WITH_7": "def multiplyBySeven ( n ) :\n    return ( ( n << 3 ) - n )\n", "NEXT_HIGHER_NUMBER_WITH_SAME_NUMBER_OF_SET_BITS": "def snoob ( x ) :\n    next = 0\n    if ( x ) :\n        rightOne = x & - ( x )\n        nextHigherOneBit = x + int ( rightOne )\n        rightOnesPattern = x ^ int ( nextHigherOneBit )\n        rightOnesPattern = ( int ( rightOnesPattern ) / int ( rightOne ) )\n        rightOnesPattern = int ( rightOnesPattern ) >> 2\n        next = nextHigherOneBit | rightOnesPattern\n    return next\n", "CHANGE_ARRAY_PERMUTATION_NUMBERS_1_N": "def makePermutation ( a , n ) :\n    count = dict ( )\n    for i in range ( n ) :\n        if count.get ( a [ i ] ) :\n            count [ a [ i ] ] += 1\n        else :\n            count [ a [ i ] ] = 1 ;\n    next_missing = 1\n    for i in range ( n ) :\n        if count [ a [ i ] ] != 1 or a [ i ] > n or a [ i ] < 1 :\n            count [ a [ i ] ] -= 1\n            while count.get ( next_missing ) :\n                next_missing += 1\n            a [ i ] = next_missing\n            count [ next_missing ] = 1\n", "MAXIMUM_AREA_QUADRILATERAL": "def maxArea ( a , b , c , d ) :\n    semiperimeter = ( a + b + c + d ) / 2\n    return math.sqrt ( ( semiperimeter - a ) * ( semiperimeter - b ) * ( semiperimeter - c ) * ( semiperimeter - d ) )\n", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE_1": "def translate ( st ) :\n    l = len ( st )\n    if ( l < 2 ) :\n        return\n    i = 0\n    j = 0\n    while ( j < l - 1 ) :\n        if ( st [ j ] == 'A' and st [ j + 1 ] == 'B' ) :\n            j += 2\n            st [ i ] = 'C'\n            i += 1\n            continue\n        st [ i ] = st [ j ]\n        i += 1\n        j += 1\n    if ( j == l - 1 ) :\n        st [ i ] = st [ j ]\n        i += 1\n    st [ i ] = ' '\n    st [ l - 1 ] = ' '\n", "FIND_POWER_POWER_MOD_PRIME": "def calculate ( A , B , C , M ) :\n    res = pow ( B , C , M - 1 )\n    ans = pow ( A , res , M )\n    return ans\n", "CHECK_EXIST_TWO_ELEMENTS_ARRAY_WHOSE_SUM_EQUAL_SUM_REST_ARRAY": "def checkPair ( arr , n ) :\n    s = set ( )\n    sum = 0\n    for i in range ( n ) :\n        sum += arr [ i ]\n    if sum % 2 != 0 :\n        return False\n    sum = sum / 2\n    for i in range ( n ) :\n        val = sum - arr [ i ]\n        if arr [ i ] not in s :\n            s.add ( arr [ i ] )\n        if val in s :\n            print ( \"Pair elements are\" , arr [ i ] , \"and\" , int ( val ) )\n", "PROGRAM_FOR_SURFACE_AREA_OF_OCTAHEDRON": "def surface_area_octahedron ( side ) :\n    return ( 2 * ( math.sqrt ( 3 ) ) * ( side * side ) )\n", "FIND_A_SPECIFIC_PAIR_IN_MATRIX": "def findMaxValue ( mat ) :\n    maxValue = 0\n    for a in range ( N - 1 ) :\n        for b in range ( N - 1 ) :\n            for d in range ( a + 1 , N ) :\n                for e in range ( b + 1 , N ) :\n                    if maxValue < int ( mat [ d ] [ e ] - mat [ a ] [ b ] ) :\n                        maxValue = int ( mat [ d ] [ e ] - mat [ a ] [ b ] ) ;\n    return maxValue ;\n", "MULTIPLY_TWO_NUMBERS_WITHOUT_USING_MULTIPLY_DIVISION_BITWISE_OPERATORS_AND_NO_LOOPS": "def multiply ( x , y ) :\n    if ( y == 0 ) :\n        return 0\n    if ( y > 0 ) :\n        return ( x + multiply ( x , y - 1 ) )\n    if ( y < 0 ) :\n        return - multiply ( x , - y )\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_1": "def findTriplets ( arr , n ) :\n    found = False\n    for i in range ( n - 1 ) :\n        s = set ( )\n        for j in range ( i + 1 , n ) :\n            x = - ( arr [ i ] + arr [ j ] )\n            if x in s :\n                print ( x , arr [ i ] , arr [ j ] )\n                found = True\n            else :\n                s.add ( arr [ j ] )\n    if found == False :\n        print ( \"No Triplet Found\" )\n", "FIND_MAXIMUM_VALUE_OF_SUM_IARRI_WITH_ONLY_ROTATIONS_ON_GIVEN_ARRAY_ALLOWED": "def maxSum ( arr ) :\n    arrSum = 0\n    currVal = 0\n    n = len ( arr )\n    for i in range ( 0 , n ) :\n        arrSum = arrSum + arr [ i ]\n        currVal = currVal + ( i * arr [ i ] )\n    maxVal = currVal\n    for j in range ( 1 , n ) :\n        currVal = currVal + arrSum - n * arr [ n - j ]\n        if currVal > maxVal :\n            maxVal = currVal\n    return maxVal\n", "PROGRAM_FOR_SCALAR_MULTIPLICATION_OF_A_MATRIX": "def scalarProductMat ( mat , k ) :\n    for i in range ( N ) :\n        for j in range ( N ) :\n            mat [ i ] [ j ] = mat [ i ] [ j ] * k\n", "PRINT_SQUARES_FIRST_N_NATURAL_NUMBERS_WITHOUT_USING_1": "def printSquares ( n ) :\n    square = 0\n    odd = 1\n    for x in range ( 0 , n ) :\n        print ( square , end = \" \" )\n        square = square + odd\n        odd = odd + 2\n", "NTH_PENTAGONAL_NUMBER": "def pentagonalNum ( n ) :\n    return ( 3 * n * n - n ) / 2\n", "COUNT_ARRAYS_ADJACENT_ELEMENTS_ONE_DIVIDE_ANOTHER": "def numofArray ( n , m ) :\n    dp = [ [ 0 for i in range ( MAX ) ] for j in range ( MAX ) ]\n    di = [ [ ] for i in range ( MAX ) ]\n    mu = [ [ ] for i in range ( MAX ) ]\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 2 * i , m + 1 , i ) :\n            di [ j ].append ( i )\n            mu [ i ].append ( j )\n        di [ i ].append ( i )\n    for i in range ( 1 , m + 1 ) :\n        dp [ 1 ] [ i ] = 1\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( 1 , m + 1 ) :\n            dp [ i ] [ j ] = 0\n            for x in di [ j ] :\n                dp [ i ] [ j ] += dp [ i - 1 ] [ x ]\n            for x in mu [ j ] :\n                dp [ i ] [ j ] += dp [ i - 1 ] [ x ]\n    ans = 0\n    for i in range ( 1 , m + 1 ) :\n        ans += dp [ n ] [ i ]\n        di [ i ].clear ( )\n        mu [ i ].clear ( )\n    return ans\n", "0_1_KNAPSACK_PROBLEM_DP_10": "def knapSack ( W , wt , val , n ) :\n    if n == 0 or W == 0 :\n        return 0\n    if ( wt [ n - 1 ] > W ) :\n        return knapSack ( W , wt , val , n - 1 )\n    else :\n        return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ] , wt , val , n - 1 ) , knapSack ( W , wt , val , n - 1 ) )\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO": "def findTriplets ( arr , n ) :\n    found = True\n    for i in range ( 0 , n - 2 ) :\n        for j in range ( i + 1 , n - 1 ) :\n            for k in range ( j + 1 , n ) :\n                if ( arr [ i ] + arr [ j ] + arr [ k ] == 0 ) :\n                    print ( arr [ i ] , arr [ j ] , arr [ k ] )\n                    found = True\n    if ( found == False ) :\n        print ( \" not exist \" )\n", "COUNT_NUMBER_WAYS_REACH_GIVEN_SCORE_GAME": "def count ( n ) :\n    table = [ 0 for i in range ( n + 1 ) ]\n    table [ 0 ] = 1\n    for i in range ( 3 , n + 1 ) :\n        table [ i ] += table [ i - 3 ]\n    for i in range ( 5 , n + 1 ) :\n        table [ i ] += table [ i - 5 ]\n    for i in range ( 10 , n + 1 ) :\n        table [ i ] += table [ i - 10 ]\n    return table [ n ]\n", "MAXIMUM_SUM_ABSOLUTE_DIFFERENCE_ARRAY": "def MaxSumDifference ( a , n ) :\n    np.sort ( a ) ;\n    j = 0\n    finalSequence = [ 0 for x in range ( n ) ]\n    for i in range ( 0 , int ( n / 2 ) ) :\n        finalSequence [ j ] = a [ i ]\n        finalSequence [ j + 1 ] = a [ n - i - 1 ]\n        j = j + 2\n    MaximumSum = 0\n    for i in range ( 0 , n - 1 ) :\n        MaximumSum = ( MaximumSum + abs ( finalSequence [ i ] - finalSequence [ i + 1 ] ) )\n    MaximumSum = ( MaximumSum + abs ( finalSequence [ n - 1 ] - finalSequence [ 0 ] ) ) ;\n    print ( MaximumSum )\n", "PROGRAM_FIND_MID_POINT_LINE": "def midpoint ( x1 , x2 , y1 , y2 ) :\n    print ( ( x1 + x2 ) // 2 , \" , \" , ( y1 + y2 ) // 2 )\n", "ALTERNATIVE_SORTING": "def alternateSort ( arr , n ) :\n    arr.sort ( )\n    i = 0\n    j = n - 1\n    while ( i < j ) :\n        print ( arr [ j ] , end = \" \" )\n        j -= 1\n        print ( arr [ i ] , end = \" \" )\n        i += 1\n    if ( n % 2 != 0 ) :\n        print ( arr [ i ] )\n", "NUMBER_SUBARRAYS_SUM_EXACTLY_EQUAL_K": "def findSubarraySum ( arr , n , Sum ) :\n    prevSum = defaultdict ( lambda : 0 )\n    res = 0\n    currsum = 0\n    for i in range ( 0 , n ) :\n        currsum += arr [ i ]\n        if currsum == Sum :\n            res += 1\n        if ( currsum - Sum ) in prevSum :\n            res += prevSum [ currsum - Sum ]\n        prevSum [ currsum ] += 1\n    return res\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_IN_A_SORTED_ARRAY": "def search ( arr , low , high ) :\n    if low > high :\n        return None\n    if low == high :\n        return arr [ low ]\n    mid = low + ( high - low ) / 2\n    if mid % 2 == 0 :\n        if arr [ mid ] == arr [ mid + 1 ] :\n            return search ( arr , mid + 2 , high )\n        else :\n            return search ( arr , low , mid )\n    else :\n        if arr [ mid ] == arr [ mid - 1 ] :\n            return search ( arr , mid + 1 , high )\n        else :\n            return search ( arr , low , mid - 1 )\n", "FORM_SMALLEST_NUMBER_USING_ONE_SWAP_OPERATION": "def smallestNumber ( num ) :\n    num = list ( num )\n    n = len ( num )\n    rightMin = [ 0 ] * n\n    right = 0\n    rightMin [ n - 1 ] = - 1 ;\n    right = n - 1 ;\n    for i in range ( n - 2 , 0 , - 1 ) :\n        if num [ i ] > num [ right ] :\n            rightMin [ i ] = right\n        else :\n            rightMin [ i ] = - 1\n            right = i\n    small = - 1\n    for i in range ( 1 , n ) :\n        if num [ i ] != '0' :\n            if small == - 1 :\n                if num [ i ] < num [ 0 ] :\n                    small = i\n            elif num [ i ] < num [ small ] :\n                small = i\n    if small != - 1 :\n        num [ 0 ] , num [ small ] = num [ small ] , num [ 0 ]\n    else :\n        for i in range ( 1 , n ) :\n            if rightMin [ i ] != - 1 :\n                num [ i ] , num [ rightMin [ i ] ] = num [ rightMin [ i ] ] , num [ i ]\n                break\n    return ''.join ( num )\n", "PROGRAM_AREA_SQUARE": "def areaSquare ( side ) :\n    area = side * side\n    return area\n", "FIND_DAY_OF_THE_WEEK_FOR_A_GIVEN_DATE": "def dayofweek ( d , m , y ) :\n    t = [ 0 , 3 , 2 , 5 , 0 , 3 , 5 , 1 , 4 , 6 , 2 , 4 ]\n    y -= m < 3\n    return ( ( y + int ( y / 4 ) - int ( y / 100 ) + int ( y / 400 ) + t [ m - 1 ] + d ) % 7 )\n", "CHECK_QUEUE_CAN_SORTED_ANOTHER_QUEUE_USING_STACK": "def checkSorted ( n , q ) :\n    st = [ ]\n    expected = 1\n    fnt = None\n    while ( not q.empty ( ) ) :\n        fnt = q.queue [ 0 ]\n        q.get ( )\n        if ( fnt == expected ) :\n            expected += 1\n        else :\n            if ( len ( st ) == 0 ) :\n                st.append ( fnt )\n            elif ( len ( st ) != 0 and st [ - 1 ] < fnt ) :\n                return False\n            else :\n                st.append ( fnt )\n        while ( len ( st ) != 0 and st [ - 1 ] == expected ) :\n            st.pop ( )\n            expected += 1\n    if ( expected - 1 == n and len ( st ) == 0 ) :\n        return True\n    return False\n", "SORT_ARRAY_CONTAIN_1_N_VALUES": "def sortit ( arr , n ) :\n    for i in range ( n ) :\n        arr [ i ] = i + 1\n", "LCS_LONGEST_COMMON_SUBSEQUENCE_THREE_STRINGS_1": "def lcsOf3 ( i , j , k ) :\n    if ( i == - 1 or j == - 1 or k == - 1 ) :\n        return 0\n    if ( dp [ i ] [ j ] [ k ] != - 1 ) :\n        return dp [ i ] [ j ] [ k ]\n    if ( X [ i ] == Y [ j ] and Y [ j ] == Z [ k ] ) :\n        dp [ i ] [ j ] [ k ] = 1 + lcsOf3 ( i - 1 , j - 1 , k - 1 )\n        return dp [ i ] [ j ] [ k ]\n    else :\n        dp [ i ] [ j ] [ k ] = max ( max ( lcsOf3 ( i - 1 , j , k ) , lcsOf3 ( i , j - 1 , k ) ) , lcsOf3 ( i , j , k - 1 ) )\n        return dp [ i ] [ j ] [ k ]\n", "LOWER_INSERTION_POINT": "def LowerInsertionPoint ( arr , n , X ) :\n    if ( X < arr [ 0 ] ) :\n        return 0 ;\n    elif ( X > arr [ n - 1 ] ) :\n        return n\n    lowerPnt = 0\n    i = 1\n    while ( i < n and arr [ i ] < X ) :\n        lowerPnt = i\n        i = i * 2\n    while ( lowerPnt < n and arr [ lowerPnt ] < X ) :\n        lowerPnt += 1\n    return lowerPnt\n", "CONSTRUCT_LEXICOGRAPHICALLY_SMALLEST_PALINDROME": "def constructPalin ( string , l ) :\n    string = list ( string )\n    i = - 1\n    j = l\n    while i < j :\n        i += 1\n        j -= 1\n        if ( string [ i ] == string [ j ] and string [ i ] != '*' ) :\n            continue\n        elif ( string [ i ] == string [ j ] and string [ i ] == '*' ) :\n            string [ i ] = 'a'\n            string [ j ] = 'a'\n            continue\n        elif string [ i ] == '*' :\n            string [ i ] = string [ j ]\n            continue\n        elif string [ j ] == '*' :\n            string [ j ] = string [ i ]\n            continue\n        print ( \"Not Possible\" )\n        return \"\"\n    return ''.join ( string )\n", "SECTION_FORMULA_POINT_DIVIDES_LINE_GIVEN_RATIO": "def section ( x1 , x2 , y1 , y2 , m , n ) :\n    x = ( float ) ( ( n * x1 ) + ( m * x2 ) ) / ( m + n )\n    y = ( float ) ( ( n * y1 ) + ( m * y2 ) ) / ( m + n )\n    print ( x , y )\n", "SQUARE_ROOT_NUMBER_USING_LOG": "def squareRoot ( n ) :\n    return pow ( 2 , 0.5 * math.log2 ( n ) )\n", "MAXIMIZE_SUM_ARRII": "def maxSum ( arr , n ) :\n    arr.sort ( )\n    sum = 0\n    for i in range ( n ) :\n        sum += arr [ i ] * i\n    return sum\n", "STRING_K_DISTINCT_CHARACTERS_NO_CHARACTERS_ADJACENT": "def findString ( n , k ) :\n    res = \"\"\n    for i in range ( k ) :\n        res = res + chr ( ord ( 'a' ) + i )\n    count = 0\n    for i in range ( n - k ) :\n        res = res + chr ( ord ( 'a' ) + count )\n        count += 1\n        if ( count == k ) :\n            count = 0 ;\n    return res\n", "COUNT_WORDS_WHOSE_TH_LETTER_EITHER_1_TH_TH_I1_TH_LETTER_GIVEN_WORD": "def countWords ( str , l ) :\n    count = 1 ;\n    if ( l == 1 ) :\n        return count\n    if ( str [ 0 ] == str [ 1 ] ) :\n        count *= 1\n    else :\n        count *= 2\n    for j in range ( 1 , l - 1 ) :\n        if ( str [ j ] == str [ j - 1 ] and str [ j ] == str [ j + 1 ] ) :\n            count *= 1\n        elif ( str [ j ] == str [ j - 1 ] or str [ j ] == str [ j + 1 ] or str [ j - 1 ] == str [ j + 1 ] ) :\n            count *= 2\n        else :\n            count *= 3\n    if ( str [ l - 1 ] == str [ l - 2 ] ) :\n        count *= 1\n    else :\n        count *= 2\n    return count\n", "NUMBER_JUMP_REQUIRED_GIVEN_LENGTH_REACH_POINT_FORM_D_0_ORIGIN_2D_PLANE": "def minJumps ( a , b , d ) :\n    temp = a\n    a = min ( a , b )\n    b = max ( temp , b )\n    if ( d >= b ) :\n        return ( d + b - 1 ) / b\n    if ( d == 0 ) :\n        return 0\n    if ( d == a ) :\n        return 1\n    return 2\n", "SUM_FACTORS_NUMBER_1": "def sumofFactors ( n ) :\n    res = 1\n    for i in range ( 2 , int ( m.sqrt ( n ) + 1 ) ) :\n        curr_sum = 1\n        curr_term = 1\n        while n % i == 0 :\n            n = n / i ;\n            curr_term = curr_term * i ;\n            curr_sum += curr_term ;\n        res = res * curr_sum\n    if n > 2 :\n        res = res * ( 1 + n )\n    return res ;\n", "DELETE_CONSECUTIVE_WORDS_SEQUENCE": "def removeConsecutiveSame ( v ) :\n    n = len ( v )\n    i = 0\n    while ( i < n - 1 ) :\n        if ( ( i + 1 ) < len ( v ) ) and ( v [ i ] == v [ i + 1 ] ) :\n            v = v [ : i ]\n            v = v [ : i ]\n            if ( i > 0 ) :\n                i -= 1\n            n = n - 2\n        else :\n            i += 1\n    return len ( v [ : i - 1 ] )\n", "COUNT_NUMBER_BINARY_STRINGS_WITHOUT_CONSECUTIVE_1S": "def countStrings ( n ) :\n    a = [ 0 for i in range ( n ) ]\n    b = [ 0 for i in range ( n ) ]\n    a [ 0 ] = b [ 0 ] = 1\n    for i in range ( 1 , n ) :\n        a [ i ] = a [ i - 1 ] + b [ i - 1 ]\n        b [ i ] = a [ i - 1 ]\n    return a [ n - 1 ] + b [ n - 1 ]\n", "FIND_THE_MISSING_NUMBER": "def getMissingNo ( A ) :\n    n = len ( A )\n    total = ( n + 1 ) * ( n + 2 ) / 2\n    sum_of_A = sum ( A )\n    return total - sum_of_A\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE": "def squareRoot ( n ) :\n    x = n\n    y = 1\n    e = 0.000001\n    while ( x - y > e ) :\n        x = ( x + y ) / 2\n        y = n / x\n    return x\n", "SUBSET_SUM_PROBLEM_OSUM_SPACE": "def isSubsetSum ( arr , n , sum ) :\n    subset = [ [ False for j in range ( sum + 1 ) ] for i in range ( 3 ) ]\n    for i in range ( n + 1 ) :\n        for j in range ( sum + 1 ) :\n            if ( j == 0 ) :\n                subset [ i % 2 ] [ j ] = True\n            elif ( i == 0 ) :\n                subset [ i % 2 ] [ j ] = False\n            elif ( arr [ i - 1 ] <= j ) :\n                subset [ i % 2 ] [ j ] = subset [ ( i + 1 ) % 2 ] [ j - arr [ i - 1 ] ] or subset [ ( i + 1 ) % 2 ] [ j ]\n            else :\n                subset [ i % 2 ] [ j ] = subset [ ( i + 1 ) % 2 ] [ j ]\n    return subset [ n % 2 ] [ sum ]\n", "MULTIPLICATIVE_INVERSE_UNDER_MODULO_M": "def modInverse ( a , m ) :\n    a = a % m ;\n    for x in range ( 1 , m ) :\n        if ( ( a * x ) % m == 1 ) :\n            return x\n    return 1\n", "COMPUTE_AVERAGE_TWO_NUMBERS_WITHOUT_OVERFLOW": "def compute_average ( a , b ) :\n    return floor ( ( a + b ) / 2 )\n", "REPRESENT_GIVEN_SET_POINTS_BEST_POSSIBLE_STRAIGHT_LINE": "def bestApproximate ( x , y , n ) :\n    sum_x = 0\n    sum_y = 0\n    sum_xy = 0\n    sum_x2 = 0\n    for i in range ( 0 , n ) :\n        sum_x += x [ i ]\n        sum_y += y [ i ]\n        sum_xy += x [ i ] * y [ i ]\n        sum_x2 += pow ( x [ i ] , 2 )\n    m = ( float ) ( ( n * sum_xy - sum_x * sum_y ) / ( n * sum_x2 - pow ( sum_x , 2 ) ) ) ;\n    c = ( float ) ( sum_y - m * sum_x ) / n ;\n    print ( \"m = \" , m ) ;\n    print ( \"c = \" , c ) ;\n", "SPLIT_ARRAY_ADD_FIRST_PART_END": "def splitArr ( arr , n , k ) :\n    for i in range ( 0 , k ) :\n        x = arr [ 0 ]\n        for j in range ( 0 , n - 1 ) :\n            arr [ j ] = arr [ j + 1 ]\n        arr [ n - 1 ] = x\n", "MAXIMUM_POSSIBLE_DIFFERENCE_TWO_SUBSETS_ARRAY": "def maxDiff ( arr , n ) :\n    SubsetSum_1 = 0\n    SubsetSum_2 = 0\n    for i in range ( 0 , n ) :\n        isSingleOccurance = True\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] == arr [ j ] ) :\n                isSingleOccurance = False\n                arr [ i ] = arr [ j ] = 0\n                break\n        if ( isSingleOccurance == True ) :\n            if ( arr [ i ] > 0 ) :\n                SubsetSum_1 += arr [ i ]\n            else :\n                SubsetSum_2 += arr [ i ]\n    return abs ( SubsetSum_1 - SubsetSum_2 )\n", "LONGEST_SUBSEQUENCE_DIFFERENCE_ADJACENTS_ONE_SET_2": "def longLenSub ( arr , n ) :\n    um = defaultdict ( lambda : 0 )\n    longLen = 0\n    for i in range ( n ) :\n        len1 = 0\n        if ( arr [ i - 1 ] in um and len1 < um [ arr [ i ] - 1 ] ) :\n            len1 = um [ arr [ i ] - 1 ]\n        if ( arr [ i ] + 1 in um and len1 < um [ arr [ i ] + 1 ] ) :\n            len1 = um [ arr [ i ] + 1 ]\n        um [ arr [ i ] ] = len1 + 1\n        if longLen < um [ arr [ i ] ] :\n            longLen = um [ arr [ i ] ]\n    return longLen\n", "LONGEST_REPEATED_SUBSEQUENCE_1": "def longestRepeatedSubSeq ( str ) :\n    n = len ( str )\n    dp = [ [ 0 for i in range ( n + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if ( str [ i - 1 ] == str [ j - 1 ] and i != j ) :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] )\n    res = ''\n    i = n\n    j = n\n    while ( i > 0 and j > 0 ) :\n        if ( dp [ i ] [ j ] == dp [ i - 1 ] [ j - 1 ] + 1 ) :\n            res += str [ i - 1 ]\n            i -= 1\n            j -= 1\n        elif ( dp [ i ] [ j ] == dp [ i - 1 ] [ j ] ) :\n            i -= 1\n        else :\n            j -= 1\n    res = ''.join ( reversed ( res ) )\n    return res\n", "FIND_INDEX_MAXIMUM_OCCURRING_ELEMENT_EQUAL_PROBABILITY": "def findRandomIndexOfMax ( arr , n ) :\n    mp = dict ( )\n    for i in range ( n ) :\n        if ( arr [ i ] in mp ) :\n            mp [ arr [ i ] ] = mp [ arr [ i ] ] + 1\n        else :\n            mp [ arr [ i ] ] = 1\n    max_element = - 323567\n    max_so_far = - 323567\n    for p in mp :\n        if ( mp [ p ] > max_so_far ) :\n            max_so_far = mp [ p ]\n            max_element = p\n    r = int ( ( ( random.randrange ( 1 , max_so_far , 2 ) % max_so_far ) + 1 ) )\n    i = 0\n    count = 0\n    while ( i < n ) :\n        if ( arr [ i ] == max_element ) :\n            count = count + 1\n        if ( count == r ) :\n            print ( \"Element with maximum frequency present at index \" , i )\n            break\n        i = i + 1\n", "CHECK_NUMBER_IS_PERFECT_SQUARE_USING_ADDITIONSUBTRACTION": "def isPerfectSquare ( n ) :\n    i = 1\n    the_sum = 0\n    while the_sum < n :\n        the_sum += i\n        if the_sum == n :\n            return True\n        i += 2\n    return False\n", "N_BONACCI_NUMBERS_1": "def bonacciseries ( n , m ) :\n    a = [ 0 for i in range ( m ) ]\n    a [ n - 1 ] = 1\n    a [ n ] = 1\n    for i in range ( n + 1 , m ) :\n        a [ i ] = 2 * a [ i - 1 ] - a [ i - n - 1 ]\n    for i in range ( 0 , m ) :\n        print ( a [ i ] , end = \" \" )\n", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY_1": "def countPairs ( arr , n ) :\n    mp = dict ( )\n    for i in range ( n ) :\n        if arr [ i ] in mp.keys ( ) :\n            mp [ arr [ i ] ] += 1\n        else :\n            mp [ arr [ i ] ] = 1\n    ans = 0\n    for it in mp :\n        count = mp [ it ]\n        ans += ( count * ( count - 1 ) ) // 2\n    return ans\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER": "def bitonicGenerator ( arr , n ) :\n    evenArr = [ ]\n    oddArr = [ ]\n    for i in range ( n ) :\n        if ( ( i % 2 ) == 0 ) :\n            evenArr.append ( arr [ i ] )\n        else :\n            oddArr.append ( arr [ i ] )\n    evenArr = sorted ( evenArr )\n    oddArr = sorted ( oddArr )\n    oddArr = oddArr [ : : - 1 ]\n    i = 0\n    for j in range ( len ( evenArr ) ) :\n        arr [ i ] = evenArr [ j ]\n        i += 1\n    for j in range ( len ( oddArr ) ) :\n        arr [ i ] = oddArr [ j ]\n        i += 1\n", "DYNAMIC_PROGRAMMING_SET_9_BINOMIAL_COEFFICIENT": "def binomialCoeff ( n , k ) :\n    if k == 0 or k == n :\n        return 1\n    return binomialCoeff ( n - 1 , k - 1 ) + binomialCoeff ( n - 1 , k )\n", "WRITE_A_C_PROGRAM_TO_FIND_THE_PARITY_OF_AN_UNSIGNED_INTEGER": "def getParity ( n ) :\n    parity = 0\n    while n :\n        parity = ~ parity\n        n = n & ( n - 1 )\n    return parity\n", "CHECK_WHETHER_LARGE_NUMBER_DIVISIBLE_7": "def isdivisible7 ( num ) :\n    n = len ( num )\n    if ( n == 0 and num [ 0 ] == '\\n' ) :\n        return 1\n    if ( n % 3 == 1 ) :\n        num = str ( num ) + \"00\"\n        n += 2\n    elif ( n % 3 == 2 ) :\n        num = str ( num ) + \"0\"\n        n += 1\n    GSum = 0\n    p = 1\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        group = 0\n        group += ord ( num [ i ] ) - ord ( '0' )\n        i -= 1\n        group += ( ord ( num [ i ] ) - ord ( '0' ) ) * 10\n        i -= 1\n        group += ( ord ( num [ i ] ) - ord ( '0' ) ) * 100\n        GSum = GSum + group * p\n        p *= ( - 1 )\n    return ( GSum % 7 == 0 )\n", "PRODUCT_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING": "def productAtKthLevel ( tree , k ) :\n    level = - 1\n    product = 1\n    n = len ( tree )\n    for i in range ( 0 , n ) :\n        if ( tree [ i ] == '(' ) :\n            level += 1\n        elif ( tree [ i ] == ')' ) :\n            level -= 1\n        else :\n            if ( level == k ) :\n                product *= ( int ( tree [ i ] ) - int ( '0' ) )\n    return product\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD": "def isEven ( n ) :\n    return ( n % 2 == 0 )\n", "COUNT_GROUPINGS_NUMBER_SUM_DIGITS_EVERY_SUB_GROUP_LESS_EQUALS_IMMEDIATE_RIGHT_SUB_GROUP": "def countGroups ( position , previous_sum , length , num ) :\n    if ( position == length ) :\n        return 1\n    res = 0\n    sum = 0\n    for i in range ( position , length ) :\n        sum = sum + int ( num [ i ] )\n        if ( sum >= previous_sum ) :\n            res = res + countGroups ( i + 1 , sum , length , num )\n    return res\n", "FIND_THE_ELEMENT_THAT_ODD_NUMBER_OF_TIMES_IN_OLOG_N_TIME": "def search ( arr , low , high ) :\n    if low > high :\n        return None\n    if low == high :\n        return arr [ low ]\n    mid = ( low + high ) / 2 ;\n    if mid % 2 == 0 :\n        if arr [ mid ] == arr [ mid + 1 ] :\n            return search ( arr , mid + 2 , high )\n        else :\n            return search ( arr , low , mid )\n    else :\n        if arr [ mid ] == arr [ mid - 1 ] :\n            return search ( arr , mid + 1 , high )\n        else :\n            return search ( arr , low , mid - 1 )\n", "DELETE_CONSECUTIVE_WORDS_SEQUENCE_1": "def removeConsecutiveSame ( v ) :\n    st = [ ]\n    for i in range ( len ( v ) ) :\n        if ( len ( st ) == 0 ) :\n            st.append ( v [ i ] )\n        else :\n            Str = st [ - 1 ]\n            if ( Str == v [ i ] ) :\n                st.pop ( )\n            else :\n                st.append ( v [ i ] )\n    return len ( st )\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY_2": "def minJumps ( arr , n ) :\n    jumps = [ 0 for i in range ( n ) ]\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        if ( arr [ i ] == 0 ) :\n            jumps [ i ] = float ( 'inf' )\n        elif ( arr [ i ] >= n - i - 1 ) :\n            jumps [ i ] = 1\n        else :\n            min = float ( 'inf' )\n            for j in range ( i + 1 , n ) :\n                if ( j <= arr [ i ] + i ) :\n                    if ( min > jumps [ j ] ) :\n                        min = jumps [ j ]\n            if ( min != float ( 'inf' ) ) :\n                jumps [ i ] = min + 1\n            else :\n                jumps [ i ] = min\n    return jumps [ 0 ]\n", "PROGRAM_FIND_GCD_FLOATING_POINT_NUMBERS": "def gcd ( a , b ) :\n    if ( a < b ) :\n        return gcd ( b , a )\n    if ( abs ( b ) < 0.001 ) :\n        return a\n    else :\n        return ( gcd ( b , a - math.floor ( a / b ) * b ) )\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_TWICE": "def maxProfit ( price , n ) :\n    profit = [ 0 ] * n\n    max_price = price [ n - 1 ]\n    for i in range ( n - 2 , 0 , - 1 ) :\n        if price [ i ] > max_price :\n            max_price = price [ i ]\n        profit [ i ] = max ( profit [ i + 1 ] , max_price - price [ i ] )\n    min_price = price [ 0 ]\n    for i in range ( 1 , n ) :\n        if price [ i ] < min_price :\n            min_price = price [ i ]\n        profit [ i ] = max ( profit [ i - 1 ] , profit [ i ] + ( price [ i ] - min_price ) )\n    result = profit [ n - 1 ]\n    return result\n", "COUNT_SET_BITS_IN_AN_INTEGER_1": "def countSetBits ( n ) :\n    if ( n == 0 ) :\n        return 0\n    else :\n        return ( n & 1 ) + countSetBits ( n >> 1 )\n", "REORDER_A_ARRAY_ACCORDING_TO_GIVEN_INDEXES": "def reorder ( arr , index , n ) :\n    temp = [ 0 ] * n ;\n    for i in range ( 0 , n ) :\n        temp [ index [ i ] ] = arr [ i ]\n    for i in range ( 0 , n ) :\n        arr [ i ] = temp [ i ]\n        index [ i ] = i\n", "CHECK_IF_A_GIVEN_ARRAY_CAN_REPRESENT_PREORDER_TRAVERSAL_OF_BINARY_SEARCH_TREE": "def canRepresentBST ( pre ) :\n    s = [ ]\n    root = INT_MIN\n    for value in pre :\n        if value < root :\n            return False\n        while ( len ( s ) > 0 and s [ - 1 ] < value ) :\n            root = s.pop ( )\n        s.append ( value )\n    return True\n", "FIND_REPETITIVE_ELEMENT_1_N_1_3": "def findRepeating ( arr , n ) :\n    missingElement = 0\n    for i in range ( 0 , n ) :\n        element = arr [ abs ( arr [ i ] ) ]\n        if ( element < 0 ) :\n            missingElement = arr [ i ]\n            break\n        arr [ abs ( arr [ i ] ) ] = - arr [ abs ( arr [ i ] ) ]\n    return abs ( missingElement )\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION_1": "def MatrixChainOrder ( p , n ) :\n    m = [ [ 0 for x in range ( n ) ] for x in range ( n ) ]\n    for i in range ( 1 , n ) :\n        m [ i ] [ i ] = 0\n    for L in range ( 2 , n ) :\n        for i in range ( 1 , n - L + 1 ) :\n            j = i + L - 1\n            m [ i ] [ j ] = sys.maxint\n            for k in range ( i , j ) :\n                q = m [ i ] [ k ] + m [ k + 1 ] [ j ] + p [ i - 1 ] * p [ k ] * p [ j ]\n                if q < m [ i ] [ j ] :\n                    m [ i ] [ j ] = q\n    return m [ 1 ] [ n - 1 ]\n", "COUNT_NUMBER_ISLANDS_EVERY_ISLAND_SEPARATED_LINE": "def countIslands ( mat ) :\n    count = 0 ;\n    for i in range ( 0 , M ) :\n        for j in range ( 0 , N ) :\n            if ( mat [ i ] [ j ] == 'X' ) :\n                if ( ( i == 0 or mat [ i - 1 ] [ j ] == 'O' ) and ( j == 0 or mat [ i ] [ j - 1 ] == 'O' ) ) :\n                    count = count + 1\n    return count\n", "MINIMIZE_MAXAI_BJ_CK_MINAI_BJ_CK_THREE_DIFFERENT_SORTED_ARRAYS": "def solve ( A , B , C ) :\n    i = len ( A ) - 1\n    j = len ( B ) - 1\n    k = len ( C ) - 1\n    min_diff = abs ( max ( A [ i ] , B [ j ] , C [ k ] ) - min ( A [ i ] , B [ j ] , C [ k ] ) )\n    while i != - 1 and j != - 1 and k != - 1 :\n        current_diff = abs ( max ( A [ i ] , B [ j ] , C [ k ] ) - min ( A [ i ] , B [ j ] , C [ k ] ) )\n        if current_diff < min_diff :\n            min_diff = current_diff\n        max_term = max ( A [ i ] , B [ j ] , C [ k ] )\n        if A [ i ] == max_term :\n            i -= 1\n        elif B [ j ] == max_term :\n            j -= 1\n        else :\n            k -= 1\n    return min_diff\n", "ROOTS_QUADRATIC_EQUATION": "def findRoots ( a , b , c ) :\n    if a == 0 :\n        print ( \"Invalid\" )\n        return - 1\n    d = b * b - 4 * a * c\n    sqrt_val = math.sqrt ( abs ( d ) )\n    if d > 0 :\n        print ( \"Roots are real and different \" )\n        print ( ( - b + sqrt_val ) / ( 2 * a ) )\n        print ( ( - b - sqrt_val ) / ( 2 * a ) )\n    elif d == 0 :\n        print ( \"Roots are real and same\" )\n        print ( - b / ( 2 * a ) )\n    else :\n        print ( \"Roots are complex\" )\n        print ( - b / ( 2 * a ) , \" + i\" , sqrt_val )\n        print ( - b / ( 2 * a ) , \" - i\" , sqrt_val )\n", "GIVEN_LEVEL_ORDER_TRAVERSAL_BINARY_TREE_CHECK_TREE_MIN_HEAP": "def isMinHeap ( level , n ) :\n    for i in range ( int ( n / 2 ) - 1 , - 1 , - 1 ) :\n        if level [ i ] > level [ 2 * i + 1 ] :\n            return False\n        if 2 * i + 2 < n :\n            if level [ i ] > level [ 2 * i + 2 ] :\n                return False\n    return True\n", "FIND_MINIMUM_ELEMENT_IN_A_SORTED_AND_ROTATED_ARRAY": "def findMin ( arr , low , high ) :\n    if high < low :\n        return arr [ 0 ]\n    if high == low :\n        return arr [ low ]\n    mid = int ( ( low + high ) / 2 )\n    if mid < high and arr [ mid + 1 ] < arr [ mid ] :\n        return arr [ mid + 1 ]\n    if mid > low and arr [ mid ] < arr [ mid - 1 ] :\n        return arr [ mid ]\n    if arr [ high ] > arr [ mid ] :\n        return findMin ( arr , low , mid - 1 )\n    return findMin ( arr , mid + 1 , high )\n", "SMALLEST_LENGTH_STRING_WITH_REPEATED_REPLACEMENT_OF_TWO_DISTINCT_ADJACENT": "def stringReduction ( str ) :\n    n = len ( str )\n    count = [ 0 ] * 3\n    for i in range ( n ) :\n        count [ ord ( str [ i ] ) - ord ( 'a' ) ] += 1\n    if ( count [ 0 ] == n or count [ 1 ] == n or count [ 2 ] == n ) :\n        return n\n    if ( ( count [ 0 ] % 2 ) == ( count [ 1 ] % 2 ) and ( count [ 1 ] % 2 ) == ( count [ 2 ] % 2 ) ) :\n        return 2\n    return 1\n", "CHECK_LARGE_NUMBER_DIVISIBLE_3_NOT": "def check ( num ) :\n    digitSum = 0\n    while num > 0 :\n        rem = num % 10\n        digitSum = digitSum + rem\n        num = num / 10\n    return ( digitSum % 3 == 0 )\n", "COMPUTE_N_UNDER_MODULO_P": "def modFact ( n , p ) :\n    if n >= p :\n        return 0\n    result = 1\n    for i in range ( 1 , n + 1 ) :\n        result = ( result * i ) % p\n    return result\n", "POSSIBILITY_OF_A_WORD_FROM_A_GIVEN_SET_OF_CHARACTERS": "def isPresent ( s , q ) :\n    freq = [ 0 ] * MAX_CHAR\n    for i in range ( 0 , len ( s ) ) :\n        freq [ ord ( s [ i ] ) ] += 1\n    for i in range ( 0 , len ( q ) ) :\n        freq [ ord ( q [ i ] ) ] -= 1\n        if ( freq [ ord ( q [ i ] ) ] < 0 ) :\n            return False\n    return True\n", "NEXT_POWER_OF_2_1": "def nextPowerOf2 ( n ) :\n    p = 1\n    if ( n and not ( n & ( n - 1 ) ) ) :\n        return n\n    while ( p < n ) :\n        p <<= 1\n    return p ;\n", "REORDER_A_ARRAY_ACCORDING_TO_GIVEN_INDEXES_1": "def reorder ( arr , index , n ) :\n    for i in range ( 0 , n ) :\n        while ( index [ i ] != i ) :\n            oldTargetI = index [ index [ i ] ]\n            oldTargetE = arr [ index [ i ] ]\n            arr [ index [ i ] ] = arr [ i ]\n            index [ index [ i ] ] = index [ i ]\n            index [ i ] = oldTargetI\n            arr [ i ] = oldTargetE\n", "UNBOUNDED_KNAPSACK_REPETITION_ITEMS_ALLOWED": "def unboundedKnapsack ( W , n , val , wt ) :\n    dp = [ 0 for i in range ( W + 1 ) ]\n    ans = 0\n    for i in range ( W + 1 ) :\n        for j in range ( n ) :\n            if ( wt [ j ] <= i ) :\n                dp [ i ] = max ( dp [ i ] , dp [ i - wt [ j ] ] + val [ j ] )\n    return dp [ W ]\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX": "def isDiagonalMatrix ( mat ) :\n    for i in range ( 0 , N ) :\n        for j in range ( 0 , N ) :\n            if ( ( i != j ) and ( mat [ i ] [ j ] != 0 ) ) :\n                return False\n    return True\n", "MAXIMUM_REMOVAL_FROM_ARRAY_WHEN_REMOVAL_TIME_WAITING_TIME": "def maxRemoval ( arr , n ) :\n    count = 0\n    cummulative_sum = 0\n    arr.sort ( )\n    for i in range ( n ) :\n        if arr [ i ] >= cummulative_sum :\n            count += 1\n            cummulative_sum += arr [ i ]\n    return count\n", "PROGRAM_CENSOR_WORD_ASTERISKS_SENTENCE": "def censor ( text , word ) :\n    word_list = text.split ( )\n    result = ''\n    stars = '*' * len ( word )\n    count = 0\n    index = 0 ;\n    for i in word_list :\n        if i == word :\n            word_list [ index ] = stars\n        index += 1\n    result = ' '.join ( word_list )\n    return result\n", "COUNT_STRINGS_WITH_CONSECUTIVE_1S": "def countStrings ( n ) :\n    a = [ 0 ] * n\n    b = [ 0 ] * n\n    a [ 0 ] = b [ 0 ] = 1\n    for i in range ( 1 , n ) :\n        a [ i ] = a [ i - 1 ] + b [ i - 1 ]\n        b [ i ] = a [ i - 1 ]\n    return ( 1 << n ) - a [ n - 1 ] - b [ n - 1 ]\n", "LENGTH_LONGEST_BALANCED_SUBSEQUENCE": "def maxLength ( s , n ) :\n    dp = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    for i in range ( n - 1 ) :\n        if ( s [ i ] == '(' and s [ i + 1 ] == ')' ) :\n            dp [ i ] [ i + 1 ] = 2\n    for l in range ( 2 , n ) :\n        i = - 1\n        for j in range ( l , n ) :\n            i += 1\n            if ( s [ i ] == '(' and s [ j ] == ')' ) :\n                dp [ i ] [ j ] = 2 + dp [ i + 1 ] [ j - 1 ]\n            for k in range ( i , j ) :\n                dp [ i ] [ j ] = max ( dp [ i ] [ j ] , dp [ i ] [ k ] + dp [ k + 1 ] [ j ] )\n    return dp [ 0 ] [ n - 1 ]\n", "FIND_THE_POINT_WHERE_MAXIMUM_INTERVALS_OVERLAP": "def findMaxGuests ( arrl , exit , n ) :\n    arrl.sort ( ) ;\n    exit.sort ( ) ;\n    guests_in = 1 ;\n    max_guests = 1 ;\n    time = arrl [ 0 ] ;\n    i = 1 ;\n    j = 0 ;\n    while ( i < n and j < n ) :\n        if ( arrl [ i ] <= exit [ j ] ) :\n            guests_in = guests_in + 1 ;\n            if ( guests_in > max_guests ) :\n                max_guests = guests_in ;\n                time = arrl [ i ] ;\n            i = i + 1 ;\n        else :\n            guests_in = guests_in - 1 ;\n            j = j + 1 ;\n    print ( \"Maximum Number of Guests =\" , max_guests , \"at time\" , time )\n", "EFFICIENT_WAY_CHECK_WHETHER_N_TH_FIBONACCI_NUMBER_MULTIPLE_10": "def isMultipleOf10 ( n ) :\n    return ( n % 15 == 0 )\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE": "def maxSumPairWithDifferenceLessThanK ( arr , N , K ) :\n    arr.sort ( )\n    dp = [ 0 ] * N\n    dp [ 0 ] = 0\n    for i in range ( 1 , N ) :\n        dp [ i ] = dp [ i - 1 ]\n        if ( arr [ i ] - arr [ i - 1 ] < K ) :\n            if ( i >= 2 ) :\n                dp [ i ] = max ( dp [ i ] , dp [ i - 2 ] + arr [ i ] + arr [ i - 1 ] ) ;\n            else :\n                dp [ i ] = max ( dp [ i ] , arr [ i ] + arr [ i - 1 ] ) ;\n    return dp [ N - 1 ]\n", "FIND_K_PAIRS_SMALLEST_SUMS_TWO_ARRAYS": "def kSmallestPair ( arr1 , n1 , arr2 , n2 , k ) :\n    if ( k > n1 * n2 ) :\n        print ( \"k pairs don't exist\" )\n        return\n    index2 = [ 0 for i in range ( n1 ) ]\n    while ( k > 0 ) :\n        min_sum = sys.maxsize\n        min_index = 0\n        for i1 in range ( 0 , n1 , 1 ) :\n            if ( index2 [ i1 ] < n2 and arr1 [ i1 ] + arr2 [ index2 [ i1 ] ] < min_sum ) :\n                min_index = i1\n                min_sum = arr1 [ i1 ] + arr2 [ index2 [ i1 ] ]\n        print ( \"(\" , arr1 [ min_index ] , \",\" , arr2 [ index2 [ min_index ] ] , \")\" , end = \" \" )\n        index2 [ min_index ] += 1\n        k -= 1\n", "FIRST_UPPERCASE_LETTER_IN_A_STRING_ITERATIVE_AND_RECURSIVE_1": "def first ( str , i ) :\n    if ( str [ i ] == '\\0' ) :\n        return 0\n    if ( str [ i ].isupper ( ) ) :\n        return str [ i ]\n    return first ( str , i + 1 )\n", "FIND_PAIRS_B_ARRAY_B_K": "def printPairs ( arr , n , k ) :\n    isPairFound = True\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            if ( i != j and arr [ i ] % arr [ j ] == k ) :\n                print ( \"(\" , arr [ i ] , \", \" , arr [ j ] , \")\" , sep = \"\" , end = \" \" )\n                isPairFound = True\n    return isPairFound\n", "FIND_ARRANGEMENT_QUEUE_GIVEN_TIME": "def solve ( n , t , p ) :\n    s = list ( p )\n    for i in range ( 0 , t ) :\n        for j in range ( 0 , n - 1 ) :\n            if ( s [ j ] == 'B' and s [ j + 1 ] == 'G' ) :\n                temp = s [ j ] ;\n                s [ j ] = s [ j + 1 ] ;\n                s [ j + 1 ] = temp ;\n                j = j + 1\n    print ( ''.join ( s ) )\n", "SHORTEST_POSSIBLE_COMBINATION_TWO_STRINGS": "def printSuperSeq ( a , b ) :\n    m = len ( a )\n    n = len ( b )\n    dp = [ [ 0 ] * ( n + 1 ) for i in range ( m + 1 ) ]\n    for i in range ( 0 , m + 1 ) :\n        for j in range ( 0 , n + 1 ) :\n            if not i :\n                dp [ i ] [ j ] = j ;\n            elif not j :\n                dp [ i ] [ j ] = i ;\n            elif ( a [ i - 1 ] == b [ j - 1 ] ) :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n            else :\n                dp [ i ] [ j ] = 1 + min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) ;\n    index = dp [ m ] [ n ] ;\n    res = [ \"\" ] * ( index )\n    i = m\n    j = n ;\n    while ( i > 0 and j > 0 ) :\n        if ( a [ i - 1 ] == b [ j - 1 ] ) :\n            res [ index - 1 ] = a [ i - 1 ] ;\n            i -= 1\n            j -= 1\n            index -= 1\n        elif ( dp [ i - 1 ] [ j ] < dp [ i ] [ j - 1 ] ) :\n            res [ index - 1 ] = a [ i - 1 ]\n            i -= 1\n            index -= 1\n        else :\n            res [ index - 1 ] = b [ j - 1 ]\n            j -= 1\n            index -= 1\n    while ( i > 0 ) :\n        res [ index - 1 ] = a [ i - 1 ]\n        i -= 1\n        index -= 1\n    while ( j > 0 ) :\n        res [ index - 1 ] = b [ j - 1 ]\n        j -= 1\n        index -= 1\n    print ( \"\".join ( res ) )\n", "COUNT_ROTATIONS_DIVISIBLE_8": "def countRotationsDivBy8 ( n ) :\n    l = len ( n )\n    count = 0\n    if ( l == 1 ) :\n        oneDigit = int ( n [ 0 ] )\n        if ( oneDigit % 8 == 0 ) :\n            return 1\n        return 0\n    if ( l == 2 ) :\n        first = int ( n [ 0 ] ) * 10 + int ( n [ 1 ] )\n        second = int ( n [ 1 ] ) * 10 + int ( n [ 0 ] )\n        if ( first % 8 == 0 ) :\n            count += 1\n        if ( second % 8 == 0 ) :\n            count += 1\n        return count\n    threeDigit = 0\n    for i in range ( 0 , ( l - 2 ) ) :\n        threeDigit = ( int ( n [ i ] ) * 100 + int ( n [ i + 1 ] ) * 10 + int ( n [ i + 2 ] ) )\n        if ( threeDigit % 8 == 0 ) :\n            count += 1\n    threeDigit = ( int ( n [ l - 1 ] ) * 100 + int ( n [ 0 ] ) * 10 + int ( n [ 1 ] ) )\n    if ( threeDigit % 8 == 0 ) :\n        count += 1\n    threeDigit = ( int ( n [ l - 2 ] ) * 100 + int ( n [ l - 1 ] ) * 10 + int ( n [ 0 ] ) )\n    if ( threeDigit % 8 == 0 ) :\n        count += 1\n    return count\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_AT_MOST_K_CHANGES_ALLOWED": "def lcs ( dp , arr1 , n , arr2 , m , k ) :\n    if k < 0 :\n        return - ( 10 ** 7 )\n    if n < 0 or m < 0 :\n        return 0\n    ans = dp [ n ] [ m ] [ k ]\n    if ans != - 1 :\n        return ans\n    ans = max ( lcs ( dp , arr1 , n - 1 , arr2 , m , k ) , lcs ( dp , arr1 , n , arr2 , m - 1 , k ) )\n    if arr1 [ n - 1 ] == arr2 [ m - 1 ] :\n        ans = max ( ans , 1 + lcs ( dp , arr1 , n - 1 , arr2 , m - 1 , k ) )\n    ans = max ( ans , lcs ( dp , arr1 , n - 1 , arr2 , m - 1 , k - 1 ) )\n    return ans\n", "CHECK_LINE_TOUCHES_INTERSECTS_CIRCLE": "def checkCollision ( a , b , c , x , y , radius ) :\n    dist = ( ( abs ( a * x + b * y + c ) ) / math.sqrt ( a * a + b * b ) )\n    if ( radius == dist ) :\n        print ( \"Touch\" )\n    elif ( radius > dist ) :\n        print ( \"Intersect\" )\n    else :\n        print ( \"Outside\" )\n", "FIND_THE_MAXIMUM_SUBARRAY_XOR_IN_A_GIVEN_ARRAY": "def maxSubarrayXOR ( arr , n ) :\n    ans = - 2147483648\n    for i in range ( n ) :\n        curr_xor = 0\n        for j in range ( i , n ) :\n            curr_xor = curr_xor ^ arr [ j ]\n            ans = max ( ans , curr_xor )\n    return ans\n", "SHORTEST_PATH_EXACTLY_K_EDGES_DIRECTED_WEIGHTED_GRAPH": "def shortestPath ( graph , u , v , k ) :\n    V = 4\n    INF = 999999999999\n    if k == 0 and u == v :\n        return 0\n    if k == 1 and graph [ u ] [ v ] != INF :\n        return graph [ u ] [ v ]\n    if k <= 0 :\n        return INF\n    res = INF\n    for i in range ( V ) :\n        if graph [ u ] [ i ] != INF and u != i and v != i :\n            rec_res = shortestPath ( graph , i , v , k - 1 )\n            if rec_res != INF :\n                res = min ( res , graph [ u ] [ i ] + rec_res )\n    return res\n", "FIND_SUBARRAY_WITH_GIVEN_SUM": "def subArraySum ( arr , n , sum ) :\n    for i in range ( n ) :\n        curr_sum = arr [ i ]\n        j = i + 1\n        while j <= n :\n            if curr_sum == sum :\n                print ( \"Sum found between\" )\n                print ( \"indexes %d and %d\" % ( i , j - 1 ) )\n                return 1\n            if curr_sum > sum or j == n :\n                break\n            curr_sum = curr_sum + arr [ j ]\n            j += 1\n    print ( \"No subarray found\" )\n    return 0\n", "K_TH_PRIME_FACTOR_GIVEN_NUMBER": "def kPrimeFactor ( n , k ) :\n    while ( n % 2 == 0 ) :\n        k = k - 1\n        n = n / 2\n        if ( k == 0 ) :\n            return 2\n    i = 3\n    while i <= math.sqrt ( n ) :\n        while ( n % i == 0 ) :\n            if ( k == 1 ) :\n                return i\n            k = k - 1\n            n = n / i\n        i = i + 2\n    if ( n > 2 and k == 1 ) :\n        return n\n    return - 1\n", "FIND_ROTATION_COUNT_ROTATED_SORTED_ARRAY_1": "def countRotations ( arr , low , high ) :\n    if ( high < low ) :\n        return 0\n    if ( high == low ) :\n        return low\n    mid = low + ( high - low ) / 2 ;\n    mid = int ( mid )\n    if ( mid < high and arr [ mid + 1 ] < arr [ mid ] ) :\n        return ( mid + 1 )\n    if ( mid > low and arr [ mid ] < arr [ mid - 1 ] ) :\n        return mid\n    if ( arr [ high ] > arr [ mid ] ) :\n        return countRotations ( arr , low , mid - 1 ) ;\n    return countRotations ( arr , mid + 1 , high )\n", "COMPUTE_AVERAGE_TWO_NUMBERS_WITHOUT_OVERFLOW_1": "def compute_average ( a , b ) :\n    return ( a // 2 ) + ( b // 2 ) + ( ( a % 2 + b % 2 ) // 2 )\n", "SORTING_USING_TRIVIAL_HASH_FUNCTION_1": "def sortUsingHash ( a , n ) :\n    Max = max ( a )\n    Min = abs ( min ( a ) )\n    hashpos = [ 0 ] * ( Max + 1 )\n    hashneg = [ 0 ] * ( Min + 1 )\n    for i in range ( 0 , n ) :\n        if a [ i ] >= 0 :\n            hashpos [ a [ i ] ] += 1\n        else :\n            hashneg [ abs ( a [ i ] ) ] += 1\n    for i in range ( Min , 0 , - 1 ) :\n        if hashneg [ i ] != 0 :\n            for j in range ( 0 , hashneg [ i ] ) :\n                print ( ( - 1 ) * i , end = \" \" )\n    for i in range ( 0 , Max + 1 ) :\n        if hashpos [ i ] != 0 :\n            for j in range ( 0 , hashpos [ i ] ) :\n                print ( i , end = \" \" )\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_1": "def printRepeating ( arr , size ) :\n    count = [ 0 ] * size\n    print ( \" Repeating elements are \" , end = \"\" )\n    for i in range ( 0 , size ) :\n        if ( count [ arr [ i ] ] == 1 ) :\n            print ( arr [ i ] , end = \" \" )\n        else :\n            count [ arr [ i ] ] = count [ arr [ i ] ] + 1\n", "MINIMUM_STEPS_MINIMIZE_N_PER_GIVEN_CONDITION": "def getMinSteps ( n ) :\n    table = [ 0 ] * ( n + 1 )\n    for i in range ( n + 1 ) :\n        table [ i ] = n - i\n    for i in range ( n , 0 , - 1 ) :\n        if ( not ( i % 2 ) ) :\n            table [ i // 2 ] = min ( table [ i ] + 1 , table [ i // 2 ] )\n        if ( not ( i % 3 ) ) :\n            table [ i // 3 ] = min ( table [ i ] + 1 , table [ i // 3 ] )\n    return table [ 1 ]\n    ", "COUNT_POSSIBLE_DECODINGS_GIVEN_DIGIT_SEQUENCE_1": "def countDecodingDP ( digits , n ) :\n    count = [ 0 ] * ( n + 1 ) ;\n    count [ 0 ] = 1 ;\n    count [ 1 ] = 1 ;\n    for i in range ( 2 , n + 1 ) :\n        count [ i ] = 0 ;\n        if ( digits [ i - 1 ] > '0' ) :\n            count [ i ] = count [ i - 1 ] ;\n        if ( digits [ i - 2 ] == '1' or ( digits [ i - 2 ] == '2' and digits [ i - 1 ] < '7' ) ) :\n            count [ i ] += count [ i - 2 ] ;\n    return count [ n ] ;\n", "EULERS_FOUR_SQUARE_IDENTITY_1": "def checkEulerFourSquareIdentity ( a , b ) :\n    ab = a * b\n    flag = False\n    i = 0\n    while i * i <= ab :\n        j = i\n        while i * i + j * j <= ab :\n            k = j\n            while i * i + j * j + k * k <= ab :\n                l = ( ab - ( i * i + j * j + k * k ) ) ** ( 0.5 )\n                if l == int ( l ) and l >= k :\n                    flag = True\n                    print ( \"i = \" , i )\n                    print ( \"j = \" , j )\n                    print ( \"k = \" , k )\n                    print ( \"l = \" , l )\n                    print ( \"Product of\" , a , \"and\" , b , \"can be written as sum of squares of i, j, k, l\" )\n                    print ( ab , \" = \" , i , \"*\" , i , \"+\" , j , \"*\" , j , \"+\" , k , \"*\" , k , \"+\" , l , \"*\" , l )\n                k += 1\n            j += 1\n        i += 1\n    if flag == False :\n        print ( \"Solution doesn't exist!\" )\n        return\n", "COUNT_NUMBER_INCREASING_SUBSEQUENCES_SIZE_K": "def numOfIncSubseqOfSizeK ( arr , n , k ) :\n    dp = [ [ 0 for i in range ( n ) ] for i in range ( k ) ]\n    for i in range ( n ) :\n        dp [ 0 ] [ i ] = 1\n    for l in range ( 1 , k ) :\n        for i in range ( l , n ) :\n            dp [ l ] [ i ] = 0\n            for j in range ( l - 1 , i ) :\n                if ( arr [ j ] < arr [ i ] ) :\n                    dp [ l ] [ i ] += dp [ l - 1 ] [ j ]\n    Sum = 0\n    for i in range ( k - 1 , n ) :\n        Sum += dp [ k - 1 ] [ i ]\n    return Sum\n", "KNAPSACK_PROBLEM_1": "def knapSack ( W , wt , val , n ) :\n    K = [ [ 0 for x in range ( W + 1 ) ] for x in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        for w in range ( W + 1 ) :\n            if i == 0 or w == 0 :\n                K [ i ] [ w ] = 0\n            elif wt [ i - 1 ] <= w :\n                K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ] , K [ i - 1 ] [ w ] )\n            else :\n                K [ i ] [ w ] = K [ i - 1 ] [ w ]\n    return K [ n ] [ W ]\n", "PROGRAM_TO_PRINT_DOUBLE_HEADED_ARROW_PATTERN": "def drawPattern ( N ) :\n    n = N ;\n    row = 1 ;\n    nst = 1 ;\n    nsp1 = n - 1 ;\n    nsp2 = - 1 ;\n    val1 = row ;\n    val2 = 1 ;\n    while ( row <= n ) :\n        csp1 = 1 ;\n        while ( csp1 <= nsp1 ) :\n            print ( \" \" , end = \" \" ) ;\n            csp1 = csp1 + 1 ;\n        cst1 = 1 ;\n        while ( cst1 <= nst ) :\n            print ( val1 , end = \" \" ) ;\n            val1 = val1 - 1 ;\n            cst1 = cst1 + 1 ;\n        csp2 = 1 ;\n        while ( csp2 <= nsp2 ) :\n            print ( \" \" , end = \" \" ) ;\n            csp2 = csp2 + 1 ;\n        if ( row != 1 and row != n ) :\n            cst2 = 1 ;\n            while ( cst2 <= nst ) :\n                print ( val2 , end = \" \" ) ;\n                val2 = val2 + 1 ;\n                cst2 = cst2 + 1 ;\n        print ( )\n        if ( row <= n // 2 ) :\n            nst = nst + 1 ;\n            nsp1 = nsp1 - 2 ;\n            nsp2 = nsp2 + 2 ;\n            val1 = row + 1 ;\n            val2 = 1 ;\n        else :\n            nst = nst - 1 ;\n            nsp1 = nsp1 + 2 ;\n            nsp2 = nsp2 - 2 ;\n            val1 = n - row ;\n            val2 = 1 ;\n        row = row + 1 ;\n", "INTEGER_POSITIVE_VALUE_POSITIVE_NEGATIVE_VALUE_ARRAY": "def findInteger ( arr , n ) :\n    hash = dict ( )\n    maximum = 0\n    for i in arr :\n        if ( i < 0 ) :\n            if abs ( i ) not in hash.keys ( ) :\n                hash [ abs ( i ) ] = - 1\n            else :\n                hash [ abs ( i ) ] -= 1\n        else :\n            hash [ i ] = hash.get ( i , 0 ) + 1\n    for i in arr :\n        if i in hash.keys ( ) and hash [ i ] > 0 :\n            return i\n    return - 1\n", "SPACE_OPTIMIZED_SOLUTION_LCS": "def lcs ( X , Y ) :\n    m = len ( X )\n    n = len ( Y )\n    L = [ [ 0 for i in range ( n + 1 ) ] for j in range ( 2 ) ]\n    bi = bool\n    for i in range ( m ) :\n        bi = i & 1\n        for j in range ( n + 1 ) :\n            if ( i == 0 or j == 0 ) :\n                L [ bi ] [ j ] = 0\n            elif ( X [ i ] == Y [ j - 1 ] ) :\n                L [ bi ] [ j ] = L [ 1 - bi ] [ j - 1 ] + 1\n            else :\n                L [ bi ] [ j ] = max ( L [ 1 - bi ] [ j ] , L [ bi ] [ j - 1 ] )\n    return L [ bi ] [ n ]\n", "REPRESENT_NUMBER_SUM_MINIMUM_POSSIBLE_PSUEDOBINARY_NUMBERS": "def psuedoBinary ( n ) :\n    while ( n > 0 ) :\n        temp = n ;\n        m = 0 ;\n        p = 1 ;\n        while ( temp ) :\n            rem = temp % 10 ;\n            temp = int ( temp / 10 ) ;\n            if ( rem != 0 ) :\n                m += p ;\n            p *= 10 ;\n        print ( m , end = \" \" ) ;\n        n = n - m ;\n", "FIND_NUMBER_CURRENCY_NOTES_SUM_UPTO_GIVEN_AMOUNT": "def countCurrency ( amount ) :\n    notes = [ 2000 , 500 , 200 , 100 , 50 , 20 , 10 , 5 , 1 ]\n    noteCounter = [ 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ]\n    print ( \"Currency Count -> \" )\n    for i , j in zip ( notes , noteCounter ) :\n        if amount >= i :\n            j = amount // i\n            amount = amount - j * i\n            print ( i , \" : \" , j )\n", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS": "def rearrange ( a , size ) :\n    positive = 0\n    negative = 1\n    while ( True ) :\n        while ( positive < size and a [ positive ] >= 0 ) :\n            positive = positive + 2\n        while ( negative < size and a [ negative ] <= 0 ) :\n            negative = negative + 2\n        if ( positive < size and negative < size ) :\n            temp = a [ positive ]\n            a [ positive ] = a [ negative ]\n            a [ negative ] = temp\n        else :\n            break\n", "FIND_WHETHER_AN_ARRAY_IS_SUBSET_OF_ANOTHER_ARRAY_SET_1": "def isSubset ( arr1 , arr2 , m , n ) :\n    i = 0\n    j = 0\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( arr2 [ i ] == arr1 [ j ] ) :\n                break\n        if ( j == m ) :\n            return 0\n    return 1\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM": "def pairInSortedRotated ( arr , n , x ) :\n    for i in range ( 0 , n - 1 ) :\n        if ( arr [ i ] > arr [ i + 1 ] ) :\n            break ;\n    l = ( i + 1 ) % n\n    r = i\n    while ( l != r ) :\n        if ( arr [ l ] + arr [ r ] == x ) :\n            return True ;\n        if ( arr [ l ] + arr [ r ] < x ) :\n            l = ( l + 1 ) % n ;\n        else :\n            r = ( n + r - 1 ) % n ;\n    return False ;\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR_1": "def getRemainder ( num , divisor ) :\n    if ( divisor == 0 ) :\n        return False\n    if ( divisor < 0 ) :\n        divisor = - divisor\n    if ( num < 0 ) :\n        num = - num\n    i = 1\n    product = 0\n    while ( product <= num ) :\n        product = divisor * i\n        i += 1\n    return num - ( product - divisor )\n", "GNOME_SORT_A_STUPID_ONE": "def gnomeSort ( arr , n ) :\n    index = 0\n    while index < n :\n        if index == 0 :\n            index = index + 1\n        if arr [ index ] >= arr [ index - 1 ] :\n            index = index + 1\n        else :\n            arr [ index ] , arr [ index - 1 ] = arr [ index - 1 ] , arr [ index ]\n            index = index - 1\n    return arr\n", "NUMBER_WAYS_INSERT_CHARACTER_INCREASE_LCS_ONE": "def numberofways ( A , B , N , M ) :\n    pos = [ [ ] for _ in range ( MAX ) ]\n    for i in range ( M ) :\n        pos [ ord ( B [ i ] ) ].append ( i + 1 )\n    dpl = [ [ 0 ] * ( M + 2 ) for _ in range ( N + 2 ) ]\n    for i in range ( 1 , N + 1 ) :\n        for j in range ( 1 , M + 1 ) :\n            if A [ i - 1 ] == B [ j - 1 ] :\n                dpl [ i ] [ j ] = dpl [ i - 1 ] [ j - 1 ] + 1\n            else :\n                dpl [ i ] [ j ] = max ( dpl [ i - 1 ] [ j ] , dpl [ i ] [ j - 1 ] )\n    LCS = dpl [ N ] [ M ]\n    dpr = [ [ 0 ] * ( M + 2 ) for _ in range ( N + 2 ) ]\n    for i in range ( N , 0 , - 1 ) :\n        for j in range ( M , 0 , - 1 ) :\n            if A [ i - 1 ] == B [ j - 1 ] :\n                dpr [ i ] [ j ] = dpr [ i + 1 ] [ j + 1 ] + 1\n            else :\n                dpr [ i ] [ j ] = max ( dpr [ i + 1 ] [ j ] , dpr [ i ] [ j + 1 ] )\n    ans = 0\n    for i in range ( N + 1 ) :\n        for j in range ( MAX ) :\n            for x in pos [ j ] :\n                if dpl [ i ] [ x - 1 ] + dpr [ i + 1 ] [ x + 1 ] == LCS :\n                    ans += 1\n                    break\n    return ans\n", "MINIMUM_PRODUCT_K_INTEGERS_ARRAY_POSITIVE_INTEGERS": "def minProduct ( arr , n , k ) :\n    heapq.heapify ( arr )\n    count = 0\n    ans = 1\n    while ( arr ) and count < k :\n        x = heapq.heappop ( arr )\n        ans = ans * x\n        count = count + 1\n    return ans ;\n", "FIND_UNIQUE_ELEMENTS_MATRIX": "def unique ( mat , n , m ) :\n    maximum = 0 ; flag = 0\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , m ) :\n            if ( maximum < mat [ i ] [ j ] ) :\n                maximum = mat [ i ] [ j ] ;\n    uniqueElementDict = [ 0 ] * ( maximum + 1 )\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , m ) :\n            uniqueElementDict [ mat [ i ] [ j ] ] += 1\n    for key in range ( maximum + 1 ) :\n        if uniqueElementDict [ key ] == 1 :\n            print ( key , end = \" \" )\n            flag = 1\n    if ( flag == 0 ) :\n        print ( \"No unique element in the matrix\" )\n", "LONGEST_SUBSEQUENCE_SUCH_THAT_DIFFERENCE_BETWEEN_ADJACENTS_IS_ONE": "def longestSubseqWithDiffOne ( arr , n ) :\n    dp = [ 1 for i in range ( n ) ]\n    for i in range ( n ) :\n        for j in range ( i ) :\n            if ( ( arr [ i ] == arr [ j ] + 1 ) or ( arr [ i ] == arr [ j ] - 1 ) ) :\n                dp [ i ] = max ( dp [ i ] , dp [ j ] + 1 )\n    result = 1\n    for i in range ( n ) :\n        if ( result < dp [ i ] ) :\n            result = dp [ i ]\n    return result\n", "C_PROGRAM_CONCATENATE_STRING_GIVEN_NUMBER_TIMES": "def repeat ( s , n ) :\n    s1 = s\n    for i in range ( 1 , n ) :\n        s += s1\n    return s\n", "SEARCHING_FOR_PATTERNS_SET_1_NAIVE_PATTERN_SEARCHING": "def search ( pat , txt ) :\n    M = len ( pat )\n    N = len ( txt )\n    for i in range ( N - M + 1 ) :\n        j = 0\n        while ( j < M ) :\n            if ( txt [ i + j ] != pat [ j ] ) :\n                break\n            j += 1\n        if ( j == M ) :\n            print ( \"Pattern found at index \" , i )\n", "COUNT_POSSIBLE_PATHS_SOURCE_DESTINATION_EXACTLY_K_EDGES": "def countwalks ( graph , u , v , k ) :\n    if ( k == 0 and u == v ) :\n        return 1\n    if ( k == 1 and graph [ u ] [ v ] ) :\n        return 1\n    if ( k <= 0 ) :\n        return 0\n    count = 0\n    for i in range ( 0 , V ) :\n        if ( graph [ u ] [ i ] == 1 ) :\n            count += countwalks ( graph , i , v , k - 1 )\n    return count\n", "COUNT_DIVISIBLE_PAIRS_ARRAY": "def countDivisibles ( arr , n ) :\n    res = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] % arr [ j ] == 0 or arr [ j ] % arr [ i ] == 0 ) :\n                res += 1\n    return res\n", "PROGRAM_TO_CHECK_IF_A_MATRIX_IS_SYMMETRIC": "def isSymmetric ( mat , N ) :\n    for i in range ( N ) :\n        for j in range ( N ) :\n            if ( mat [ i ] [ j ] != mat [ j ] [ i ] ) :\n                return False\n    return True\n", "COUNT_PALINDROME_SUB_STRINGS_STRING": "def CountPS ( str , n ) :\n    dp = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    P = [ [ False for x in range ( n ) ] for y in range ( n ) ]\n    for i in range ( n ) :\n        P [ i ] [ i ] = True\n    for i in range ( n - 1 ) :\n        if ( str [ i ] == str [ i + 1 ] ) :\n            P [ i ] [ i + 1 ] = True\n            dp [ i ] [ i + 1 ] = 1\n    for gap in range ( 2 , n ) :\n        for i in range ( n - gap ) :\n            j = gap + i ;\n            if ( str [ i ] == str [ j ] and P [ i + 1 ] [ j - 1 ] ) :\n                P [ i ] [ j ] = True\n            if ( P [ i ] [ j ] == True ) :\n                dp [ i ] [ j ] = ( dp [ i ] [ j - 1 ] + dp [ i + 1 ] [ j ] + 1 - dp [ i + 1 ] [ j - 1 ] )\n            else :\n                dp [ i ] [ j ] = ( dp [ i ] [ j - 1 ] + dp [ i + 1 ] [ j ] - dp [ i + 1 ] [ j - 1 ] )\n    return dp [ 0 ] [ n - 1 ]\n", "WAYS_SUM_N_USING_ARRAY_ELEMENTS_REPETITION_ALLOWED": "def countWays ( arr , m , N ) :\n    count = [ 0 for i in range ( N + 1 ) ]\n    count [ 0 ] = 1\n    for i in range ( 1 , N + 1 ) :\n        for j in range ( m ) :\n            if ( i >= arr [ j ] ) :\n                count [ i ] += count [ i - arr [ j ] ]\n    return count [ N ]\n", "MINIMUM_NUMBER_OF_OPERATIONS_TO_MOVE_ALL_UPPERCASE_CHARACTERS_BEFORE_ALL_LOWER_CASE_CHARACTERS": "def minOperations ( str , n ) :\n    lastUpper = - 1\n    firstLower = - 1\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if ( str [ i ].isupper ( ) ) :\n            lastUpper = i\n            break\n    for i in range ( n ) :\n        if ( str [ i ].islower ( ) ) :\n            firstLower = i\n            break\n    if ( lastUpper == - 1 or firstLower == - 1 ) :\n        return 0\n    countUpper = 0\n    for i in range ( firstLower , n ) :\n        if ( str [ i ].isupper ( ) ) :\n            countUpper += 1\n    countLower = 0\n    for i in range ( lastUpper ) :\n        if ( str [ i ].islower ( ) ) :\n            countLower += 1\n    return min ( countLower , countUpper )\n", "PRINT_A_GIVEN_MATRIX_IN_SPIRAL_FORM": "def spiralPrint ( m , n , a ) :\n    k = 0 ; l = 0\n    while ( k < m and l < n ) :\n        for i in range ( l , n ) :\n            print ( a [ k ] [ i ] , end = \" \" )\n        k += 1\n        for i in range ( k , m ) :\n            print ( a [ i ] [ n - 1 ] , end = \" \" )\n        n -= 1\n        if ( k < m ) :\n            for i in range ( n - 1 , ( l - 1 ) , - 1 ) :\n                print ( a [ m - 1 ] [ i ] , end = \" \" )\n            m -= 1\n        if ( l < n ) :\n            for i in range ( m - 1 , k - 1 , - 1 ) :\n                print ( a [ i ] [ l ] , end = \" \" )\n            l += 1\n", "FIND_DISTINCT_INTEGERS_FOR_A_TRIPLET_WITH_GIVEN_PRODUCT": "def findTriplets ( x ) :\n    fact = [ ] ;\n    factors = set ( ) ;\n    for i in range ( 2 , int ( sqrt ( x ) ) ) :\n        if ( x % i == 0 ) :\n            fact.append ( i ) ;\n            if ( x / i != i ) :\n                fact.append ( x // i ) ;\n            factors.add ( i ) ;\n            factors.add ( x // i ) ;\n    found = False ;\n    k = len ( fact ) ;\n    for i in range ( k ) :\n        a = fact [ i ] ;\n        for j in range ( k ) :\n            b = fact [ j ] ;\n            if ( ( a != b ) and ( x % ( a * b ) == 0 ) and ( x / ( a * b ) != a ) and ( x / ( a * b ) != b ) and ( x / ( a * b ) != 1 ) ) :\n                print ( a , b , x // ( a * b ) ) ;\n                found = True ;\n                break ;\n        if ( found ) :\n            break ;\n    if ( not found ) :\n        print ( \"-1\" ) ;\n", "SUM_TWO_LARGE_NUMBERS_1": "def findSum ( str1 , str2 ) :\n    if len ( str1 ) > len ( str2 ) :\n        temp = str1\n        str1 = str2\n        str2 = temp\n    str3 = \"\"\n    n1 = len ( str1 )\n    n2 = len ( str2 )\n    diff = n2 - n1\n    carry = 0\n    for i in range ( n1 - 1 , - 1 , - 1 ) :\n        sum = ( ( ord ( str1 [ i ] ) - ord ( '0' ) ) + int ( ( ord ( str2 [ i + diff ] ) - ord ( '0' ) ) ) + carry )\n        str3 = str3 + str ( sum % 10 )\n        carry = sum // 10\n    for i in range ( n2 - n1 - 1 , - 1 , - 1 ) :\n        sum = ( ( ord ( str2 [ i ] ) - ord ( '0' ) ) + carry )\n        str3 = str3 + str ( sum % 10 )\n        carry = sum // 10\n    if ( carry ) :\n        str3 + str ( carry + '0' )\n    str3 = str3 [ : : - 1 ]\n    return str3\n", "COCKTAIL_SORT": "def cocktailSort ( a ) :\n    n = len ( a )\n    swapped = True\n    start = 0\n    end = n - 1\n    while ( swapped == True ) :\n        swapped = False\n        for i in range ( start , end ) :\n            if ( a [ i ] > a [ i + 1 ] ) :\n                a [ i ] , a [ i + 1 ] = a [ i + 1 ] , a [ i ]\n                swapped = True\n        if ( swapped == False ) :\n            break\n        swapped = False\n        end = end - 1\n        for i in range ( end - 1 , start - 1 , - 1 ) :\n            if ( a [ i ] > a [ i + 1 ] ) :\n                a [ i ] , a [ i + 1 ] = a [ i + 1 ] , a [ i ]\n                swapped = True\n        start = start + 1\n", "COUNT_DERANGEMENTS_PERMUTATION_SUCH_THAT_NO_ELEMENT_APPEARS_IN_ITS_ORIGINAL_POSITION_1": "def countDer ( n ) :\n    der = [ 0 for i in range ( n + 1 ) ]\n    der [ 0 ] = 1\n    der [ 1 ] = 0\n    der [ 2 ] = 1\n    for i in range ( 3 , n + 1 ) :\n        der [ i ] = ( i - 1 ) * ( der [ i - 1 ] + der [ i - 2 ] )\n    return der [ n ]\n", "MAXIMUM_PRODUCT_SUBARRAY_ADDED_NEGATIVE_PRODUCT_CASE": "def findMaxProduct ( arr , n ) :\n    ans = - float ( 'inf' )\n    maxval = 1\n    minval = 1\n    for i in range ( 0 , n ) :\n        if arr [ i ] > 0 :\n            maxval = maxval * arr [ i ]\n            minval = min ( 1 , minval * arr [ i ] )\n        elif arr [ i ] == 0 :\n            minval = 1\n            maxval = 0\n        elif arr [ i ] < 0 :\n            prevMax = maxval\n            maxval = minval * arr [ i ]\n            minval = prevMax * arr [ i ]\n        ans = max ( ans , maxval )\n        if maxval <= 0 :\n            maxval = 1\n    return ans\n", "REARRANGE_ARRAY_SUCH_THAT_EVEN_POSITIONED_ARE_GREATER_THAN_ODD": "def assign ( a , n ) :\n    a.sort ( )\n    ans = [ 0 ] * n\n    p = 0\n    q = n - 1\n    for i in range ( n ) :\n        if ( i + 1 ) % 2 == 0 :\n            ans [ i ] = a [ q ]\n            q = q - 1\n        else :\n            ans [ i ] = a [ p ]\n            p = p + 1\n    for i in range ( n ) :\n        print ( ans [ i ] , end = \" \" )\n", "FRIENDS_PAIRING_PROBLEM": "def countFriendsPairings ( n ) :\n    dp = [ 0 for i in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        if ( i <= 2 ) :\n            dp [ i ] = i\n        else :\n            dp [ i ] = dp [ i - 1 ] + ( i - 1 ) * dp [ i - 2 ]\n    return dp [ n ]\n", "PRIME_NUMBERS": "def isPrime ( n ) :\n    if ( n <= 1 ) :\n        return False\n    for i in range ( 2 , n ) :\n        if ( n % i == 0 ) :\n            return False\n    return True\n", "PROBABILITY_REACHING_POINT_2_3_STEPS_TIME": "def find_prob ( N , P ) :\n    dp = [ 0 ] * ( n + 1 )\n    dp [ 0 ] = 1\n    dp [ 1 ] = 0\n    dp [ 2 ] = P\n    dp [ 3 ] = 1 - P\n    for i in range ( 4 , N + 1 ) :\n        dp [ i ] = ( P ) * dp [ i - 2 ] + ( 1 - P ) * dp [ i - 3 ]\n    return dp [ N ]\n", "SMALLEST_OF_THREE_INTEGERS_WITHOUT_COMPARISON_OPERATORS_1": "def smallest ( x , y , z ) :\n    if ( not ( y / x ) ) :\n        return y if ( not ( y / z ) ) else z\n    return x if ( not ( x / z ) ) else z\n", "COMMON_ELEMENTS_IN_ALL_ROWS_OF_A_GIVEN_MATRIX": "def printCommonElements ( mat ) :\n    mp = dict ( )\n    for j in range ( N ) :\n        mp [ mat [ 0 ] [ j ] ] = 1\n    for i in range ( 1 , M ) :\n        for j in range ( N ) :\n            if ( mat [ i ] [ j ] in mp.keys ( ) and mp [ mat [ i ] [ j ] ] == i ) :\n                mp [ mat [ i ] [ j ] ] = i + 1\n                if i == M - 1 :\n                    print ( mat [ i ] [ j ] , end = \" \" )\n", "DETECTING_NEGATIVE_CYCLE_USING_FLOYD_WARSHALL": "def negCyclefloydWarshall ( graph ) :\n    dist = [ [ 0 for i in range ( V + 1 ) ] for j in range ( V + 1 ) ]\n    for i in range ( V ) :\n        for j in range ( V ) :\n            dist [ i ] [ j ] = graph [ i ] [ j ]\n    for k in range ( V ) :\n        for i in range ( V ) :\n            for j in range ( V ) :\n                if ( dist [ i ] [ k ] + dist [ k ] [ j ] < dist [ i ] [ j ] ) :\n                    dist [ i ] [ j ] = dist [ i ] [ k ] + dist [ k ] [ j ]\n    for i in range ( V ) :\n        if ( dist [ i ] [ i ] < 0 ) :\n            return True\n    return False\n", "PROGRAM_SORT_STRING_DESCENDING_ORDER": "def sortString ( str ) :\n    charCount = [ 0 ] * MAX_CHAR ;\n    for i in range ( len ( str ) ) :\n        charCount [ ord ( str [ i ] ) - ord ( 'a' ) ] += 1 ;\n    for i in range ( MAX_CHAR - 1 , - 1 , - 1 ) :\n        for j in range ( charCount [ i ] ) :\n            print ( chr ( 97 + i ) , end = \"\" ) ;\n", "COUNT_PAIRS_WITH_GIVEN_SUM": "def getPairsCount ( arr , n , sum ) :\n    count = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if arr [ i ] + arr [ j ] == sum :\n                count += 1\n    return count\n", "SUM_SERIES_12_32_52_2N_12_1": "def sumOfSeries ( n ) :\n    return int ( ( n * ( 2 * n - 1 ) * ( 2 * n + 1 ) ) / 3 )\n", "MAXIMUM_DIFFERENCE_BETWEEN_FREQUENCY_OF_TWO_ELEMENTS_SUCH_THAT_ELEMENT_HAVING_GREATER_FREQUENCY_IS_ALSO_GREATER": "def maxdiff ( arr , n ) :\n    freq = defaultdict ( lambda : 0 )\n    for i in range ( n ) :\n        freq [ arr [ i ] ] += 1\n    ans = 0\n    for i in range ( n ) :\n        for j in range ( n ) :\n            if freq [ arr [ i ] ] > freq [ arr [ j ] ] and arr [ i ] > arr [ j ] :\n                ans = max ( ans , freq [ arr [ i ] ] - freq [ arr [ j ] ] )\n            elif freq [ arr [ i ] ] < freq [ arr [ j ] ] and arr [ i ] < arr [ j ] :\n                ans = max ( ans , freq [ arr [ j ] ] - freq [ arr [ i ] ] )\n    return ans\n", "SHIFT_MATRIX_ELEMENTS_K": "def shiftMatrixByK ( mat , k ) :\n    if ( k > N ) :\n        print ( \"shifting is\"\" not possible\" )\n        return\n    j = 0\n    while ( j < N ) :\n        for i in range ( k , N ) :\n            print ( \"{} \".format ( mat [ j ] [ i ] ) , end = \"\" )\n        for i in range ( 0 , k ) :\n            print ( \"{} \".format ( mat [ j ] [ i ] ) , end = \"\" )\n        print ( \"\" )\n        j = j + 1\n", "MAXIMUM_AND_MINIMUM_IN_A_SQUARE_MATRIX": "def MAXMIN ( arr , n ) :\n    MIN = 10 ** 9\n    MAX = - 10 ** 9\n    for i in range ( n ) :\n        for j in range ( n // 2 + 1 ) :\n            if ( arr [ i ] [ j ] > arr [ i ] [ n - j - 1 ] ) :\n                if ( MIN > arr [ i ] [ n - j - 1 ] ) :\n                    MIN = arr [ i ] [ n - j - 1 ]\n                if ( MAX < arr [ i ] [ j ] ) :\n                    MAX = arr [ i ] [ j ]\n            else :\n                if ( MIN > arr [ i ] [ j ] ) :\n                    MIN = arr [ i ] [ j ]\n                if ( MAX < arr [ i ] [ n - j - 1 ] ) :\n                    MAX = arr [ i ] [ n - j - 1 ]\n    print ( \"MAXimum =\" , MAX , \", MINimum =\" , MIN )\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY_1": "def findGreatest ( arr , n ) :\n    m = dict ( )\n    for i in arr :\n        m [ i ] = m.get ( i , 0 ) + 1\n    arr = sorted ( arr )\n    for i in range ( n - 1 , 0 , - 1 ) :\n        j = 0\n        while ( j < i and arr [ j ] <= sqrt ( arr [ i ] ) ) :\n            if ( arr [ i ] % arr [ j ] == 0 ) :\n                result = arr [ i ] // arr [ j ]\n                if ( result != arr [ j ] and ( result in m.keys ( ) ) and m [ result ] > 0 ) :\n                    return arr [ i ]\n                elif ( result == arr [ j ] and ( result in m.keys ( ) ) and m [ result ] > 1 ) :\n                    return arr [ i ]\n            j += 1\n    return - 1\n", "0_1_KNAPSACK_PROBLEM_DP_10_1": "def knapSack ( W , wt , val , n ) :\n    K = [ [ 0 for x in range ( W + 1 ) ] for x in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        for w in range ( W + 1 ) :\n            if i == 0 or w == 0 :\n                K [ i ] [ w ] = 0\n            elif wt [ i - 1 ] <= w :\n                K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ] , K [ i - 1 ] [ w ] )\n            else :\n                K [ i ] [ w ] = K [ i - 1 ] [ w ]\n    return K [ n ] [ W ]\n", "PROGRAM_DECIMAL_OCTAL_CONVERSION": "def decToOctal ( n ) :\n    octalNum = [ 0 ] * 100 ;\n    i = 0 ;\n    while ( n != 0 ) :\n        octalNum [ i ] = n % 8 ;\n        n = int ( n / 8 ) ;\n        i += 1 ;\n    for j in range ( i - 1 , - 1 , - 1 ) :\n        print ( octalNum [ j ] , end = \"\" ) ;\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M_1": "def countSubSeq ( A , N , M ) :\n    ans = 0\n    h = [ 0 ] * M\n    for i in range ( 0 , N ) :\n        A [ i ] = A [ i ] % M\n        h [ A [ i ] ] = h [ A [ i ] ] + 1\n    for i in range ( 0 , M ) :\n        for j in range ( i , M ) :\n            rem = ( M - ( i + j ) % M ) % M\n            if ( rem < j ) :\n                continue\n            if ( i == j and rem == j ) :\n                ans = ans + h [ i ] * ( h [ i ] - 1 ) * ( h [ i ] - 2 ) / 6\n            elif ( i == j ) :\n                ans = ans + ( h [ i ] * ( h [ i ] - 1 ) * h [ rem ] / 2 )\n            elif ( i == rem ) :\n                ans = ans + h [ i ] * ( h [ i ] - 1 ) * h [ j ] / 2\n            elif ( rem == j ) :\n                ans = ans + h [ j ] * ( h [ j ] - 1 ) * h [ i ] / 2\n            else :\n                ans = ans + h [ i ] * h [ j ] * h [ rem ]\n        return ans\n", "COUNT_FIBONACCI_NUMBERS_GIVEN_RANGE_LOG_TIME": "def countFibs ( low , high ) :\n    f1 , f2 , f3 = 0 , 1 , 1\n    result = 0\n    while ( f1 <= high ) :\n        if ( f1 >= low ) :\n            result += 1\n        f1 = f2\n        f2 = f3\n        f3 = f1 + f2\n    return result\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT_1": "def isPowerOfFour ( n ) :\n    count = 0\n    if ( n and ( not ( n & ( n - 1 ) ) ) ) :\n        while ( n > 1 ) :\n            n >>= 1\n            count += 1\n        if ( count % 2 == 0 ) :\n            return True\n        else :\n            return False\n", "FIND_SUM_EVEN_FACTORS_NUMBER": "def sumofFactors ( n ) :\n    if ( n % 2 != 0 ) :\n        return 0\n    res = 1\n    for i in range ( 2 , ( int ) ( math.sqrt ( n ) ) + 1 ) :\n        count = 0\n        curr_sum = 1\n        curr_term = 1\n        while ( n % i == 0 ) :\n            count = count + 1\n            n = n // i\n            if ( i == 2 and count == 1 ) :\n                curr_sum = 0\n            curr_term = curr_term * i\n            curr_sum = curr_sum + curr_term\n        res = res * curr_sum\n    if ( n >= 2 ) :\n        res = res * ( 1 + n )\n    return res\n", "FIND_SUM_NON_REPEATING_DISTINCT_ELEMENTS_ARRAY": "def findSum ( arr , n ) :\n    s = set ( )\n    sum = 0\n    for i in range ( n ) :\n        if arr [ i ] not in s :\n            s.add ( arr [ i ] )\n    for i in s :\n        sum = sum + i\n    return sum\n", "DYNAMIC_PROGRAMMING_SET_17_PALINDROME_PARTITIONING_1": "def minPalPartion ( str1 ) :\n    n = len ( str1 ) ;\n    C = [ 0 ] * ( n + 1 ) ;\n    P = [ [ False for x in range ( n + 1 ) ] for y in range ( n + 1 ) ] ;\n    for i in range ( n ) :\n        P [ i ] [ i ] = True ;\n    for L in range ( 2 , n + 1 ) :\n        for i in range ( n - L + 1 ) :\n            j = i + L - 1 ;\n            if ( L == 2 ) :\n                P [ i ] [ j ] = ( str1 [ i ] == str1 [ j ] ) ;\n            else :\n                P [ i ] [ j ] = ( ( str1 [ i ] == str1 [ j ] ) and P [ i + 1 ] [ j - 1 ] ) ;\n    for i in range ( n ) :\n        if ( P [ 0 ] [ i ] == True ) :\n            C [ i ] = 0 ;\n        else :\n            C [ i ] = sys.maxsize ;\n            for j in range ( i ) :\n                if ( P [ j + 1 ] [ i ] == True and 1 + C [ j ] < C [ i ] ) :\n                    C [ i ] = 1 + C [ j ] ;\n    return C [ n - 1 ] ;\n", "MINIMUM_POSITIVE_POINTS_TO_REACH_DESTINATION": "def minInitialPoints ( points ) :\n    dp = [ [ 0 for x in range ( C + 1 ) ] for y in range ( R + 1 ) ]\n    m , n = R , C\n    if points [ m - 1 ] [ n - 1 ] > 0 :\n        dp [ m - 1 ] [ n - 1 ] = 1\n    else :\n        dp [ m - 1 ] [ n - 1 ] = abs ( points [ m - 1 ] [ n - 1 ] ) + 1\n    for i in range ( m - 2 , - 1 , - 1 ) :\n        dp [ i ] [ n - 1 ] = max ( dp [ i + 1 ] [ n - 1 ] - points [ i ] [ n - 1 ] , 1 )\n    for i in range ( 2 , - 1 , - 1 ) :\n        dp [ m - 1 ] [ i ] = max ( dp [ m - 1 ] [ i + 1 ] - points [ m - 1 ] [ i ] , 1 )\n    for i in range ( m - 2 , - 1 , - 1 ) :\n        for j in range ( n - 2 , - 1 , - 1 ) :\n            min_points_on_exit = min ( dp [ i + 1 ] [ j ] , dp [ i ] [ j + 1 ] )\n            dp [ i ] [ j ] = max ( min_points_on_exit - points [ i ] [ j ] , 1 )\n    return dp [ 0 ] [ 0 ]\n", "COUNT_OF_PAIRS_SATISFYING_THE_GIVEN_CONDITION": "def countPair ( a , b ) :\n    s = str ( b )\n    i = 0\n    while i < ( len ( s ) ) :\n        if ( s [ i ] != '9' ) :\n            break\n        i += 1\n    result = 0\n    if ( i == len ( s ) ) :\n        result = a * len ( s )\n    else :\n        result = a * ( len ( s ) - 1 )\n    return result\n", "SURVIVAL": "def survival ( S , N , M ) :\n    if ( ( ( N * 6 ) < ( M * 7 ) and S > 6 ) or M > N ) :\n        print ( \"No\" )\n    else :\n        days = ( M * S ) / N\n        if ( ( ( M * S ) % N ) != 0 ) :\n            days += 1\n        print ( \"Yes \" ) ,\n        print ( days )\n", "INTERLEAVE_FIRST_HALF_QUEUE_SECOND_HALF": "def interLeaveQueue ( q ) :\n    if ( q.qsize ( ) % 2 != 0 ) :\n        print ( \"Input even number of integers.\" )\n    s = [ ]\n    halfSize = int ( q.qsize ( ) / 2 )\n    for i in range ( halfSize ) :\n        s.append ( q.queue [ 0 ] )\n        q.get ( )\n    while len ( s ) != 0 :\n        q.put ( s [ - 1 ] )\n        s.pop ( )\n    for i in range ( halfSize ) :\n        q.put ( q.queue [ 0 ] )\n        q.get ( )\n    for i in range ( halfSize ) :\n        s.append ( q.queue [ 0 ] )\n        q.get ( )\n    while len ( s ) != 0 :\n        q.put ( s [ - 1 ] )\n        s.pop ( )\n        q.put ( q.queue [ 0 ] )\n        q.get ( )\n", "INTEGER_POSITIVE_VALUE_POSITIVE_NEGATIVE_VALUE_ARRAY_1": "def findInteger ( arr , n ) :\n    neg = 0\n    pos = 0\n    sum = 0\n    for i in range ( 0 , n ) :\n        sum += arr [ i ]\n        if ( arr [ i ] < 0 ) :\n            neg += 1\n        else :\n            pos += 1\n    return ( sum / abs ( neg - pos ) )\n", "FIND_SUM_EVEN_INDEX_BINOMIAL_COEFFICIENTS": "def evenSum ( n ) :\n    C = [ [ 0 for x in range ( n + 1 ) ] for y in range ( n + 1 ) ]\n    for i in range ( 0 , n + 1 ) :\n        for j in range ( 0 , min ( i , n + 1 ) ) :\n            if j == 0 or j == i :\n                C [ i ] [ j ] = 1\n            else :\n                C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ]\n    sum = 0 ;\n    for i in range ( 0 , n + 1 ) :\n        if n % 2 == 0 :\n            sum = sum + C [ n ] [ i ]\n    return sum\n", "DELANNOY_NUMBER": "def dealnnoy ( n , m ) :\n    if ( m == 0 or n == 0 ) :\n        return 1\n    return dealnnoy ( m - 1 , n ) + dealnnoy ( m - 1 , n - 1 ) + dealnnoy ( m , n - 1 )\n", "FIND_THE_LARGEST_SUBARRAY_WITH_0_SUM": "def maxLen ( arr ) :\n    max_len = 0\n    for i in range ( len ( arr ) ) :\n        curr_sum = 0\n        for j in range ( i , len ( arr ) ) :\n            curr_sum += arr [ j ]\n            if curr_sum == 0 :\n                max_len = max ( max_len , j - i + 1 )\n    return max_len\n", "NEXT_POWER_OF_2": "def nextPowerOf2 ( n ) :\n    count = 0 ;\n    if ( n and not ( n & ( n - 1 ) ) ) :\n        return n\n    while ( n != 0 ) :\n        n >>= 1\n        count += 1\n    return 1 << count ;\n", "LONGEST_GEOMETRIC_PROGRESSION": "def lenOfLongestGP ( sett , n ) :\n    if n < 2 :\n        return n\n    if n == 2 :\n        return ( sett [ 1 ] % sett [ 0 ] == 0 )\n    sett.sort ( )\n    L = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    llgp = 1\n    for i in range ( 0 , n ) :\n        if sett [ n - 1 ] % sett [ i ] == 0 :\n            L [ i ] [ n - 1 ] = 2\n        else :\n            L [ i ] [ n - 1 ] = 1\n    for j in range ( n - 2 , 0 , - 1 ) :\n        i = j - 1\n        k = j + 1\n        while i >= 0 and k <= n - 1 :\n            if sett [ i ] * sett [ k ] < sett [ j ] * sett [ j ] :\n                k += 1\n            elif sett [ i ] * sett [ k ] > sett [ j ] * sett [ j ] :\n                if sett [ j ] % sett [ i ] == 0 :\n                    L [ i ] [ j ] = 2\n                else :\n                    L [ i ] [ j ] = 1\n                i -= 1\n            else :\n                L [ i ] [ j ] = L [ j ] [ k ] + 1\n                if L [ i ] [ j ] > llgp :\n                    llgp = L [ i ] [ j ]\n                i -= 1\n                k + 1\n        while i >= 0 :\n            if sett [ j ] % sett [ i ] == 0 :\n                L [ i ] [ j ] = 2\n            else :\n                L [ i ] [ j ] = 1\n            i -= 1\n    return llgp\n", "DYNAMIC_PROGRAMMING_SET_6_MIN_COST_PATH": "def minCost ( cost , m , n ) :\n    tc = [ [ 0 for x in range ( C ) ] for x in range ( R ) ]\n    tc [ 0 ] [ 0 ] = cost [ 0 ] [ 0 ]\n    for i in range ( 1 , m + 1 ) :\n        tc [ i ] [ 0 ] = tc [ i - 1 ] [ 0 ] + cost [ i ] [ 0 ]\n    for j in range ( 1 , n + 1 ) :\n        tc [ 0 ] [ j ] = tc [ 0 ] [ j - 1 ] + cost [ 0 ] [ j ]\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            tc [ i ] [ j ] = min ( tc [ i - 1 ] [ j - 1 ] , tc [ i - 1 ] [ j ] , tc [ i ] [ j - 1 ] ) + cost [ i ] [ j ]\n    return tc [ m ] [ n ]\n", "PROGRAM_DISTANCE_TWO_POINTS_EARTH": "def distance ( lat1 , lat2 , lon1 , lon2 ) :\n    lon1 = radians ( lon1 )\n    lon2 = radians ( lon2 )\n    lat1 = radians ( lat1 )\n    lat2 = radians ( lat2 )\n    dlon = lon2 - lon1\n    dlat = lat2 - lat1\n    a = sin ( dlat / 2 ) ** 2 + cos ( lat1 ) * cos ( lat2 ) * sin ( dlon / 2 ) ** 2\n    c = 2 * asin ( sqrt ( a ) )\n    r = 6371\n    return ( c * r )\n", "BIN_PACKING_PROBLEM_MINIMIZE_NUMBER_OF_USED_BINS": "def nextfit ( weight , c ) :\n    res = 0\n    rem = c\n    for _ in range ( len ( weight ) ) :\n        if rem >= weight [ _ ] :\n            rem = rem - weight [ _ ]\n        else :\n            res += 1\n            rem = c - weight [ _ ]\n    return res\n", "FIND_SUBARRAY_WITH_GIVEN_SUM_1": "def subArraySum ( arr , n , sum ) :\n    curr_sum = arr [ 0 ]\n    start = 0\n    i = 1\n    while i <= n :\n        while curr_sum > sum and start < i - 1 :\n            curr_sum = curr_sum - arr [ start ]\n            start += 1\n        if curr_sum == sum :\n            print ( \"Sum found between indexes\" )\n            print ( \"%d and %d\" % ( start , i - 1 ) )\n            return 1\n        if i < n :\n            curr_sum = curr_sum + arr [ i ]\n        i += 1\n    print ( \"No subarray found\" )\n    return 0\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM_1": "def KnapSack ( val , wt , n , W ) :\n    dp = [ 0 ] * ( W + 1 ) ;\n    for i in range ( n ) :\n        for j in range ( W , wt [ i ] , - 1 ) :\n            dp [ j ] = max ( dp [ j ] , val [ i ] + dp [ j - wt [ i ] ] ) ;\n    return dp [ W ] ;\n", "FIND_VALUE_OF_Y_MOD_2_RAISED_TO_POWER_X": "def yMod ( y , x ) :\n    return ( y % pow ( 2 , x ) )\n", "SUM_SERIES_23_45_67_89_UPTO_N_TERMS": "def seriesSum ( n ) :\n    i = 1 ;\n    res = 0.0 ;\n    sign = True ;\n    while ( n > 0 ) :\n        n = n - 1 ;\n        if ( sign ) :\n            sign = False ;\n            res = res + ( i + 1 ) / ( i + 2 ) ;\n            i = i + 2 ;\n        else :\n            sign = True ;\n            res = res - ( i + 1 ) / ( i + 2 ) ;\n            i = i + 2 ;\n    return res ;\n", "LENGTH_LONGEST_STRICT_BITONIC_SUBSEQUENCE": "def longLenStrictBitonicSub ( arr , n ) :\n    inc , dcr = dict ( ) , dict ( )\n    len_inc , len_dcr = [ 0 ] * n , [ 0 ] * n\n    longLen = 0\n    for i in range ( n ) :\n        len = 0\n        if inc.get ( arr [ i ] - 1 ) in inc.values ( ) :\n            len = inc.get ( arr [ i ] - 1 )\n        inc [ arr [ i ] ] = len_inc [ i ] = len + 1\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        len = 0\n        if dcr.get ( arr [ i ] - 1 ) in dcr.values ( ) :\n            len = dcr.get ( arr [ i ] - 1 )\n        dcr [ arr [ i ] ] = len_dcr [ i ] = len + 1\n    for i in range ( n ) :\n        if longLen < ( len_inc [ i ] + len_dcr [ i ] - 1 ) :\n            longLen = len_inc [ i ] + len_dcr [ i ] - 1\n    return longLen\n", "MAXIMUM_DISTANCE_TWO_OCCURRENCES_ELEMENT_ARRAY": "def maxDistance ( arr , n ) :\n    mp = { }\n    maxDict = 0\n    for i in range ( n ) :\n        if arr [ i ] not in mp.keys ( ) :\n            mp [ arr [ i ] ] = i\n        else :\n            maxDict = max ( maxDict , i - mp [ arr [ i ] ] )\n    return maxDict\n", "FIND_RECTANGLE_BINARY_MATRIX_CORNERS_1_1": "def isRectangle ( matrix ) :\n    rows = len ( matrix )\n    if ( rows == 0 ) :\n        return False\n    columns = len ( matrix [ 0 ] )\n    table = { }\n    for i in range ( rows ) :\n        for j in range ( columns - 1 ) :\n            for k in range ( j + 1 , columns ) :\n                if ( matrix [ i ] [ j ] == 1 and matrix [ i ] [ k ] == 1 ) :\n                    if ( j in table and k in table [ j ] ) :\n                        return True\n                    if ( k in table and j in table [ k ] ) :\n                        return True\n                    if j not in table :\n                        table [ j ] = set ( )\n                    if k not in table :\n                        table [ k ] = set ( )\n                    table [ j ].add ( k )\n                    table [ k ].add ( j )\n    return False\n", "COUNT_MINIMUM_NUMBER_SUBSETS_SUBSEQUENCES_CONSECUTIVE_NUMBERS": "def numofsubset ( arr , n ) :\n    x = sorted ( arr )\n    count = 1\n    for i in range ( 0 , n - 1 ) :\n        if ( x [ i ] + 1 != x [ i + 1 ] ) :\n            count = count + 1\n    return count\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY": "def maxSubArraySum ( a , size ) :\n    max_so_far = - maxint - 1\n    max_ending_here = 0\n    for i in range ( 0 , size ) :\n        max_ending_here = max_ending_here + a [ i ]\n        if ( max_so_far < max_ending_here ) :\n            max_so_far = max_ending_here\n        if max_ending_here < 0 :\n            max_ending_here = 0\n    return max_so_far\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR_2": "def getRemainder ( num , divisor ) :\n    while ( num >= divisor ) :\n        num -= divisor ;\n    return num ;\n", "CHECK_LARGE_NUMBER_DIVISIBLE_4_NOT": "def check ( st ) :\n    n = len ( st )\n    if ( n == 0 ) :\n        return False\n    if ( n == 1 ) :\n        return ( ( st [ 0 ] - '0' ) % 4 == 0 )\n    last = ( int ) ( st [ n - 1 ] )\n    second_last = ( int ) ( st [ n - 2 ] )\n    return ( ( second_last * 10 + last ) % 4 == 0 )\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_1": "def getSingle ( arr , n ) :\n    result = 0\n    for i in range ( 0 , INT_SIZE ) :\n        sm = 0\n        x = ( 1 << i )\n        for j in range ( 0 , n ) :\n            if ( arr [ j ] & x ) :\n                sm = sm + 1\n        if ( sm % 3 ) :\n            result = result | x\n    return result\n", "NUMBER_RECTANGLES_NM_GRID": "def rectCount ( n , m ) :\n    return ( m * n * ( n + 1 ) * ( m + 1 ) ) // 4\n", "MAXIMUM_POINTS_INTERSECTION_N_CIRCLES": "def intersection ( n ) :\n    return n * ( n - 1 ) ;\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY_2": "def printDistinct ( arr , n ) :\n    s = dict ( ) ;\n    for i in range ( n ) :\n        if ( arr [ i ] not in s.keys ( ) ) :\n            s [ arr [ i ] ] = arr [ i ] ;\n            print ( arr [ i ] , end = \" \" ) ;\n", "CHECK_ROWS_MATRIX_CIRCULAR_ROTATIONS": "def isPermutedMatrix ( mat , n ) :\n    str_cat = \"\"\n    for i in range ( n ) :\n        str_cat = str_cat + \"-\" + str ( mat [ 0 ] [ i ] )\n    str_cat = str_cat + str_cat\n    for i in range ( 1 , n ) :\n        curr_str = \"\"\n        for j in range ( n ) :\n            curr_str = curr_str + \"-\" + str ( mat [ i ] [ j ] )\n        if ( str_cat.find ( curr_str ) ) :\n            return True\n    return False\n", "SUM_PAIRWISE_PRODUCTS": "def findSum ( n ) :\n    sm = 0\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( i , n + 1 ) :\n            sm = sm + i * j\n    return sm\n", "SORT_3_INTEGERS_WITHOUT_USING_CONDITION_USING_MAX_FUNCTION": "def printSorted ( a , b , c ) :\n    get_max = max ( a , max ( b , c ) )\n    get_min = - max ( - a , max ( - b , - c ) )\n    get_mid = ( a + b + c ) - ( get_max + get_min )\n    print ( get_min , \" \" , get_mid , \" \" , get_max )\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER_2": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 )\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY_2": "def find_extra_element_index ( arrA , arrB ) :\n    extra_element = sum ( arrA ) - sum ( arrB )\n    return arrA.index ( extra_element )\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM_1": "def printSubsequences ( arr , n ) :\n    opsize = math.pow ( 2 , n )\n    for counter in range ( 1 , ( int ) ( opsize ) ) :\n        for j in range ( 0 , n ) :\n            if ( counter & ( 1 << j ) ) :\n                print ( arr [ j ] , end = \" \" )\n        print ( )\n", "N_BONACCI_NUMBERS": "def bonacciseries ( n , m ) :\n    a = [ 0 ] * m\n    a [ n - 1 ] = 1\n    for i in range ( n , m ) :\n        for j in range ( i - n , i ) :\n            a [ i ] = a [ i ] + a [ j ]\n    for i in range ( 0 , m ) :\n        print ( a [ i ] , end = \" \" )\n", "LOWER_CASE_UPPER_CASE_INTERESTING_FACT": "def to_upper ( string ) :\n    for i in range ( len ( string ) ) :\n        if ( 'a' <= string [ i ] <= 'z' ) :\n            string = ( string [ 0 : i ] + chr ( ord ( string [ i ] ) - ord ( 'a' ) + ord ( 'A' ) ) + string [ i + 1 : ] )\n    return string ;\n", "PRINT_BRACKET_NUMBER": "def printBracketNumber ( exp , n ) :\n    left_bnum = 1\n    right_bnum = list ( )\n    for i in range ( n ) :\n        if exp [ i ] == '(' :\n            print ( left_bnum , end = \" \" )\n            right_bnum.append ( left_bnum )\n            left_bnum += 1\n        elif exp [ i ] == ')' :\n            print ( right_bnum [ - 1 ] , end = \" \" )\n            right_bnum.pop ( )\n", "MAXIMUM_PRODUCT_OF_4_ADJACENT_ELEMENTS_IN_MATRIX": "def FindMaxProduct ( arr , n ) :\n    max = 0\n    for i in range ( n ) :\n        for j in range ( n ) :\n            if ( ( j - 3 ) >= 0 ) :\n                result = ( arr [ i ] [ j ] * arr [ i ] [ j - 1 ] * arr [ i ] [ j - 2 ] * arr [ i ] [ j - 3 ] )\n                if ( max < result ) :\n                    max = result\n            if ( ( i - 3 ) >= 0 ) :\n                result = ( arr [ i ] [ j ] * arr [ i - 1 ] [ j ] * arr [ i - 2 ] [ j ] * arr [ i - 3 ] [ j ] )\n                if ( max < result ) :\n                    max = result\n            if ( ( i - 3 ) >= 0 and ( j - 3 ) >= 0 ) :\n                result = ( arr [ i ] [ j ] * arr [ i - 1 ] [ j - 1 ] * arr [ i - 2 ] [ j - 2 ] * arr [ i - 3 ] [ j - 3 ] )\n                if ( max < result ) :\n                    max = result\n    return max\n", "LONGEST_SUBARRAY_SUM_DIVISIBLE_K": "def longSubarrWthSumDivByK ( arr , n , k ) :\n    um = { i : 0 for i in range ( 8 ) }\n    mod_arr = [ 0 for i in range ( n ) ]\n    max = 0\n    curr_sum = 0\n    for i in range ( n ) :\n        curr_sum += arr [ i ]\n        mod_arr [ i ] = ( ( curr_sum % k ) + k ) % k\n    for i in range ( n ) :\n        if ( mod_arr [ i ] == 0 ) :\n            max = i + 1\n        elif ( mod_arr [ i ] in um ) :\n            um [ mod_arr [ i ] ] = i\n        else :\n            if ( max < ( i - um [ mod_arr [ i ] ] ) ) :\n                max = i - um [ mod_arr [ i ] ]\n    return max\n", "CAESAR_CIPHER": "def encrypt ( text , s ) :\n    result = \"\"\n    for i in range ( len ( text ) ) :\n        char = text [ i ]\n        if ( char.isupper ( ) ) :\n            result += chr ( ( ord ( char ) + s - 65 ) % 26 + 65 )\n        else :\n            result += chr ( ( ord ( char ) + s - 97 ) % 26 + 97 )\n    return result\n", "SUBARRAYS_DISTINCT_ELEMENTS": "def sumoflength ( arr , n ) :\n    s = [ ]\n    j = 0\n    ans = 0\n    for i in range ( n ) :\n        while ( j < n and ( arr [ j ] not in s ) ) :\n            s.append ( arr [ j ] )\n            j += 1\n        ans += ( ( j - i ) * ( j - i + 1 ) ) // 2\n        s.remove ( arr [ i ] )\n    return ans\n", "K_TH_ELEMENT_TWO_SORTED_ARRAYS": "def kth ( arr1 , arr2 , m , n , k ) :\n    sorted1 = [ 0 ] * ( m + n )\n    i = 0\n    j = 0\n    d = 0\n    while ( i < m and j < n ) :\n        if ( arr1 [ i ] < arr2 [ j ] ) :\n            sorted1 [ d ] = arr1 [ i ]\n            i += 1\n        else :\n            sorted1 [ d ] = arr2 [ j ]\n            j += 1\n        d += 1\n    while ( i < m ) :\n        sorted1 [ d ] = arr1 [ i ]\n        d += 1\n        i += 1\n    while ( j < n ) :\n        sorted1 [ d ] = arr2 [ j ]\n        d += 1\n        j += 1\n    return sorted1 [ k - 1 ]\n", "REMOVE_CONSECUTIVE_DUPLICATES_STRING": "def removeDuplicates ( S ) :\n    n = len ( S )\n    if ( n < 2 ) :\n        return\n    j = 0\n    for i in range ( n ) :\n        if ( S [ j ] != S [ i ] ) :\n            j += 1\n            S [ j ] = S [ i ]\n    j += 1\n    S = S [ : j ]\n    return S\n", "MAJORITY_ELEMENT": "def findMajority ( arr , n ) :\n    maxCount = 0 ;\n    index = - 1\n    for i in range ( n ) :\n        count = 0\n        for j in range ( n ) :\n            if ( arr [ i ] == arr [ j ] ) :\n                count += 1\n        if ( count > maxCount ) :\n            maxCount = count\n            index = i\n    if ( maxCount > n // 2 ) :\n        print ( arr [ index ] )\n    else :\n        print ( \"No Majority Element\" )\n", "FUNCTION_COPY_STRING_ITERATIVE_RECURSIVE_1": "def myCopy ( s1 , s2 , index ) :\n    s2 [ index ] = s1 [ index ] ;\n    if ( index == len ( s1 ) - 1 ) :\n        return ;\n    myCopy ( s1 , s2 , index + 1 ) ;\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE_1": "def printCountDP ( dist ) :\n    count = [ 0 ] * ( dist + 1 )\n    count [ 0 ] = 1\n    count [ 1 ] = 1\n    count [ 2 ] = 2\n    for i in range ( 3 , dist + 1 ) :\n        count [ i ] = ( count [ i - 1 ] + count [ i - 2 ] + count [ i - 3 ] )\n    return count [ dist ] ;\n", "DISCRETE_LOGARITHM_FIND_INTEGER_K_AK_CONGRUENT_MODULO_B": "def discreteLogarithm ( a , b , m ) :\n    n = int ( math.sqrt ( m ) + 1 ) ;\n    an = 1 ;\n    for i in range ( n ) :\n        an = ( an * a ) % m ;\n    value = [ 0 ] * m ;\n    cur = an ;\n    for i in range ( 1 , n + 1 ) :\n        if ( value [ cur ] == 0 ) :\n            value [ cur ] = i ;\n        cur = ( cur * an ) % m ;\n    cur = b ;\n    for i in range ( n + 1 ) :\n        if ( value [ cur ] > 0 ) :\n            ans = value [ cur ] * n - i ;\n            if ( ans < m ) :\n                return ans ;\n        cur = ( cur * a ) % m ;\n    return - 1 ;\n", "CHANGE_BITS_CAN_MADE_ONE_FLIP_1": "def isOneFlip ( str ) :\n    sum = 0\n    n = len ( str )\n    for i in range ( 0 , n ) :\n        sum += int ( str [ i ] ) - int ( '0' )\n    return ( sum == n - 1 or sum == 1 )\n", "FIND_PAIRS_IN_ARRAY_WHOSE_SUMS_ALREADY_EXIST_IN_ARRAY": "def findPair ( arr , n ) :\n    found = False\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            for k in range ( 0 , n ) :\n                if ( arr [ i ] + arr [ j ] == arr [ k ] ) :\n                    print ( arr [ i ] , arr [ j ] )\n                    found = True\n    if ( found == False ) :\n        print ( \"Not exist\" )\n", "MODULAR_MULTIPLICATIVE_INVERSE_1_N": "def modularInverse ( n , prime ) :\n    dp = [ 0 ] * ( n + 1 )\n    dp [ 0 ] = dp [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        dp [ i ] = dp [ prime % i ] * ( prime - prime // i ) % prime\n    for i in range ( 1 , n + 1 ) :\n        print ( dp [ i ] , end = \" \" )\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE_1": "def shufleArray ( a , f , l ) :\n    if ( l > f ) :\n        return\n    if ( l - f == 1 ) :\n        return\n    mid = int ( ( f + l ) / 2 )\n    temp = mid + 1\n    mmid = int ( ( f + mid ) / 2 )\n    for i in range ( mmid + 1 , mid + 1 ) :\n        ( a [ i ] , a [ temp ] ) = ( a [ temp ] , a [ i ] )\n        temp += 1\n    shufleArray ( a , f , mid )\n    shufleArray ( a , mid + 1 , l )\n", "N_TH_ROOT_NUMBER": "def nthRoot ( A , N ) :\n    xPre = random.randint ( 1 , 101 ) % 10\n    eps = 0.001\n    delX = 2147483647\n    xK = 0.0\n    while ( delX > eps ) :\n        xK = ( ( N - 1.0 ) * xPre + A / pow ( xPre , N - 1 ) ) / N\n        delX = abs ( xK - xPre )\n        xPre = xK ;\n    return xK\n", "NUMBER_OF_WAYS_TO_ARRANGE_N_ITEMS_UNDER_GIVEN_CONSTRAINTS": "def waysToArrange ( N , K , k ) :\n    C = np.zeros ( ( N + 1 , N + 1 ) )\n    for i in range ( N + 1 ) :\n        for j in range ( i + 1 ) :\n            if ( j == 0 or j == i ) :\n                C [ i ] [ j ] = 1\n            else :\n                C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] )\n    dp = np.zeros ( ( K + 1 ) )\n    count = 0\n    dp [ 0 ] = 1\n    for i in range ( K ) :\n        dp [ i + 1 ] = ( dp [ i ] * C [ count + k [ i ] - 1 ] [ k [ i ] - 1 ] )\n        count += k [ i ]\n    return dp [ K ]\n", "TEMPLE_OFFERINGS": "def offeringNumber ( n , templeHeight ) :\n    sum = 0\n    for i in range ( n ) :\n        left = 0\n        right = 0\n        for j in range ( i - 1 , - 1 , - 1 ) :\n            if ( templeHeight [ j ] < templeHeight [ j + 1 ] ) :\n                left += 1\n            else :\n                break\n        for j in range ( i + 1 , n ) :\n            if ( templeHeight [ j ] < templeHeight [ j - 1 ] ) :\n                right += 1\n            else :\n                break\n        sum += max ( right , left ) + 1\n    return sum\n", "CENTER_ELEMENT_OF_MATRIX_EQUALS_SUMS_OF_HALF_DIAGONALS": "def HalfDiagonalSums ( mat , n ) :\n    diag1_left = 0\n    diag1_right = 0\n    diag2_left = 0\n    diag2_right = 0\n    i = 0\n    j = n - 1\n    while i < n :\n        if ( i < n // 2 ) :\n            diag1_left += mat [ i ] [ i ]\n            diag2_left += mat [ j ] [ i ]\n        elif ( i > n // 2 ) :\n            diag1_right += mat [ i ] [ i ]\n            diag2_right += mat [ j ] [ i ]\n        i += 1\n        j -= 1\n    return ( diag1_left == diag2_right and diag2_right == diag2_left and diag1_right == diag2_left and diag2_right == mat [ n // 2 ] [ n // 2 ] )\n", "COUNT_FACTORIAL_NUMBERS_IN_A_GIVEN_RANGE": "def countFact ( low , high ) :\n    fact = 1\n    x = 1\n    while ( fact < low ) :\n        fact = fact * x\n        x += 1\n    res = 0\n    while ( fact <= high ) :\n        res += 1\n        fact = fact * x\n        x += 1\n    return res\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE_1": "def reverseStr ( str ) :\n    n = len ( str )\n    i , j = 0 , n - 1\n    while i < j :\n        str [ i ] , str [ j ] = str [ j ] , str [ i ]\n        i += 1\n        j -= 1\n", "FIND_MINIMUM_ADJUSTMENT_COST_OF_AN_ARRAY": "def minAdjustmentCost ( A , n , target ) :\n    dp = [ [ 0 for i in range ( M + 1 ) ] for i in range ( n ) ]\n    for j in range ( M + 1 ) :\n        dp [ 0 ] [ j ] = abs ( j - A [ 0 ] )\n    for i in range ( 1 , n ) :\n        for j in range ( M + 1 ) :\n            dp [ i ] [ j ] = 100000000\n            for k in range ( max ( j - target , 0 ) , min ( M , j + target ) + 1 ) :\n                dp [ i ] [ j ] = min ( dp [ i ] [ j ] , dp [ i - 1 ] [ k ] + abs ( A [ i ] - j ) )\n    res = 10000000\n    for j in range ( M + 1 ) :\n        res = min ( res , dp [ n - 1 ] [ j ] )\n    return res\n", "COUNT_FREQUENCY_K_MATRIX_SIZE_N_MATRIXI_J_IJ": "def find ( n , k ) :\n    if ( n + 1 >= k ) :\n        return ( k - 1 )\n    else :\n        return ( 2 * n + 1 - k )\n", "MINIMUM_FLIP_REQUIRED_MAKE_BINARY_MATRIX_SYMMETRIC_1": "def minimumflip ( mat , n ) :\n    flip = 0\n    for i in range ( n ) :\n        for j in range ( i ) :\n            if mat [ i ] [ j ] != mat [ j ] [ i ] :\n                flip += 1\n    return flip\n", "NTH_PALINDROME_K_DIGITS": "def nthPalindrome ( n , k ) :\n    if ( k & 1 ) :\n        temp = k // 2\n    else :\n        temp = k // 2 - 1\n    palindrome = 10 ** temp\n    palindrome = palindrome + n - 1\n    print ( palindrome , end = \"\" )\n    if ( k & 1 ) :\n        palindrome = palindrome // 10\n    while ( palindrome ) :\n        print ( palindrome % 10 , end = \"\" )\n        palindrome = palindrome // 10\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE_1": "def lis ( arr ) :\n    n = len ( arr )\n    lis = [ 1 ] * n\n    for i in range ( 1 , n ) :\n        for j in range ( 0 , i ) :\n            if arr [ i ] > arr [ j ] and lis [ i ] < lis [ j ] + 1 :\n                lis [ i ] = lis [ j ] + 1\n    maximum = 0\n    for i in range ( n ) :\n        maximum = max ( maximum , lis [ i ] )\n    return maximum\n", "PATH_MAXIMUM_AVERAGE_VALUE": "def maxAverageOfPath ( cost , N ) :\n    dp = [ [ 0 for i in range ( N + 1 ) ] for j in range ( N + 1 ) ]\n    dp [ 0 ] [ 0 ] = cost [ 0 ] [ 0 ]\n    for i in range ( 1 , N ) :\n        dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ] + cost [ i ] [ 0 ]\n    for j in range ( 1 , N ) :\n        dp [ 0 ] [ j ] = dp [ 0 ] [ j - 1 ] + cost [ 0 ] [ j ]\n    for i in range ( 1 , N ) :\n        for j in range ( 1 , N ) :\n            dp [ i ] [ j ] = max ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) + cost [ i ] [ j ]\n    return dp [ N - 1 ] [ N - 1 ] / ( 2 * N - 1 )\n", "PROGRAM_COUNT_OCCURRENCE_GIVEN_CHARACTER_STRING": "def count ( s , c ) :\n    res = 0\n    for i in range ( len ( s ) ) :\n        if ( s [ i ] == c ) :\n            res = res + 1\n    return res\n", "KTH_SMALLESTLARGEST_ELEMENT_UNSORTED_ARRAY": "def kthSmallest ( arr , n , k ) :\n    arr.sort ( )\n    return arr [ k - 1 ]\n", "CONVERT_ALTERNATE_CHARACTERS_STRING_UPPER_CASE": "def convertOpposite ( str ) :\n    ln = len ( str )\n    for i in range ( ln ) :\n        if str [ i ] >= 'a' and str [ i ] <= 'z' :\n            str [ i ] = chr ( ord ( str [ i ] ) - 32 )\n        elif str [ i ] >= 'A' and str [ i ] <= 'Z' :\n            str [ i ] = chr ( ord ( str [ i ] ) + 32 )\n", "SUM_SERIES_555555_N_TERMS": "def sumOfSeries ( n ) :\n    return ( int ) ( 0.6172 * ( pow ( 10 , n ) - 1 ) - 0.55 * n )\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION": "def MatrixChainOrder ( p , i , j ) :\n    if i == j :\n        return 0\n    _min = sys.maxsize\n    for k in range ( i , j ) :\n        count = ( MatrixChainOrder ( p , i , k ) + MatrixChainOrder ( p , k + 1 , j ) + p [ i - 1 ] * p [ k ] * p [ j ] )\n        if count < _min :\n            _min = count ;\n    return _min ;\n", "COUNT_SET_BITS_IN_AN_INTEGER_3": "def countSetBits ( n ) :\n    if ( n == 0 ) :\n        return 0\n    else :\n        return 1 + countSetBits ( n & ( n - 1 ) )\n", "MINIMUM_LENGTH_UNSORTED_SUBARRAY_SORTING_WHICH_MAKES_THE_COMPLETE_ARRAY_SORTED": "def printUnsorted ( arr , n ) :\n    e = n - 1\n    for s in range ( 0 , n - 1 ) :\n        if arr [ s ] > arr [ s + 1 ] :\n            break\n    if s == n - 1 :\n        print ( \"The complete array is sorted\" )\n        exit ( )\n    e = n - 1\n    while e > 0 :\n        if arr [ e ] < arr [ e - 1 ] :\n            break\n        e -= 1\n    max = arr [ s ]\n    min = arr [ s ]\n    for i in range ( s + 1 , e + 1 ) :\n        if arr [ i ] > max :\n            max = arr [ i ]\n        if arr [ i ] < min :\n            min = arr [ i ]\n    for i in range ( s ) :\n        if arr [ i ] > min :\n            s = i\n            break\n    i = n - 1\n    while i >= e + 1 :\n        if arr [ i ] < max :\n            e = i\n            break\n        i -= 1\n    print ( \"The unsorted subarray which makes the given array\" )\n    print ( \"sorted lies between the indexes %d and %d\" % ( s , e ) )\n", "STEINS_ALGORITHM_FOR_FINDING_GCD": "def gcd ( a , b ) :\n    if ( a == 0 ) :\n        return b\n    if ( b == 0 ) :\n        return a\n    k = 0\n    while ( ( ( a | b ) & 1 ) == 0 ) :\n        a = a >> 1\n        b = b >> 1\n        k = k + 1\n    while ( ( a & 1 ) == 0 ) :\n        a = a >> 1\n    while ( b != 0 ) :\n        while ( ( b & 1 ) == 0 ) :\n            b = b >> 1\n        if ( a > b ) :\n            temp = a\n            a = b\n            b = temp\n        b = ( b - a )\n    return ( a << k )\n", "HEXAGONAL_NUMBER": "def hexagonalNum ( n ) :\n    return n * ( 2 * n - 1 )\n", "GOOGLE_CASE_GIVEN_SENTENCE": "def convert ( s ) :\n    n = len ( s )\n    s1 = \"\"\n    s1 = s1 + s [ 0 ].lower ( )\n    i = 1\n    while i < n :\n        if ( s [ i ] == ' ' and i <= n ) :\n            s1 = s1 + \" \" + ( s [ i + 1 ] ).lower ( )\n            i = i + 1\n        else :\n            s1 = s1 + ( s [ i ] ).upper ( )\n        i = i + 1\n    return s1\n", "FIND_A_ROTATION_WITH_MAXIMUM_HAMMING_DISTANCE": "def maxHamming ( arr , n ) :\n    brr = [ 0 ] * ( 2 * n + 1 )\n    for i in range ( n ) :\n        brr [ i ] = arr [ i ]\n    for i in range ( n ) :\n        brr [ n + i ] = arr [ i ]\n    maxHam = 0\n    for i in range ( 1 , n ) :\n        currHam = 0\n        k = 0\n        for j in range ( i , i + n ) :\n            if brr [ j ] != arr [ k ] :\n                currHam += 1\n                k = k + 1\n        if currHam == n :\n            return n\n        maxHam = max ( maxHam , currHam )\n    return maxHam\n", "GIVEN_A_NUMBER_N_GENERATE_BIT_PATTERNS_FROM_0_TO_2N_1_SO_THAT_SUCCESSIVE_PATTERNS_DIFFER_BY_ONE_BIT": "def generateGrayarr ( n ) :\n    if ( n <= 0 ) :\n        return\n    arr = list ( )\n    arr.append ( \"0\" )\n    arr.append ( \"1\" )\n    i = 2\n    j = 0\n    while ( True ) :\n        if i >= 1 << n :\n            break\n        for j in range ( i - 1 , - 1 , - 1 ) :\n            arr.append ( arr [ j ] )\n        for j in range ( i ) :\n            arr [ j ] = \"0\" + arr [ j ]\n        for j in range ( i , 2 * i ) :\n            arr [ j ] = \"1\" + arr [ j ]\n        i = i << 1\n    for i in range ( len ( arr ) ) :\n        print ( arr [ i ] )\n", "MINIMUM_SWAPS_REQUIRED_BRING_ELEMENTS_LESS_EQUAL_K_TOGETHER": "def minSwap ( arr , n , k ) :\n    count = 0\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] <= k ) :\n            count = count + 1\n    bad = 0\n    for i in range ( 0 , count ) :\n        if ( arr [ i ] > k ) :\n            bad = bad + 1\n    ans = bad\n    j = count\n    for i in range ( 0 , n ) :\n        if ( j == n ) :\n            break\n        if ( arr [ i ] > k ) :\n            bad = bad - 1\n        if ( arr [ j ] > k ) :\n            bad = bad + 1\n        ans = min ( ans , bad )\n        j = j + 1\n    return ans\n", "FIND_NTH_FIBONACCI_NUMBER_USING_GOLDEN_RATIO": "def fib ( n ) :\n    if n < 6 :\n        return f [ n ]\n    t = 5\n    fn = 5\n    while t < n :\n        fn = round ( fn * PHI )\n        t += 1\n    return fn\n", "SORTING_ARRAY_REVERSE_AROUND_MIDDLE": "def ifPossible ( arr , n ) :\n    cp = [ 0 ] * n\n    cp = arr\n    cp.sort ( )\n    for i in range ( 0 , n ) :\n        if ( not ( arr [ i ] == cp [ i ] ) and not ( arr [ n - 1 - i ] == cp [ i ] ) ) :\n            return False\n    return True\n", "COUNT_ROTATIONS_DIVISIBLE_4": "def countRotations ( n ) :\n    l = len ( n )\n    if ( l == 1 ) :\n        oneDigit = ( int ) ( n [ 0 ] )\n        if ( oneDigit % 4 == 0 ) :\n            return 1\n        return 0\n    count = 0\n    for i in range ( 0 , l - 1 ) :\n        twoDigit = ( int ) ( n [ i ] ) * 10 + ( int ) ( n [ i + 1 ] )\n        if ( twoDigit % 4 == 0 ) :\n            count = count + 1\n    twoDigit = ( int ) ( n [ l - 1 ] ) * 10 + ( int ) ( n [ 0 ] )\n    if ( twoDigit % 4 == 0 ) :\n        count = count + 1\n    return count\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN_2": "def findNth ( n ) :\n    nthElement = 19 + ( n - 1 ) * 9\n    outliersCount = int ( math.log10 ( nthElement ) ) - 1\n    nthElement += 9 * outliersCount\n    return nthElement\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD_1": "def isPrime ( n ) :\n    if ( n <= 1 ) :\n        return False\n    if ( n <= 3 ) :\n        return True\n    if ( n % 2 == 0 or n % 3 == 0 ) :\n        return False\n    i = 5\n    while ( i * i <= n ) :\n        if ( n % i == 0 or n % ( i + 2 ) == 0 ) :\n            return False\n        i = i + 6\n    return True\n", "MINIMUM_NUMBER_SUBSETS_DISTINCT_ELEMENTS_1": "def subset ( arr , n ) :\n    mp = { i : 0 for i in range ( 10 ) }\n    for i in range ( n ) :\n        mp [ arr [ i ] ] += 1\n    res = 0\n    for key , value in mp.items ( ) :\n        res = max ( res , value )\n    return res\n", "RECAMANS_SEQUENCE_1": "def recaman ( n ) :\n    if ( n <= 0 ) :\n        return\n    print ( 0 , \",\" , end = '' )\n    s = set ( [ ] )\n    s.add ( 0 )\n    prev = 0\n    for i in range ( 1 , n ) :\n        curr = prev - i\n        if ( curr < 0 or curr in s ) :\n            curr = prev + i\n        s.add ( curr )\n        print ( curr , \",\" , end = '' )\n        prev = curr\n", "GENERATE_ROTATIONS_GIVEN_STRING_1": "def printRotatedString ( string ) :\n    n = len ( string )\n    temp = string + string\n    for i in range ( n ) :\n        for j in range ( n ) :\n            print ( temp [ i + j ] , end = \"\" )\n        print ( )\n", "FITTING_SHELVES_PROBLEM": "def minSpacePreferLarge ( w , m , n ) :\n    num_m = 0\n    num_n = 0\n    rem = w\n    p = 0\n    q = 0\n    r = 0\n    while ( w >= n ) :\n        p = w / m\n        r = w % m\n        if ( r <= rem ) :\n            num_m = p\n            num_n = q\n            rem = r\n        q += 1\n        w -= n\n    print ( str ( int ( num_m ) ) + \" \" + str ( num_n ) + \" \" + str ( rem ) )\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS_1": "def countStr ( n ) :\n    return ( 1 + ( n * 2 ) + ( n * ( ( n * n ) - 1 ) // 2 ) )\n", "DIVISIBILITY_BY_12_FOR_A_LARGE_NUMBER": "def isDvisibleBy12 ( num ) :\n    if ( len ( num ) >= 3 ) :\n        d1 = int ( num [ len ( num ) - 1 ] ) ;\n        if ( d1 % 2 != 0 ) :\n            return False\n        d2 = int ( num [ len ( num ) - 2 ] )\n        sum = 0\n        for i in range ( 0 , len ( num ) ) :\n            sum += int ( num [ i ] )\n        return ( sum % 3 == 0 and ( d2 * 10 + d1 ) % 4 == 0 )\n    else :\n        number = int ( num )\n        return ( number % 12 == 0 )\n", "DYNAMIC_PROGRAMMING_SET_36_CUT_A_ROPE_TO_MAXIMIZE_PRODUCT_1": "def maxProd ( n ) :\n    if ( n == 2 or n == 3 ) :\n        return ( n - 1 )\n    res = 1\n    while ( n > 4 ) :\n        n -= 3 ;\n        res *= 3 ;\n    return ( n * res )\n", "RETURN_A_PAIR_WITH_MAXIMUM_PRODUCT_IN_ARRAY_OF_INTEGERS": "def maxProduct ( arr , n ) :\n    if ( n < 2 ) :\n        print ( \"No pairs exists\" )\n        return\n    a = arr [ 0 ] ; b = arr [ 1 ]\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] * arr [ j ] > a * b ) :\n                a = arr [ i ] ; b = arr [ j ]\n    print ( \"Max product pair is {\" , a , \",\" , b , \"}\" , sep = \"\" )\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS_2": "def findSum ( n ) :\n    n -= 1\n    sum = 0\n    sum += ( n * ( n + 1 ) ) / 2\n    sum += ( n * ( n + 1 ) * ( 2 * n + 1 ) ) / 6\n    return int ( sum )\n", "PRINT_MATRIX_ANTISPIRAL_FORM": "def antiSpiralTraversal ( m , n , a ) :\n    k = 0\n    l = 0\n    stk = [ ]\n    while ( k <= m and l <= n ) :\n        for i in range ( l , n + 1 ) :\n            stk.append ( a [ k ] [ i ] )\n        k += 1\n        for i in range ( k , m + 1 ) :\n            stk.append ( a [ i ] [ n ] )\n        n -= 1\n        if ( k <= m ) :\n            for i in range ( n , l - 1 , - 1 ) :\n                stk.append ( a [ m ] [ i ] )\n            m -= 1\n        if ( l <= n ) :\n            for i in range ( m , k - 1 , - 1 ) :\n                stk.append ( a [ i ] [ l ] )\n            l += 1\n    while len ( stk ) != 0 :\n        print ( str ( stk [ - 1 ] ) , end = \" \" )\n        stk.pop ( )\n", "DICE_THROW_PROBLEM_1": "def findWays ( f , d , s ) :\n    mem = [ [ 0 for i in range ( s + 1 ) ] for j in range ( d + 1 ) ]\n    mem [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , d + 1 ) :\n        for j in range ( 1 , s + 1 ) :\n            mem [ i ] [ j ] = mem [ i ] [ j - 1 ] + mem [ i - 1 ] [ j - 1 ]\n            if j - f - 1 >= 0 :\n                mem [ i ] [ j ] -= mem [ i - 1 ] [ j - f - 1 ]\n    return mem [ d ] [ s ]\n", "WRITE_A_C_PROGRAM_TO_CALCULATE_POWXN": "def power ( x , y ) :\n    if ( y == 0 ) : return 1\n    elif ( int ( y % 2 ) == 0 ) :\n        return ( power ( x , int ( y / 2 ) ) * power ( x , int ( y / 2 ) ) )\n    else :\n        return ( x * power ( x , int ( y / 2 ) ) * power ( x , int ( y / 2 ) ) )\n", "SMALLEST_WINDOW_CONTAINS_CHARACTERS_STRING": "def findSubString ( str ) :\n    n = len ( str )\n    dist_count = len ( set ( [ x for x in str ] ) )\n    count , start , start_index , min_len = 0 , 0 , - 1 , 9999999999\n    curr_count = defaultdict ( lambda : 0 )\n    for j in range ( n ) :\n        curr_count [ str [ j ] ] += 1\n        if curr_count [ str [ j ] ] == 1 :\n            count += 1\n        if count == dist_count :\n            while curr_count [ str [ start ] ] > 1 :\n                if curr_count [ str [ start ] ] > 1 :\n                    curr_count [ str [ start ] ] -= 1\n                start += 1\n            len_window = j - start + 1\n            if min_len > len_window :\n                min_len = len_window\n                start_index = start\n    return str [ start_index : start_index + min_len ]\n", "CLUSTERINGPARTITIONING_AN_ARRAY_SUCH_THAT_SUM_OF_SQUARE_DIFFERENCES_IS_MINIMUM": "def solve ( i , par , a , n , k , current_ans ) :\n    if ( par > k ) :\n        return 0\n    global ans\n    if ( par == k and i == n - 1 ) :\n        ans = min ( ans , current_ans )\n        return 0\n    for j in range ( i + 1 , n ) :\n        solve ( j , par + 1 , a , n , k , current_ans + ( a [ j ] - a [ i + 1 ] ) * ( a [ j ] - a [ i + 1 ] ) )\n", "PROGRAM_FIND_SMALLEST_LARGEST_WORD_STRING": "def minMaxLengthWords ( inp ) :\n    length = len ( inp )\n    si = ei = 0\n    min_length = length\n    min_start_index = max_length = max_start_index = 0\n    while ei <= length :\n        if ( ei < length ) and ( inp [ ei ] != \" \" ) :\n            ei += 1\n        else :\n            curr_length = ei - si\n            if curr_length < min_length :\n                min_length = curr_length\n                min_start_index = si\n            if curr_length > max_length :\n                max_length = curr_length\n                max_start_index = si\n            ei += 1\n            si = ei\n    minWord = inp [ min_start_index : min_start_index + min_length ]\n    maxWord = inp [ max_start_index : max_length ]\n    print ( \"Minimum length word: \" , minWord )\n    print ( \"Maximum length word: \" , maxWord )\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M_1": "def isPossible ( n , index , modulo , M , arr , dp ) :\n    modulo = ( ( modulo % M ) + M ) % M\n    if ( index == n ) :\n        if ( modulo == 0 ) :\n            return 1\n        return 0\n    if ( dp [ index ] [ modulo ] != - 1 ) :\n        return dp [ index ] [ modulo ]\n    placeAdd = isPossible ( n , index + 1 , modulo + arr [ index ] , M , arr , dp )\n    placeMinus = isPossible ( n , index + 1 , modulo - arr [ index ] , M , arr , dp )\n    res = bool ( placeAdd or placeMinus )\n    dp [ index ] [ modulo ] = res\n    return res\n", "MINIMUM_OPERATION_MAKE_ELEMENTS_EQUAL_ARRAY": "def minOperation ( arr , n ) :\n    Hash = defaultdict ( lambda : 0 )\n    for i in range ( 0 , n ) :\n        Hash [ arr [ i ] ] += 1\n    max_count = 0\n    for i in Hash :\n        if max_count < Hash [ i ] :\n            max_count = Hash [ i ]\n    return n - max_count\n", "HYPERCUBE_GRAPH": "def power ( n ) :\n    if n == 1 :\n        return 2\n    return 2 * power ( n - 1 )\n", "PROGRAM_FIND_CORRELATION_COEFFICIENT": "def correlationCoefficient ( X , Y , n ) :\n    sum_X = 0\n    sum_Y = 0\n    sum_XY = 0\n    squareSum_X = 0\n    squareSum_Y = 0\n    i = 0\n    while i < n :\n        sum_X = sum_X + X [ i ]\n        sum_Y = sum_Y + Y [ i ]\n        sum_XY = sum_XY + X [ i ] * Y [ i ]\n        squareSum_X = squareSum_X + X [ i ] * X [ i ]\n        squareSum_Y = squareSum_Y + Y [ i ] * Y [ i ]\n        i = i + 1\n    corr = ( float ) ( n * sum_XY - sum_X * sum_Y ) /\n        ( float ) ( math.sqrt ( ( n * squareSum_X - sum_X * sum_X ) * ( n * squareSum_Y - sum_Y * sum_Y ) ) )\n    return corr\n", "COUNT_PALINDROMIC_SUBSEQUENCE_GIVEN_STRING": "def countPS ( str ) :\n    N = len ( str )\n    cps = [ [ 0 for i in range ( N + 2 ) ] for j in range ( N + 2 ) ]\n    for i in range ( N ) :\n        cps [ i ] [ i ] = 1\n    for L in range ( 2 , N + 1 ) :\n        for i in range ( N ) :\n            k = L + i - 1\n            if ( k < N ) :\n                if ( str [ i ] == str [ k ] ) :\n                    cps [ i ] [ k ] = ( cps [ i ] [ k - 1 ] + cps [ i + 1 ] [ k ] + 1 )\n                else :\n                    cps [ i ] [ k ] = ( cps [ i ] [ k - 1 ] + cps [ i + 1 ] [ k ] - cps [ i + 1 ] [ k - 1 ] )\n    return cps [ 0 ] [ N - 1 ]\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N_1": "def nextPowerOf2 ( n ) :\n    p = 1\n    if ( n and not ( n & ( n - 1 ) ) ) :\n        return n\n    while ( p < n ) :\n        p <<= 1\n    return p ;\n", "FIND_LAST_DIGIT_FACTORIAL_DIVIDES_FACTORIAL_B": "def computeLastDigit ( A , B ) :\n    variable = 1\n    if ( A == B ) :\n        return 1\n    elif ( ( B - A ) >= 5 ) :\n        return 0\n    else :\n        for i in range ( A + 1 , B + 1 ) :\n            variable = ( variable * ( i % 10 ) ) % 10\n        return variable % 10\n", "NUMBER_SUBSTRINGS_DIVISIBLE_4_STRING_INTEGERS": "def countDivisbleby4 ( s ) :\n    n = len ( s )\n    count = 0 ;\n    for i in range ( 0 , n , 1 ) :\n        if ( s [ i ] == '4' or s [ i ] == '8' or s [ i ] == '0' ) :\n            count += 1\n    for i in range ( 0 , n - 1 , 1 ) :\n        h = ( ord ( s [ i ] ) - ord ( '0' ) ) * 10 + ( ord ( s [ i + 1 ] ) - ord ( '0' ) )\n        if ( h % 4 == 0 ) :\n            count = count + i + 1\n    return count\n", "DECODE_MEDIAN_STRING_ORIGINAL_STRING": "def decodeMedianString ( s ) :\n    l = len ( s )\n    s1 = \"\"\n    if ( l % 2 == 0 ) :\n        isEven = True\n    else :\n        isEven = False\n    for i in range ( 0 , l , 2 ) :\n        if ( isEven ) :\n            s1 = s [ i ] + s1\n            s1 += s [ i + 1 ]\n        else :\n            if ( l - i > 1 ) :\n                s1 += s [ i ]\n                s1 = s [ i + 1 ] + s1\n            else :\n                s1 += s [ i ]\n    return s1\n", "NUMBER_WHICH_HAS_THE_MAXIMUM_NUMBER_OF_DISTINCT_PRIME_FACTORS_IN_RANGE_M_TO_N": "def maximumNumberDistinctPrimeRange ( m , n ) :\n    factorCount = [ 0 ] * ( n + 1 )\n    prime = [ False ] * ( n + 1 )\n    for i in range ( n + 1 ) :\n        factorCount [ i ] = 0\n        prime [ i ] = True\n    for i in range ( 2 , n + 1 ) :\n        if ( prime [ i ] == True ) :\n            factorCount [ i ] = 1\n            for j in range ( i * 2 , n + 1 , i ) :\n                factorCount [ j ] += 1\n                prime [ j ] = False\n    max = factorCount [ m ]\n    num = m\n    for i in range ( m , n + 1 ) :\n        if ( factorCount [ i ] > max ) :\n            max = factorCount [ i ]\n            num = i\n    return num\n", "NUMBER_EQUAL_PAIRS_STRING": "def countPairs ( s ) :\n    cnt = [ 0 for i in range ( 0 , MAX ) ]\n    for i in range ( len ( s ) ) :\n        cnt [ ord ( s [ i ] ) - 97 ] += 1\n    ans = 0\n    for i in range ( 0 , MAX ) :\n        ans += cnt [ i ] * cnt [ i ]\n    return ans\n", "COUNT_NUMBER_WAYS_REACH_DESTINATION_MAZE": "def countPaths ( maze ) :\n    if ( maze [ 0 ] [ 0 ] == - 1 ) :\n        return 0\n    for i in range ( R ) :\n        if ( maze [ i ] [ 0 ] == 0 ) :\n            maze [ i ] [ 0 ] = 1\n        else :\n            break\n    for i in range ( 1 , C , 1 ) :\n        if ( maze [ 0 ] [ i ] == 0 ) :\n            maze [ 0 ] [ i ] = 1\n        else :\n            break\n    for i in range ( 1 , R , 1 ) :\n        for j in range ( 1 , C , 1 ) :\n            if ( maze [ i ] [ j ] == - 1 ) :\n                continue\n            if ( maze [ i - 1 ] [ j ] > 0 ) :\n                maze [ i ] [ j ] = ( maze [ i ] [ j ] + maze [ i - 1 ] [ j ] )\n            if ( maze [ i ] [ j - 1 ] > 0 ) :\n                maze [ i ] [ j ] = ( maze [ i ] [ j ] + maze [ i ] [ j - 1 ] )\n    if ( maze [ R - 1 ] [ C - 1 ] > 0 ) :\n        return maze [ R - 1 ] [ C - 1 ]\n    else :\n        return 0\n", "FIND_MAXIMUM_SUM_POSSIBLE_EQUAL_SUM_THREE_STACKS": "def maxSum ( stack1 , stack2 , stack3 , n1 , n2 , n3 ) :\n    sum1 , sum2 , sum3 = 0 , 0 , 0\n    for i in range ( n1 ) :\n        sum1 += stack1 [ i ]\n    for i in range ( n2 ) :\n        sum2 += stack2 [ i ]\n    for i in range ( n3 ) :\n        sum3 += stack3 [ i ]\n    top1 , top2 , top3 = 0 , 0 , 0\n    ans = 0\n    while ( 1 ) :\n        if ( top1 == n1 or top2 == n2 or top3 == n3 ) :\n            return 0\n        if ( sum1 == sum2 and sum2 == sum3 ) :\n            return sum1\n        if ( sum1 >= sum2 and sum1 >= sum3 ) :\n            sum1 -= stack1 [ top1 ]\n            top1 = top1 + 1\n        elif ( sum2 >= sum3 and sum2 >= sum3 ) :\n            sum2 -= stack2 [ top2 ]\n            top2 = top2 + 1\n        elif ( sum3 >= sum2 and sum3 >= sum1 ) :\n            sum3 -= stack3 [ top3 ]\n            top3 = top3 + 1\n", "MAXIMUM_SUM_SUBSEQUENCE_LEAST_K_DISTANT_ELEMENTS": "def maxSum ( arr , N , k ) :\n    MS = [ 0 for i in range ( N ) ]\n    MS [ N - 1 ] = arr [ N - 1 ]\n    for i in range ( N - 2 , - 1 , - 1 ) :\n        if ( i + k + 1 >= N ) :\n            MS [ i ] = max ( arr [ i ] , MS [ i + 1 ] )\n        else :\n            MS [ i ] = max ( arr [ i ] + MS [ i + k + 1 ] , MS [ i + 1 ] )\n    return MS [ 0 ]\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD_1": "def isEven ( n ) :\n    return ( not ( n & 1 ) )\n", "SORT_ARRAY_TWO_HALVES_SORTED": "def mergeTwoHalf ( A , n ) :\n    A.sort ( )\n", "PYTHAGOREAN_QUADRUPLE": "def pythagorean_quadruple ( a , b , c , d ) :\n    sum = a * a + b * b + c * c ;\n    if ( d * d == sum ) :\n        return True\n    else :\n        return False\n", "FIND_THE_MAXIMUM_OF_MINIMUMS_FOR_EVERY_WINDOW_SIZE_IN_A_GIVEN_ARRAY": "def printMaxOfMin ( arr , n ) :\n    for k in range ( 1 , n + 1 ) :\n        maxOfMin = INT_MIN ;\n        for i in range ( n - k + 1 ) :\n            min = arr [ i ]\n            for j in range ( k ) :\n                if ( arr [ i + j ] < min ) :\n                    min = arr [ i + j ]\n            if ( min > maxOfMin ) :\n                maxOfMin = min\n        print ( maxOfMin , end = \" \" )\n", "COUNT_SUM_OF_DIGITS_IN_NUMBERS_FROM_1_TO_N": "def sumOfDigitsFrom1ToN ( n ) :\n    if ( n < 10 ) :\n        return ( n * ( n + 1 ) / 2 )\n    d = ( int ) ( math.log10 ( n ) )\n    a = [ 0 ] * ( d + 1 )\n    a [ 0 ] = 0\n    a [ 1 ] = 45\n    for i in range ( 2 , d + 1 ) :\n        a [ i ] = a [ i - 1 ] * 10 + 45 * ( int ) ( math.ceil ( math.pow ( 10 , i - 1 ) ) )\n    p = ( int ) ( math.ceil ( math.pow ( 10 , d ) ) )\n    msd = n // p\n    return ( int ) ( msd * a [ d ] + ( msd * ( msd - 1 ) // 2 ) * p + msd * ( 1 + n % p ) + sumOfDigitsFrom1ToN ( n % p ) )\n", "RECURSIVELY_BREAK_NUMBER_3_PARTS_GET_MAXIMUM_SUM_1": "def breakSum ( n ) :\n    dp = [ 0 ] * ( n + 1 )\n    dp [ 0 ] = 0\n    dp [ 1 ] = 1\n    for i in range ( 2 , n + 1 ) :\n        dp [ i ] = max ( dp [ int ( i / 2 ) ] + dp [ int ( i / 3 ) ] + dp [ int ( i / 4 ) ] , i ) ;\n    return dp [ n ]\n", "FIND_REPEATING_ELEMENT_SORTED_ARRAY_SIZE_N": "def findRepeatingElement ( arr , low , high ) :\n    if low > high :\n        return - 1\n    mid = ( low + high ) / 2\n    if ( arr [ mid ] != mid + 1 ) :\n        if ( mid > 0 and arr [ mid ] == arr [ mid - 1 ] ) :\n            return mid\n        return findRepeatingElement ( arr , low , mid - 1 )\n    return findRepeatingElement ( arr , mid + 1 , high )\n", "COUNT_SUBARRAYS_EQUAL_NUMBER_1S_0S_1": "def countSubarrWithEqualZeroAndOne ( arr , n ) :\n    mp = dict ( )\n    Sum = 0\n    count = 0\n    for i in range ( n ) :\n        if ( arr [ i ] == 0 ) :\n            arr [ i ] = - 1\n        Sum += arr [ i ]\n        if ( Sum == 0 ) :\n            count += 1\n        if ( Sum in mp.keys ( ) ) :\n            count += mp [ Sum ]\n        mp [ Sum ] = mp.get ( Sum , 0 ) + 1\n    return count\n", "UNION_AND_INTERSECTION_OF_TWO_SORTED_ARRAYS_2_1": "def printIntersection ( arr1 , arr2 , m , n ) :\n    i , j = 0 , 0\n    while i < m and j < n :\n        if arr1 [ i ] < arr2 [ j ] :\n            i += 1\n        elif arr2 [ j ] < arr1 [ i ] :\n            j += 1\n        else :\n            print ( arr2 [ j ] )\n            j += 1\n            i += 1\n", "COUNT_ALL_INCREASING_SUBSEQUENCES": "def countSub ( arr , n ) :\n    count = [ 0 for i in range ( 10 ) ]\n    for i in range ( n ) :\n        for j in range ( arr [ i ] - 1 , - 1 , - 1 ) :\n            count [ arr [ i ] ] += count [ j ]\n        count [ arr [ i ] ] += 1\n    result = 0\n    for i in range ( 10 ) :\n        result += count [ i ]\n    return result\n", "SMALLEST_NUMBER_SUM_DIGITS_N_DIVISIBLE_10N": "def digitsNum ( N ) :\n    if ( N == 0 ) :\n        print ( \"0\" , end = \"\" )\n    if ( N % 9 != 0 ) :\n        print ( N % 9 , end = \"\" )\n    for i in range ( 1 , int ( N / 9 ) + 1 ) :\n        print ( \"9\" , end = \"\" )\n    for i in range ( 1 , N + 1 ) :\n        print ( \"0\" , end = \"\" )\n    print ( )\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES_1": "def getOddOccurrence ( arr , size ) :\n    Hash = dict ( )\n    for i in range ( size ) :\n        Hash [ arr [ i ] ] = Hash.get ( arr [ i ] , 0 ) + 1 ;\n    for i in Hash :\n        if ( Hash [ i ] % 2 != 0 ) :\n            return i\n    return - 1\n", "CHECK_IF_X_CAN_GIVE_CHANGE_TO_EVERY_PERSON_IN_THE_QUEUE": "def isChangeable ( notes , n ) :\n    fiveCount = 0\n    tenCount = 0\n    for i in range ( n ) :\n        if ( notes [ i ] == 5 ) :\n            fiveCount += 1\n        elif ( notes [ i ] == 10 ) :\n            if ( fiveCount > 0 ) :\n                fiveCount -= 1\n                tenCount += 1\n            else :\n                return 0\n        else :\n            if ( fiveCount > 0 and tenCount > 0 ) :\n                fiveCount -= 1\n                tenCount -= 1\n            elif ( fiveCount >= 3 ) :\n                fiveCount -= 3\n            else :\n                return 0\n    return 1\n", "MAXIMUM_MINIMUM_VALUES_ALGEBRAIC_EXPRESSION": "def minMaxValues ( arr , n , m ) :\n    sum = 0\n    INF = 1000000000\n    MAX = 50\n    for i in range ( 0 , ( n + m ) ) :\n        sum += arr [ i ]\n        arr [ i ] += 50\n    dp = [ [ 0 for x in range ( MAX * MAX + 1 ) ] for y in range ( MAX + 1 ) ]\n    dp [ 0 ] [ 0 ] = 1\n    for i in range ( 0 , ( n + m ) ) :\n        for k in range ( min ( n , i + 1 ) , 0 , - 1 ) :\n            for j in range ( 0 , MAX * MAX + 1 ) :\n                if ( dp [ k - 1 ] [ j ] ) :\n                    dp [ k ] [ j + arr [ i ] ] = 1\n    max_value = - 1 * INF\n    min_value = INF\n    for i in range ( 0 , MAX * MAX + 1 ) :\n        if ( dp [ n ] [ i ] ) :\n            temp = i - 50 * n\n            max_value = max ( max_value , temp * ( sum - temp ) )\n            min_value = min ( min_value , temp * ( sum - temp ) )\n    print ( \"Maximum Value: {}\\nMinimum Value: {}\".format ( max_value , min_value ) )\n", "MULTIPLY_AN_INTEGER_WITH_3_5": "def multiplyWith3Point5 ( x ) :\n    return ( x << 1 ) + x + ( x >> 1 )\n", "MINIMUM_CELLS_REQUIRED_REACH_DESTINATION_JUMPS_EQUAL_CELL_VALUES": "def minCells ( mat , m , n ) :\n    dp = [ [ MAX for i in range ( n ) ] for i in range ( m ) ]\n    dp [ 0 ] [ 0 ] = 1\n    for i in range ( m ) :\n        for j in range ( n ) :\n            if ( dp [ i ] [ j ] != MAX and ( j + mat [ i ] [ j ] ) < n and ( dp [ i ] [ j ] + 1 ) < dp [ i ] [ j + mat [ i ] [ j ] ] ) :\n                dp [ i ] [ j + mat [ i ] [ j ] ] = dp [ i ] [ j ] + 1\n            if ( dp [ i ] [ j ] != MAX and ( i + mat [ i ] [ j ] ) < m and ( dp [ i ] [ j ] + 1 ) < dp [ i + mat [ i ] [ j ] ] [ j ] ) :\n                dp [ i + mat [ i ] [ j ] ] [ j ] = dp [ i ] [ j ] + 1\n    if ( dp [ m - 1 ] [ n - 1 ] != MAX ) :\n        return dp [ m - 1 ] [ n - 1 ]\n    return - 1\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY": "def findExtra ( arr1 , arr2 , n ) :\n    for i in range ( 0 , n ) :\n        if ( arr1 [ i ] != arr2 [ i ] ) :\n            return i\n    return n\n", "CALCULATE_SUM_OF_ALL_NUMBERS_PRESENT_IN_A_STRING": "def findSum ( str1 ) :\n    temp = \"\"\n    Sum = 0\n    for ch in str1 :\n        if ( ch.isdigit ( ) ) :\n            temp += ch\n        else :\n            Sum += int ( temp )\n            temp = \"0\"\n    return Sum + int ( temp )\n", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED": "def checkReverse ( arr , n ) :\n    temp = [ 0 ] * n\n    for i in range ( n ) :\n        temp [ i ] = arr [ i ]\n    temp.sort ( )\n    for front in range ( n ) :\n        if temp [ front ] != arr [ front ] :\n            break\n    for back in range ( n - 1 , - 1 , - 1 ) :\n        if temp [ back ] != arr [ back ] :\n            break\n    if front >= back :\n        return True\n    while front != back :\n        front += 1\n        if arr [ front - 1 ] < arr [ front ] :\n            return False\n    return True\n", "GENERATE_PYTHAGORAS_TRIPLET_SINGLE_INTEGER": "def evaluate ( n ) :\n    if ( n == 1 or n == 2 ) :\n        print ( \"No Pythagoras\" + \" Triplet exists\" ) ;\n    elif ( n % 2 == 0 ) :\n        var = n * n / 4 ;\n        print ( \"Pythagoras Triplets\" + \" exist i.e.\" , end = \"\" ) ;\n        print ( int ( n ) , \"\" , int ( var - 1 ) , \"\" , int ( var + 1 ) ) ;\n    elif ( n % 2 != 0 ) :\n        var = n * n + 1 ;\n        print ( \"Pythagoras Triplets \" + \"exist i.e.\" , end = \"\" ) ;\n        print ( int ( n ) , \"\" , int ( var / 2 - 1 ) , \"\" , int ( var / 2 ) ) ;\n", "PETERSON_GRAPH": "def findthepath ( S , v ) :\n    result [ 0 ] = v\n    for i in range ( 1 , len ( S ) ) :\n        if ( adj [ v ] [ ord ( S [ i ] ) - ord ( 'A' ) ] or adj [ ord ( S [ i ] ) - ord ( 'A' ) ] [ v ] ) :\n            v = ord ( S [ i ] ) - ord ( 'A' )\n        elif ( adj [ v ] [ ord ( S [ i ] ) - ord ( 'A' ) + 5 ] or adj [ ord ( S [ i ] ) - ord ( 'A' ) + 5 ] [ v ] ) :\n            v = ord ( S [ i ] ) - ord ( 'A' ) + 5\n        else :\n            return False\n        result.append ( v )\n    return True\n", "COUNT_NUMBER_OF_SOLUTIONS_OF_X2_1_MOD_P_IN_GIVEN_RANGE": "def findCountOfSolutions ( n , p ) :\n    ans = 0 ;\n    for x in range ( 1 , p ) :\n        if ( ( x * x ) % p == 1 ) :\n            last = x + p * ( n / p ) ;\n            if ( last > n ) :\n                last -= p ;\n            ans += ( ( last - x ) / p + 1 ) ;\n    return int ( ans ) ;\n", "JUMP_SEARCH": "def jumpSearch ( arr , x , n ) :\n    step = math.sqrt ( n )\n    prev = 0\n    while arr [ int ( min ( step , n ) - 1 ) ] < x :\n        prev = step\n        step += math.sqrt ( n )\n        if prev >= n :\n            return - 1\n    while arr [ int ( prev ) ] < x :\n        prev += 1\n        if prev == min ( step , n ) :\n            return - 1\n    if arr [ int ( prev ) ] == x :\n        return prev\n    return - 1\n", "FORM_MINIMUM_NUMBER_FROM_GIVEN_SEQUENCE": "def PrintMinNumberForPattern ( arr ) :\n    curr_max = 0\n    last_entry = 0\n    i = 0\n    while i < len ( arr ) :\n        noOfNextD = 0\n        if arr [ i ] == \"I\" :\n            j = i + 1\n            while j < len ( arr ) and arr [ j ] == \"D\" :\n                noOfNextD += 1\n                j += 1\n            if i == 0 :\n                curr_max = noOfNextD + 2\n                last_entry += 1\n                print ( \"\" , last_entry , end = \"\" )\n                print ( \"\" , curr_max , end = \"\" )\n                last_entry = curr_max\n            else :\n                curr_max += noOfNextD + 1\n                last_entry = curr_max\n                print ( \"\" , last_entry , end = \"\" )\n            for k in range ( noOfNextD ) :\n                last_entry -= 1\n                print ( \"\" , last_entry , end = \"\" )\n                i += 1\n        elif arr [ i ] == \"D\" :\n            if i == 0 :\n                j = i + 1\n                while j < len ( arr ) and arr [ j ] == \"D\" :\n                    noOfNextD += 1\n                    j += 1\n                curr_max = noOfNextD + 2\n                print ( \"\" , curr_max , curr_max - 1 , end = \"\" )\n                last_entry = curr_max - 1\n            else :\n                print ( \"\" , last_entry - 1 , end = \"\" )\n                last_entry -= 1\n        i += 1\n    print ( )\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8": "def isSubSeqDivisible ( st ) :\n    l = len ( st )\n    arr = [ 0 ] * l\n    for i in range ( 0 , l ) :\n        for j in range ( i , l ) :\n            for k in range ( j , l ) :\n                if ( arr [ i ] % 8 == 0 ) :\n                    return True\n                elif ( ( arr [ i ] * 10 + arr [ j ] ) % 8 == 0 and i != j ) :\n                    return True\n                elif ( ( arr [ i ] * 100 + arr [ j ] * 10 + arr [ k ] ) % 8 == 0 and i != j and j != k and i != k ) :\n                    return True\n    return False\n", "PRINT_FIBONACCI_SEQUENCE_USING_2_VARIABLES": "def fib ( n ) :\n    a = 0\n    b = 1\n    if ( n >= 0 ) :\n        print ( a , end = ' ' )\n    if ( n >= 1 ) :\n        print ( b , end = ' ' )\n    for i in range ( 2 , n + 1 ) :\n        c = a + b\n        print ( c , end = ' ' )\n        a = b\n        b = c\n", "INTERCHANGE_ELEMENTS_OF_FIRST_AND_LAST_ROWS_IN_MATRIX": "def interchangeFirstLast ( mat , n , m ) :\n    rows = n\n    for i in range ( n ) :\n        t = mat [ 0 ] [ i ]\n        mat [ 0 ] [ i ] = mat [ rows - 1 ] [ i ]\n        mat [ rows - 1 ] [ i ] = t\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS": "def findSum ( n ) :\n    arr = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    for i in range ( n ) :\n        for j in range ( n ) :\n            arr [ i ] [ j ] = abs ( i - j )\n    sum = 0\n    for i in range ( n ) :\n        for j in range ( n ) :\n            sum += arr [ i ] [ j ]\n    return sum\n", "FIND_THE_MAXIMUM_ELEMENT_IN_AN_ARRAY_WHICH_IS_FIRST_INCREASING_AND_THEN_DECREASING": "def findMaximum ( arr , low , high ) :\n    max = arr [ low ]\n    i = low\n    for i in range ( high + 1 ) :\n        if arr [ i ] > max :\n            max = arr [ i ]\n    return max\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX_1": "def isScalarMatrix ( mat ) :\n    for i in range ( 0 , N ) :\n        for j in range ( 0 , N ) :\n            if ( ( i != j ) and ( mat [ i ] [ j ] != 0 ) ) :\n                return False\n    for i in range ( 0 , N - 1 ) :\n        if ( mat [ i ] [ i ] != mat [ i + 1 ] [ i + 1 ] ) :\n            return False\n    return True\n", "STOOGE_SORT": "def stoogesort ( arr , l , h ) :\n    if l >= h :\n        return\n    if arr [ l ] > arr [ h ] :\n        t = arr [ l ]\n        arr [ l ] = arr [ h ]\n        arr [ h ] = t\n    if h - l + 1 > 2 :\n        t = ( int ) ( ( h - l + 1 ) / 3 )\n        stoogesort ( arr , l , ( h - t ) )\n        stoogesort ( arr , l + t , ( h ) )\n        stoogesort ( arr , l , ( h - t ) )\n", "DYNAMIC_PROGRAMMING_SET_11_EGG_DROPPING_PUZZLE": "def eggDrop ( n , k ) :\n    if ( k == 1 or k == 0 ) :\n        return k\n    if ( n == 1 ) :\n        return k\n    min = sys.maxsize\n    for x in range ( 1 , k + 1 ) :\n        res = max ( eggDrop ( n - 1 , x - 1 ) , eggDrop ( n , k - x ) )\n        if ( res < min ) :\n            min = res\n    return min + 1\n", "DIFFERENT_WAYS_SUM_N_USING_NUMBERS_GREATER_EQUAL_M": "def numberofways ( n , m ) :\n    dp = np.zeros ( ( n + 2 , n + 2 ) )\n    dp [ 0 ] [ n + 1 ] = 1\n    for k in range ( n , m - 1 , - 1 ) :\n        for i in range ( n + 1 ) :\n            dp [ i ] [ k ] = dp [ i ] [ k + 1 ]\n            if ( i - k >= 0 ) :\n                dp [ i ] [ k ] = ( dp [ i ] [ k ] + dp [ i - k ] [ k ] )\n    return dp [ n ] [ m ]\n", "BUBBLE_SORT": "def bubbleSort ( arr ) :\n    n = len ( arr )\n    for i in range ( n ) :\n        for j in range ( 0 , n - i - 1 ) :\n            if arr [ j ] > arr [ j + 1 ] :\n                arr [ j ] , arr [ j + 1 ] = arr [ j + 1 ] , arr [ j ]\n", "GENERATE_ROTATIONS_GIVEN_STRING": "def printRotatedString ( str ) :\n    lenn = len ( str )\n    temp = [ 0 ] * ( lenn )\n    for i in range ( lenn ) :\n        j = i\n        k = 0\n        while ( j < len ( str ) ) :\n            temp [ k ] = str [ j ]\n            k += 1\n            j += 1\n        j = 0\n        while ( j < i ) :\n            temp [ k ] = str [ j ]\n            j += 1\n            k += 1\n        print ( * temp , sep = \"\" )\n", "MID_POINT_LINE_GENERATION_ALGORITHM": "def midPoint ( X1 , Y1 , X2 , Y2 ) :\n    dx = X2 - X1\n    dy = Y2 - Y1\n    d = dy - ( dx / 2 )\n    x = X1\n    y = Y1\n    print ( x , \",\" , y , \"\\n\" )\n    while ( x < X2 ) :\n        x = x + 1\n        if ( d < 0 ) :\n            d = d + dy\n        else :\n            d = d + ( dy - dx )\n            y = y + 1\n        print ( x , \",\" , y , \"\\n\" )\n", "FINDING_VERTEX_FOCUS_DIRECTRIX_PARABOLA": "def parabola ( a , b , c ) :\n    print ( \"Vertex: (\" , ( - b / ( 2 * a ) ) , \", \" , ( ( ( 4 * a * c ) - ( b * b ) ) / ( 4 * a ) ) , \")\" , sep = \"\" )\n    print ( \"Focus: (\" , ( - b / ( 2 * a ) ) , \", \" , ( ( ( 4 * a * c ) - ( b * b ) + 1 ) / ( 4 * a ) ) , \")\" , sep = \"\" )\n    print ( \"Directrix: y=\" , c - ( ( b * b ) + 1 ) * 4 * a , sep = \"\" )\n", "TRIANGULAR_NUMBERS": "def isTriangular ( num ) :\n    if ( num < 0 ) :\n        return False\n    sum , n = 0 , 1\n    while ( sum <= num ) :\n        sum = sum + n\n        if ( sum == num ) :\n            return True\n        n += 1\n    return False\n", "PIZZA_CUT_PROBLEM_CIRCLE_DIVISION_LINES": "def findMaximumPieces ( n ) :\n    return int ( 1 + n * ( n + 1 ) / 2 )\n", "MINIMUM_TIME_WRITE_CHARACTERS_USING_INSERT_DELETE_COPY_OPERATION": "def minTimeForWritingChars ( N , insrt , remov , cpy ) :\n    if N == 0 :\n        return 0\n    if N == 1 :\n        return insrt\n    dp = [ 0 ] * ( N + 1 )\n    for i in range ( 1 , N + 1 ) :\n        if i % 2 == 0 :\n            dp [ i ] = min ( dp [ i - 1 ] + insrt , dp [ i // 2 ] + cpy )\n        else :\n            dp [ i ] = min ( dp [ i - 1 ] + insrt , dp [ ( i + 1 ) // 2 ] + cpy + remov )\n    return dp [ N ]\n", "SEARCHING_ARRAY_ADJACENT_DIFFER_K": "def search ( arr , n , x , k ) :\n    i = 0\n    while ( i < n ) :\n        if ( arr [ i ] == x ) :\n            return i\n        i = i + max ( 1 , int ( abs ( arr [ i ] - x ) / k ) )\n    print ( \"number is not present!\" )\n    return - 1\n", "FIND_MAXIMUM_PRODUCT_OF_A_TRIPLET_IN_ARRAY": "def maxProduct ( arr , n ) :\n    if n < 3 :\n        return - 1\n    max_product = - ( sys.maxsize - 1 )\n    for i in range ( 0 , n - 2 ) :\n        for j in range ( i + 1 , n - 1 ) :\n            for k in range ( j + 1 , n ) :\n                max_product = max ( max_product , arr [ i ] * arr [ j ] * arr [ k ] )\n    return max_product\n", "LONGEST_PALINDROME_SUBSEQUENCE_SPACE": "def lps ( s ) :\n    n = len ( s )\n    a = [ 0 ] * n\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        back_up = 0\n        for j in range ( i , n ) :\n            if j == i :\n                a [ j ] = 1\n            elif s [ i ] == s [ j ] :\n                temp = a [ j ]\n                a [ j ] = back_up + 2\n                back_up = temp\n            else :\n                back_up = a [ j ]\n                a [ j ] = max ( a [ j - 1 ] , a [ j ] )\n    return a [ n - 1 ]\n", "CHECK_HALF_STRING_CHARACTER_FREQUENCY_CHARACTER_1": "def checkCorrectOrNot ( s ) :\n    global MAX_CHAR\n    count = [ 0 ] * MAX_CHAR\n    n = len ( s )\n    if n == 1 :\n        return true\n    i = 0 ; j = n - 1\n    while i < j :\n        count [ ord ( s [ i ] ) - ord ( 'a' ) ] += 1\n        count [ ord ( s [ j ] ) - ord ( 'a' ) ] -= 1\n        i += 1 ; j -= 1\n    for i in range ( MAX_CHAR ) :\n        if count [ i ] != 0 :\n            return False\n    return True\n", "EXPONENTIAL_SQUARING_FAST_MODULO_MULTIPLICATION": "def exponentiation ( bas , exp ) :\n    if ( exp == 0 ) :\n        return 1 ;\n    if ( exp == 1 ) :\n        return bas % N ;\n    t = exponentiation ( bas , int ( exp / 2 ) ) ;\n    t = ( t * t ) % N ;\n    if ( exp % 2 == 0 ) :\n        return t ;\n    else :\n        return ( ( bas % N ) * t ) % N ;\n", "REMOVE_MINIMUM_NUMBER_ELEMENTS_NO_COMMON_ELEMENT_EXIST_ARRAY": "def minRemove ( a , b , n , m ) :\n    countA = dict ( )\n    countB = dict ( )\n    for i in range ( n ) :\n        countA [ a [ i ] ] = countA.get ( a [ i ] , 0 ) + 1\n    for i in range ( n ) :\n        countB [ b [ i ] ] = countB.get ( b [ i ] , 0 ) + 1\n    res = 0\n    for x in countA :\n        if x in countB.keys ( ) :\n            res += min ( countA [ x ] , countB [ x ] )\n    return res\n", "FIND_A_FIXED_POINT_IN_A_GIVEN_ARRAY": "def linearSearch ( arr , n ) :\n    for i in range ( n ) :\n        if arr [ i ] is i :\n            return i\n    return - 1\n", "ADD_1_TO_A_GIVEN_NUMBER": "def addOne ( x ) :\n    m = 1 ;\n    while ( x & m ) :\n        x = x ^ m\n        m <<= 1\n    x = x ^ m\n    return x\n", "HEIGHT_COMPLETE_BINARY_TREE_HEAP_N_NODES": "def height ( N ) :\n    return math.ceil ( math.log2 ( N + 1 ) ) - 1\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY": "def minJumps ( arr , l , h ) :\n    if ( h == l ) :\n        return 0\n    if ( arr [ l ] == 0 ) :\n        return float ( 'inf' )\n    min = float ( 'inf' )\n    for i in range ( l + 1 , h + 1 ) :\n        if ( i < l + arr [ l ] + 1 ) :\n            jumps = minJumps ( arr , i , h )\n            if ( jumps != float ( 'inf' ) and jumps + 1 < min ) :\n                min = jumps + 1\n    return min\n", "PROGRAM_FOR_NTH_FIBONACCI_NUMBER_2": "def fib ( n ) :\n    if ( n == 0 ) :\n        return 0\n    if ( n == 1 or n == 2 ) :\n        f [ n ] = 1\n        return ( f [ n ] )\n    if ( f [ n ] ) :\n        return f [ n ]\n    if ( n & 1 ) :\n        k = ( n + 1 ) // 2\n    else :\n        k = n // 2\n    if ( ( n & 1 ) ) :\n        f [ n ] = ( fib ( k ) * fib ( k ) + fib ( k - 1 ) * fib ( k - 1 ) )\n    else :\n        f [ n ] = ( 2 * fib ( k - 1 ) + fib ( k ) ) * fib ( k )\n    return f [ n ]\n", "DECODE_STRING_RECURSIVELY_ENCODED_COUNT_FOLLOWED_SUBSTRING": "def decode ( Str ) :\n    integerstack = [ ]\n    stringstack = [ ]\n    temp = \"\"\n    result = \"\"\n    for i in range ( len ( Str ) ) :\n        count = 0\n        if ( Str [ i ] >= '0' and Str [ i ] <= '9' ) :\n            while ( Str [ i ] >= '0' and Str [ i ] <= '9' ) :\n                count = count * 10 + ord ( Str [ i ] ) - ord ( '0' )\n                i += 1\n            i -= 1\n            integerstack.append ( count )\n        elif ( Str [ i ] == ']' ) :\n            temp = \"\"\n            count = 0\n            if ( len ( integerstack ) != 0 ) :\n                count = integerstack [ - 1 ]\n                integerstack.pop ( )\n            while ( len ( stringstack ) != 0 and stringstack [ - 1 ] != '[' ) :\n                temp = stringstack [ - 1 ] + temp\n                stringstack.pop ( )\n            if ( len ( stringstack ) != 0 and stringstack [ - 1 ] == '[' ) :\n                stringstack.pop ( )\n            for j in range ( count ) :\n                result = result + temp\n            for j in range ( len ( result ) ) :\n                stringstack.append ( result [ j ] )\n            result = \"\"\n        elif ( Str [ i ] == '[' ) :\n            if ( Str [ i - 1 ] >= '0' and Str [ i - 1 ] <= '9' ) :\n                stringstack.append ( Str [ i ] )\n            else :\n                stringstack.append ( Str [ i ] )\n                integerstack.append ( 1 )\n        else :\n            stringstack.append ( Str [ i ] )\n    while len ( stringstack ) != 0 :\n        result = stringstack [ - 1 ] + result\n        stringstack.pop ( )\n    return result\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP": "def isHeap ( arr , i , n ) :\n    if i > int ( ( n - 2 ) / 2 ) :\n        return True\n    if ( arr [ i ] >= arr [ 2 * i + 1 ] and arr [ i ] >= arr [ 2 * i + 2 ] and isHeap ( arr , 2 * i + 1 , n ) and isHeap ( arr , 2 * i + 2 , n ) ) :\n        return True\n    return False\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP_1": "def isHeap ( arr , n ) :\n    for i in range ( int ( ( n - 2 ) / 2 ) + 1 ) :\n        if arr [ 2 * i + 1 ] > arr [ i ] :\n            return False\n        if ( 2 * i + 2 < n and arr [ 2 * i + 2 ] > arr [ i ] ) :\n            return False\n    return True\n", "CALCULATE_ANGLE_HOUR_HAND_MINUTE_HAND": "def calcAngle ( h , m ) :\n    if ( h < 0 or m < 0 or h > 12 or m > 60 ) :\n        print ( 'Wrong input' )\n    if ( h == 12 ) :\n        h = 0\n    if ( m == 60 ) :\n        m = 0\n    hour_angle = 0.5 * ( h * 60 + m )\n    minute_angle = 6 * m\n    angle = abs ( hour_angle - minute_angle )\n    angle = min ( 360 - angle , angle )\n    return angle\n", "CONVERTING_DECIMAL_NUMBER_LYING_BETWEEN_1_TO_3999_TO_ROMAN_NUMERALS": "def printRoman ( number ) :\n    num = [ 1 , 4 , 5 , 9 , 10 , 40 , 50 , 90 , 100 , 400 , 500 , 900 , 1000 ]\n    sym = [ \"I\" , \"IV\" , \"V\" , \"IX\" , \"X\" , \"XL\" , \"L\" , \"XC\" , \"C\" , \"CD\" , \"D\" , \"CM\" , \"M\" ]\n    i = 12\n    while number :\n        div = number // num [ i ]\n        number %= num [ i ]\n        while div :\n            print ( sym [ i ] , end = \"\" )\n            div -= 1\n        i -= 1\n", "SORTING_USING_TRIVIAL_HASH_FUNCTION": "def sortUsingHash ( a , n ) :\n    Max = max ( a )\n    Hash = [ 0 ] * ( Max + 1 )\n    for i in range ( 0 , n ) :\n        Hash [ a [ i ] ] += 1\n    for i in range ( 0 , Max + 1 ) :\n        if Hash [ i ] != 0 :\n            for j in range ( 0 , Hash [ i ] ) :\n                print ( i , end = \" \" )\n", "SUM_PAIRWISE_PRODUCTS_2": "def findSum ( n ) :\n    return n * ( n + 1 ) * ( n + 2 ) * ( 3 * n + 1 ) / 24\n", "ENTRINGER_NUMBER": "def zigzag ( n , k ) :\n    if ( n == 0 and k == 0 ) :\n        return 1\n    if ( k == 0 ) :\n        return 0\n    return zigzag ( n , k - 1 ) + zigzag ( n - 1 , n - k ) ;\n", "MINIMUM_SUM_TWO_NUMBERS_FORMED_DIGITS_ARRAY_2": "def minSum ( a , n ) :\n    a = sorted ( a )\n    num1 , num2 = 0 , 0\n    for i in range ( n ) :\n        if i % 2 == 0 :\n            num1 = num1 * 10 + a [ i ]\n        else :\n            num2 = num2 * 10 + a [ i ]\n    return num2 + num1\n", "SUBARRAY_NO_PAIR_SUM_DIVISIBLE_K": "def subarrayDivisibleByK ( arr , n , k ) :\n    mp = [ 0 ] * 1000\n    s = 0 ; e = 0 ; maxs = 0 ; maxe = 0 ;\n    mp [ arr [ 0 ] % k ] = mp [ arr [ 0 ] % k ] + 1 ;\n    for i in range ( 1 , n ) :\n        mod = arr [ i ] % k\n        while ( mp [ k - mod ] != 0 or ( mod == 0 and mp [ mod ] != 0 ) ) :\n            mp [ arr [ s ] % k ] = mp [ arr [ s ] % k ] - 1\n            s = s + 1\n        mp [ mod ] = mp [ mod ] + 1\n        e = e + 1\n        if ( ( e - s ) > ( maxe - maxs ) ) :\n            maxe = e\n            maxs = s\n    print ( \"The maximum size is {} and the \".format ( ( maxe - maxs + 1 ) ) ) for i in range ( maxs , maxe + 1 ) :\n        print ( \"{} \".format ( arr [ i ] ) , end = \"\" )\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_K_TIMES": "def maxProfit ( prices , n , k ) :\n    profit = [ [ 0 for i in range ( k + 1 ) ] for j in range ( n ) ]\n    for i in range ( 1 , n ) :\n        for j in range ( 1 , k + 1 ) :\n            max_so_far = 0\n            for l in range ( i ) :\n                max_so_far = max ( max_so_far , prices [ i ] - prices [ l ] + profit [ l ] [ j - 1 ] )\n            profit [ i ] [ j ] = max ( profit [ i - 1 ] [ j ] , max_so_far )\n    return profit [ n - 1 ] [ k ]\n", "MINIMIZE_SUM_PRODUCT_TWO_ARRAYS_PERMUTATIONS_ALLOWED": "def minValue ( A , B , n ) :\n    sorted ( A )\n    sorted ( B )\n    result = 0\n    for i in range ( n ) :\n        result += ( A [ i ] * B [ n - i - 1 ] )\n    return result\n", "FIND_MAXIMUM_ELEMENT_ROW_MATRIX": "def maxelement ( arr ) :\n    no_of_rows = len ( arr )\n    no_of_column = len ( arr [ 0 ] )\n    for i in range ( no_of_rows ) :\n        max1 = 0\n        for j in range ( no_of_column ) :\n            if arr [ i ] [ j ] > max1 :\n                max1 = arr [ i ] [ j ]\n        print ( max1 )\n", "ROUND_OFF_NUMBER_GIVEN_NUMBER_SIGNIFICANT_DIGITS": "def Round_off ( N , n ) :\n    b = N\n    c = floor ( N )\n    i = 0 ;\n    while ( b >= 1 ) :\n        b = b / 10\n        i = i + 1\n    d = n - i\n    b = N\n    b = b * pow ( 10 , d )\n    e = b + 0.5\n    if ( float ( e ) == float ( ceil ( b ) ) ) :\n        f = ( ceil ( b ) )\n        h = f - 2\n        if ( h % 2 != 0 ) :\n            e = e - 1\n    j = floor ( e )\n    m = pow ( 10 , d )\n    j = j / m\n    print ( \"The number after rounding-off is\" , j )\n", "CHECK_WHETHER_POINT_EXISTS_CIRCLE_SECTOR_NOT": "def checkPoint ( radius , x , y , percent , startAngle ) :\n    endAngle = 360 / percent + startAngle\n    polarradius = math.sqrt ( x * x + y * y )\n    Angle = math.atan ( y / x )\n    if ( Angle >= startAngle and Angle <= endAngle and polarradius < radius ) :\n        print ( \"Point (\" , x , \",\" , y , \") \" \"exist in the circle sector\" )\n    else :\n        print ( \"Point (\" , x , \",\" , y , \") \" \"does not exist in the circle sector\" )\n", "NUMBER_IS_DIVISIBLE_BY_29_OR_NOT": "def isDivisible ( n ) :\n    while ( int ( n / 100 ) ) :\n        last_digit = int ( n % 10 )\n        n = int ( n / 10 )\n        n += last_digit * 3\n    return ( n % 29 == 0 )\n", "PRINT_ALL_DISTINCT_CHARACTERS_OF_A_STRING_IN_ORDER_3_METHODS": "def printDistinct ( str ) :\n    count = [ 0 ] * NO_OF_CHARS\n    for i in range ( len ( str ) ) :\n        if ( str [ i ] != ' ' ) :\n            count [ ord ( str [ i ] ) ] += 1\n    n = i\n    for i in range ( n ) :\n        if ( count [ ord ( str [ i ] ) ] == 1 ) :\n            print ( str [ i ] , end = \"\" )\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE": "def recursiveReverse ( str ) :\n    stack = [ ]\n    for i in range ( len ( str ) ) :\n        stack.append ( str [ i ] )\n    for i in range ( len ( str ) ) :\n        str [ i ] = stack.pop ( )\n", "PAINTING_FENCE_ALGORITHM": "def countWays ( n , k ) :\n    total = k\n    mod = 1000000007\n    same , diff = 0 , k\n    for i in range ( 2 , n + 1 ) :\n        same = diff\n        diff = total * ( k - 1 )\n        diff = diff % mod\n        total = ( same + diff ) % mod\n    return total\n", "COUNT_OF_SUB_STRINGS_THAT_DO_NOT_CONTAIN_ALL_THE_CHARACTERS_FROM_THE_SET_A_B_C_AT_THE_SAME_TIME": "def CountSubString ( Str , n ) :\n    ans = ( n * ( n + 1 ) ) // 2\n    a_index = 0\n    b_index = 0\n    c_index = 0\n    for i in range ( n ) :\n        if ( Str [ i ] == 'a' ) :\n            a_index = i + 1\n            ans -= min ( b_index , c_index )\n        elif ( Str [ i ] == 'b' ) :\n            b_index = i + 1\n            ans -= min ( a_index , c_index )\n        else :\n            c_index = i + 1\n            ans -= min ( a_index , b_index )\n    return ans\n", "CALCULATING_FACTORIALS_USING_STIRLING_APPROXIMATION": "def stirlingFactorial ( n ) :\n    if ( n == 1 ) :\n        return 1 ;\n    e = 2.71 ;\n    z = ( math.sqrt ( 2 * 3.14 * n ) * math.pow ( ( n / e ) , n ) ) ;\n    return math.floor ( z ) ;\n", "LEXICOGRAPHICALLY_SMALLEST_STRING_OBTAINED_CONCATENATING_ARRAY": "def lexSmallest ( a , n ) :\n    a.sort ( reverse = True )\n    answer = \"\"\n    for i in range ( n ) :\n        answer += a [ i ]\n    return answer\n", "PRODUCT_MAXIMUM_FIRST_ARRAY_MINIMUM_SECOND": "def minmaxProduct ( arr1 , arr2 , n1 , n2 ) :\n    arr1.sort ( )\n    arr2.sort ( )\n    return arr1 [ n1 - 1 ] * arr2 [ 0 ]\n", "FIND_IF_THERE_IS_A_SUBARRAY_WITH_0_SUM": "def subArrayExists ( arr , n ) :\n    s = set ( )\n    sum = 0\n    for i in range ( n ) :\n        sum += arr [ i ]\n        if sum == 0 or sum in s :\n            return True\n        s.add ( sum )\n    return False\n", "MINIMUM_PRODUCT_SUBSET_ARRAY": "def minProductSubset ( a , n ) :\n    if ( n == 1 ) :\n        return a [ 0 ]\n    max_neg = float ( '-inf' )\n    min_pos = float ( 'inf' )\n    count_neg = 0\n    count_zero = 0\n    prod = 1\n    for i in range ( 0 , n ) :\n        if ( a [ i ] == 0 ) :\n            count_zero = count_zero + 1\n            continue\n        if ( a [ i ] < 0 ) :\n            count_neg = count_neg + 1\n            max_neg = max ( max_neg , a [ i ] )\n        if ( a [ i ] > 0 ) :\n            min_pos = min ( min_pos , a [ i ] )\n        prod = prod * a [ i ]\n    if ( count_zero == n or ( count_neg == 0 and count_zero > 0 ) ) :\n        return 0 ;\n    if ( count_neg == 0 ) :\n        return min_pos\n    if ( ( count_neg & 1 ) == 0 and count_neg != 0 ) :\n        prod = int ( prod / max_neg )\n    return prod ;\n", "NUMBER_NODES_TWO_VERTICES_ACYCLIC_GRAPH_DISJOINT_UNION_METHOD": "def totalNodes ( adjac , n , x , y ) :\n    visited = [ 0 ] * ( n + 1 )\n    p = [ None ] * n\n    q = queue.Queue ( )\n    q.put ( x )\n    visited [ x ] = True\n    m = None\n    while ( not q.empty ( ) ) :\n        m = q.get ( )\n        for i in range ( len ( adjac [ m ] ) ) :\n            h = adjac [ m ] [ i ]\n            if ( not visited [ h ] ) :\n                visited [ h ] = True\n                p [ h ] = m\n                q.put ( h )\n    count = 0\n    i = p [ y ]\n    while ( i != x ) :\n        count += 1\n        i = p [ i ]\n    return count\n", "PRINTING_STRING_PLUS_PATTERN_MATRIX": "def carveCross ( str ) :\n    n = len ( str )\n    if ( n % 2 == 0 ) :\n        print ( \"Not possible.Please enter \" , \"odd length string.\\n\" )\n    else :\n        arr = [ [ False for x in range ( max ) ] for y in range ( max ) ]\n        m = n // 2\n        for i in range ( n ) :\n            for j in range ( n ) :\n                arr [ i ] [ j ] = 'X'\n        for i in range ( n ) :\n            arr [ i ] [ m ] = str [ i ]\n        for i in range ( n ) :\n            arr [ m ] [ i ] = str [ i ]\n        for i in range ( n ) :\n            for j in range ( n ) :\n                print ( arr [ i ] [ j ] , end = \" \" )\n            print ( )\n", "NEXT_GREATER_FREQUENCY_ELEMENT": "def NFG ( a , n ) :\n    if ( n <= 0 ) :\n        print ( \"List empty\" )\n        return [ ]\n    stack = [ 0 ] * n\n    freq = { }\n    for i in a :\n        freq [ a [ i ] ] = 0\n    for i in a :\n        freq [ a [ i ] ] += 1\n    res = [ 0 ] * n\n    top = - 1\n    top += 1\n    stack [ top ] = 0\n    for i in range ( 1 , n ) :\n        if ( freq [ a [ stack [ top ] ] ] > freq [ a [ i ] ] ) :\n            top += 1\n            stack [ top ] = i\n        else :\n            while ( top > - 1 and freq [ a [ stack [ top ] ] ] < freq [ a [ i ] ] ) :\n                res [ stack [ top ] ] = a [ i ]\n                top -= 1\n            top += 1\n            stack [ top ] = i\n    while ( top > - 1 ) :\n        res [ stack [ top ] ] = - 1\n        top -= 1\n    return res\n", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED_1": "def checkReverse ( arr , n ) :\n    if ( n == 1 ) :\n        return True\n    i = 1\n    for i in range ( 1 , n ) :\n        if arr [ i - 1 ] < arr [ i ] :\n            if ( i == n ) :\n                return True\n    j = i\n    while ( arr [ j ] < arr [ j - 1 ] ) :\n        if ( i > 1 and arr [ j ] < arr [ i - 2 ] ) :\n            return False\n        j += 1\n    if ( j == n ) :\n        return True\n    k = j\n    if ( arr [ k ] < arr [ i - 1 ] ) :\n        return False\n    while ( k > 1 and k < n ) :\n        if ( arr [ k ] < arr [ k - 1 ] ) :\n            return False\n        k += 1\n    return True\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_2": "def findTriplets ( arr , n ) :\n    found = False\n    arr.sort ( )\n    for i in range ( 0 , n - 1 ) :\n        l = i + 1\n        r = n - 1\n        x = arr [ i ]\n        while ( l < r ) :\n            if ( x + arr [ l ] + arr [ r ] == 0 ) :\n                print ( x , arr [ l ] , arr [ r ] )\n                l += 1\n                r -= 1\n                found = True\n            elif ( x + arr [ l ] + arr [ r ] < 0 ) :\n                l += 1\n            else :\n                r -= 1\n    if ( found == False ) :\n        print ( \" No Triplet Found\" )\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS": "def findElements ( arr , n ) :\n    for i in range ( n ) :\n        count = 0\n        for j in range ( 0 , n ) :\n            if arr [ j ] > arr [ i ] :\n                count = count + 1\n        if count >= 2 :\n            print ( arr [ i ] , end = \" \" )\n", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS_1": "def printArray ( a , n ) :\n    for i in a :\n        print ( i , end = \" \" )\n    print ( )\n", "FIND_MINIMUM_RADIUS_ATLEAST_K_POINT_LIE_INSIDE_CIRCLE": "def minRadius ( k , x , y , n ) :\n    dis = [ 0 ] * n\n    for i in range ( 0 , n ) :\n        dis [ i ] = x [ i ] * x [ i ] + y [ i ] * y [ i ]\n    dis.sort ( )\n    return dis [ k - 1 ]\n", "COUNT_SUBARRAYS_EQUAL_NUMBER_1S_0S": "def countSubarrWithEqualZeroAndOne ( arr , n ) :\n    um = dict ( )\n    curr_sum = 0\n    for i in range ( n ) :\n        curr_sum += ( - 1 if ( arr [ i ] == 0 ) else arr [ i ] )\n        if um.get ( curr_sum ) :\n            um [ curr_sum ] += 1\n        else :\n            um [ curr_sum ] = 1\n    count = 0\n    for itr in um :\n        if um [ itr ] > 1 :\n            count += ( ( um [ itr ] * int ( um [ itr ] - 1 ) ) / 2 )\n    if um.get ( 0 ) :\n        count += um [ 0 ]\n    return int ( count )\n", "MINIMUM_INDEX_SUM_COMMON_ELEMENTS_TWO_LISTS": "def find ( list1 , list2 ) :\n    res = [ ]\n    max_possible_sum = len ( list1 ) + len ( list2 ) - 2\n    for sum in range ( max_possible_sum + 1 ) :\n        for i in range ( sum + 1 ) :\n            if ( i < len ( list1 ) and ( sum - i ) < len ( list2 ) and list1 [ i ] == list2 [ sum - i ] ) :\n                res.append ( list1 [ i ] )\n        if ( len ( res ) > 0 ) :\n            break\n    for i in range ( len ( res ) ) :\n        print ( res [ i ] , end = \" \" )\n", "CHECK_IF_A_NUMBER_IS_JUMBLED_OR_NOT": "def checkJumbled ( num ) :\n    if ( num / 10 == 0 ) :\n        return True\n    while ( num != 0 ) :\n        if ( num / 10 == 0 ) :\n            return True\n        digit1 = num % 10\n        digit2 = ( num / 10 ) % 10\n        if ( abs ( digit2 - digit1 ) > 1 ) :\n            return False\n        num = num / 10\n    return True\n", "CEILING_IN_A_SORTED_ARRAY_1": "def ceilSearch ( arr , low , high , x ) :\n    if x <= arr [ low ] :\n        return low\n    if x > arr [ high ] :\n        return - 1\n    mid = ( low + high ) / 2 ;\n    if arr [ mid ] == x :\n        return mid\n    elif arr [ mid ] < x :\n        if mid + 1 <= high and x <= arr [ mid + 1 ] :\n            return mid + 1\n        else :\n            return ceilSearch ( arr , mid + 1 , high , x )\n    else :\n        if mid - 1 >= low and x > arr [ mid - 1 ] :\n            return mid\n        else :\n            return ceilSearch ( arr , low , mid - 1 , x )\n", "GIVEN_P_AND_N_FIND_THE_LARGEST_X_SUCH_THAT_PX_DIVIDES_N_2": "def largestPower ( n , p ) :\n    x = 0\n    while n :\n        n /= p\n        x += n\n    return x\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY": "def maxSum ( arr , n ) :\n    res = - sys.maxsize\n    for i in range ( 0 , n ) :\n        curr_sum = 0\n        for j in range ( 0 , n ) :\n            index = int ( ( i + j ) % n )\n            curr_sum += j * arr [ index ]\n        res = max ( res , curr_sum )\n    return res\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE_1": "def smallestSubWithSum ( arr , n , x ) :\n    curr_sum = 0 ;\n    min_len = n + 1 ;\n    start = 0 ;\n    end = 0 ;\n    while ( end < n ) :\n        while ( curr_sum <= x and end < n ) :\n            if ( curr_sum <= 0 and x > 0 ) :\n                start = end ;\n                curr_sum = 0 ;\n            curr_sum += arr [ end ] ;\n            end += 1 ;\n        while ( curr_sum > x and start < n ) :\n            if ( end - start < min_len ) :\n                min_len = end - start ;\n            curr_sum -= arr [ start ] ;\n            start += 1 ;\n    return min_len ;\n", "LEXICOGRAPHICALLY_SMALLEST_STRING_WHOSE_HAMMING_DISTANCE_GIVEN_STRING_EXACTLY_K": "def findString ( str , n , k ) :\n    if ( k == 0 ) :\n        print ( str )\n        return\n    str2 = str\n    p = 0\n    for i in range ( 0 , n , 1 ) :\n        if ( str2 [ i ] != 'a' ) :\n            str2 = str2.replace ( str2 [ i ] , 'a' )\n            p += 1\n            if ( p == k ) :\n                break\n    if ( p < k ) :\n        i = n - 1\n        while ( i >= 0 ) :\n            if ( str [ i ] == 'a' ) :\n                str2 = str2.replace ( str2 [ i ] , 'b' )\n                p += 1\n            if ( p == k ) :\n                break\n            i -= 1\n    print ( str2 )\n", "SUBSET_SUM_DIVISIBLE_M": "def modularSum ( arr , n , m ) :\n    if ( n > m ) :\n        return True\n    DP = [ False for i in range ( m ) ]\n    for i in range ( n ) :\n        if ( DP [ 0 ] ) :\n            return True\n        temp = [ False for i in range ( m ) ]\n        for j in range ( m ) :\n            if ( DP [ j ] == True ) :\n                if ( DP [ ( j + arr [ i ] ) % m ] == False ) :\n                    temp [ ( j + arr [ i ] ) % m ] = True\n        for j in range ( m ) :\n            if ( temp [ j ] ) :\n                DP [ j ] = True\n        DP [ arr [ i ] % m ] = True\n    return DP [ 0 ]\n", "FIND_SUM_EVEN_INDEX_BINOMIAL_COEFFICIENTS_1": "def evenbinomialCoeffSum ( n ) :\n    return ( 1 << ( n - 1 ) )\n", "EVEN_FIBONACCI_NUMBERS_SUM": "def evenFibSum ( limit ) :\n    if ( limit < 2 ) :\n        return 0\n    ef1 = 0\n    ef2 = 2\n    sm = ef1 + ef2\n    while ( ef2 <= limit ) :\n        ef3 = 4 * ef2 + ef1\n        if ( ef3 > limit ) :\n            break\n        ef1 = ef2\n        ef2 = ef3\n        sm = sm + ef2\n    return sm\n", "MAKING_ELEMENTS_OF_TWO_ARRAYS_SAME_WITH_MINIMUM_INCREMENTDECREMENT": "def MinOperation ( a , b , n ) :\n    a.sort ( reverse = False )\n    b.sort ( reverse = False )\n    result = 0\n    for i in range ( 0 , n , 1 ) :\n        if ( a [ i ] > b [ i ] ) :\n            result = result + abs ( a [ i ] - b [ i ] )\n        elif ( a [ i ] < b [ i ] ) :\n            result = result + abs ( a [ i ] - b [ i ] )\n    return result\n", "REQUIRED_MINIMUM_DIGITS_REMOVE_NUMBER_MAKE_PERFECT_SQUARE": "def perfectSquare ( s ) :\n    n = len ( s )\n    ans = - 1\n    num = \"\"\n    for i in range ( 1 , ( 1 << n ) ) :\n        str = \"\"\n        for j in range ( 0 , n ) :\n            if ( ( i >> j ) & 1 ) :\n                str = str + s [ j ]\n        if ( str [ 0 ] != '0' ) :\n            temp = 0 ;\n            for j in range ( 0 , len ( str ) ) :\n                temp = ( temp * 10 + ( ord ( str [ j ] ) - ord ( '0' ) ) )\n            k = int ( math.sqrt ( temp ) )\n            if ( k * k == temp ) :\n                if ( ans < len ( str ) ) :\n                    ans = len ( str )\n                    num = str\n    if ( ans == - 1 ) :\n        return ans\n    else :\n        print ( \"{} \".format ( num ) , end = \"\" )\n        return n - ans\n", "COUNT_WORDS_APPEAR_EXACTLY_TWO_TIMES_ARRAY_WORDS": "def countWords ( stri , n ) :\n    m = dict ( )\n    for i in range ( n ) :\n        m [ stri [ i ] ] = m.get ( stri [ i ] , 0 ) + 1\n    res = 0\n    for i in m.values ( ) :\n        if i == 2 :\n            res += 1\n    return res\n", "COUNT_SET_BITS_IN_AN_INTEGER_4": "def countSetBitsRec ( num ) :\n    nibble = 0 ;\n    if ( 0 == num ) :\n        return num_to_bits [ 0 ] ;\n    nibble = num & 0xf ;\n    return num_to_bits [ nibble ] + countSetBitsRec ( num >> 4 ) ;\n", "MAXIMUM_WEIGHT_PATH_ENDING_ELEMENT_LAST_ROW_MATRIX": "def maxCost ( mat , N ) :\n    dp = [ [ 0 for i in range ( N ) ] for j in range ( N ) ]\n    dp [ 0 ] [ 0 ] = mat [ 0 ] [ 0 ]\n    for i in range ( 1 , N ) :\n        dp [ i ] [ 0 ] = mat [ i ] [ 0 ] + dp [ i - 1 ] [ 0 ]\n    for i in range ( 1 , N ) :\n        for j in range ( 1 , min ( i + 1 , N ) ) :\n            dp [ i ] [ j ] = mat [ i ] [ j ] + \\\n                max ( dp [ i - 1 ] [ j - 1 ] , dp [ i - 1 ] [ j ] )\n    result = 0\n    for i in range ( N ) :\n        if ( result < dp [ N - 1 ] [ i ] ) :\n            result = dp [ N - 1 ] [ i ]\n    return result\n", "PERFECT_REVERSIBLE_STRING": "def isReversible ( str ) :\n    i = 0 ; j = len ( str ) - 1 ;\n    while ( i < j ) :\n        if ( str [ i ] != str [ j ] ) :\n            return False ;\n        i += 1 ;\n        j -= 1 ;\n    return True ;\n", "FIND_SUM_ODD_FACTORS_NUMBER": "def sumofoddFactors ( n ) :\n    res = 1\n    while n % 2 == 0 :\n        n = n // 2\n    for i in range ( 3 , int ( math.sqrt ( n ) + 1 ) ) :\n        count = 0\n        curr_sum = 1\n        curr_term = 1\n        while n % i == 0 :\n            count += 1\n            n = n // i\n            curr_term *= i\n            curr_sum += curr_term\n        res *= curr_sum\n    if n >= 2 :\n        res *= ( 1 + n )\n    return res\n", "MAXIMUM_SUM_PATH_MATRIX_TOP_BOTTOM": "def maxSum ( mat , n ) :\n    if n == 1 :\n        return mat [ 0 ] [ 0 ]\n    dp = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    maxSum = INT_MIN\n    for j in range ( n ) :\n        dp [ n - 1 ] [ j ] = mat [ n - 1 ] [ j ]\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        for j in range ( n ) :\n            maxi = INT_MIN\n            if ( ( ( ( j - 1 ) >= 0 ) and ( maxi < dp [ i + 1 ] [ j - 1 ] ) ) ) :\n                maxi = dp [ i + 1 ] [ j - 1 ]\n            if ( ( ( ( j + 1 ) < n ) and ( maxi < dp [ i + 1 ] [ j + 1 ] ) ) ) :\n                maxi = dp [ i + 1 ] [ j + 1 ]\n            dp [ i ] [ j ] = mat [ i ] [ j ] + maxi\n    for j in range ( n ) :\n        if ( maxSum < dp [ 0 ] [ j ] ) :\n            maxSum = dp [ 0 ] [ j ]\n    return maxSum\n", "COUNT_DIGITS_FACTORIAL_SET_1": "def findDigits ( n ) :\n    if ( n < 0 ) :\n        return 0 ;\n    if ( n <= 1 ) :\n        return 1 ;\n    digits = 0 ;\n    for i in range ( 2 , n + 1 ) :\n        digits += math.log10 ( i ) ;\n    return math.floor ( digits ) + 1 ;\n", "FIND_UNCOMMON_CHARACTERS_TWO_STRINGS": "def findAndPrintUncommonChars ( str1 , str2 ) :\n    present = [ 0 ] * MAX_CHAR\n    for i in range ( 0 , MAX_CHAR ) :\n        present [ i ] = 0\n    l1 = len ( str1 )\n    l2 = len ( str2 )\n    for i in range ( 0 , l1 ) :\n        present [ ord ( str1 [ i ] ) - ord ( 'a' ) ] = 1\n    for i in range ( 0 , l2 ) :\n        if ( present [ ord ( str2 [ i ] ) - ord ( 'a' ) ] == 1 or present [ ord ( str2 [ i ] ) - ord ( 'a' ) ] == - 1 ) :\n            present [ ord ( str2 [ i ] ) - ord ( 'a' ) ] = - 1\n        else :\n            present [ ord ( str2 [ i ] ) - ord ( 'a' ) ] = 2\n    for i in range ( 0 , MAX_CHAR ) :\n        if ( present [ i ] == 1 or present [ i ] == 2 ) :\n            print ( chr ( i + ord ( 'a' ) ) , end = \" \" )\n", "SQUARE_ROOT_OF_AN_INTEGER_1": "def floorSqrt ( x ) :\n    if ( x == 0 or x == 1 ) :\n        return x\n    start = 1\n    end = x\n    while ( start <= end ) :\n        mid = ( start + end ) // 2\n        if ( mid * mid == x ) :\n            return mid\n        if ( mid * mid < x ) :\n            start = mid + 1\n            ans = mid\n        else :\n            end = mid - 1\n    return ans\n", "CHECK_POSSIBLE_PATH_2D_MATRIX": "def isPath ( arr ) :\n    arr [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , row ) :\n        if ( arr [ i ] [ 0 ] != - 1 ) :\n            arr [ i ] [ 0 ] = arr [ i - 1 ] [ 0 ]\n    for j in range ( 1 , col ) :\n        if ( arr [ 0 ] [ j ] != - 1 ) :\n            arr [ 0 ] [ j ] = arr [ 0 ] [ j - 1 ]\n    for i in range ( 1 , row ) :\n        for j in range ( 1 , col ) :\n            if ( arr [ i ] [ j ] != - 1 ) :\n                arr [ i ] [ j ] = max ( arr [ i ] [ j - 1 ] , arr [ i - 1 ] [ j ] )\n    return ( arr [ row - 1 ] [ col - 1 ] == 1 )\n", "NEWMAN_CONWAY_SEQUENCE_1": "def sequence ( n ) :\n    f = array.array ( 'i' , [ 0 , 1 , 1 ] )\n    for i in range ( 3 , n + 1 ) :\n        r = f [ f [ i - 1 ] ] + f [ i - f [ i - 1 ] ]\n        f.append ( r ) ;\n    return r\n", "PRINT_WORDS_STRING_REVERSE_ORDER": "def wordReverse ( str ) :\n    i = len ( str ) - 1\n    start = end = i + 1\n    result = ''\n    while i >= 0 :\n        if str [ i ] == ' ' :\n            start = i + 1\n            while start != end :\n                result += str [ start ]\n                start += 1\n            result += ' '\n            end = i\n        i -= 1\n    start = 0\n    while start != end :\n        result += str [ start ]\n        start += 1\n    return result\n", "FIND_NUMBER_ENDLESS_POINTS": "def countEndless ( input_mat , n ) :\n    row = np.zeros ( ( n , n ) )\n    col = np.zeros ( ( n , n ) )\n    for j in range ( n ) :\n        isEndless = 1\n        for i in range ( n - 1 , - 1 , - 1 ) :\n            if ( input_mat [ i ] [ j ] == 0 ) :\n                isEndless = 0\n            col [ i ] [ j ] = isEndless\n    for i in range ( n ) :\n        isEndless = 1\n        for j in range ( n - 1 , - 1 , - 1 ) :\n            if ( input_mat [ i ] [ j ] == 0 ) :\n                isEndless = 0\n            row [ i ] [ j ] = isEndless\n    ans = 0\n    for i in range ( n ) :\n        for j in range ( 1 , n ) :\n            if ( row [ i ] [ j ] and col [ i ] [ j ] ) :\n                ans += 1\n    return ans\n", "CHECK_POSSIBLE_TRANSFORM_ONE_STRING_ANOTHER": "def check ( s1 , s2 ) :\n    n = len ( s1 )\n    m = len ( s2 )\n    dp = ( [ [ False for i in range ( m + 1 ) ] for i in range ( n + 1 ) ] )\n    dp [ 0 ] [ 0 ] = True\n    for i in range ( len ( s1 ) ) :\n        for j in range ( len ( s2 ) + 1 ) :\n            if ( dp [ i ] [ j ] ) :\n                if ( ( j < len ( s2 ) and ( s1 [ i ].upper ( ) == s2 [ j ] ) ) ) :\n                    dp [ i + 1 ] [ j + 1 ] = True\n                if ( s1 [ i ].isupper ( ) == False ) :\n                    dp [ i + 1 ] [ j ] = True\n    return ( dp [ n ] [ m ] )\n", "CALCULATE_VOLUME_DODECAHEDRON": "def vol_of_dodecahedron ( side ) :\n    return ( ( ( 15 + ( 7 * ( math.sqrt ( 5 ) ) ) ) / 4 ) * ( math.pow ( side , 3 ) ) )\n", "PROGRAM_FIND_REMAINDER_LARGE_NUMBER_DIVIDED_11": "def remainder ( st ) :\n    ln = len ( st )\n    rem = 0\n    for i in range ( 0 , ln ) :\n        num = rem * 10 + ( int ) ( st [ i ] )\n        rem = num % 11\n    return rem\n", "SORT_STRING_CHARACTERS": "def sortString ( str ) :\n    str = ''.join ( sorted ( str ) )\n    print ( str )\n", "BIRTHDAY_PARADOX": "def find ( p ) :\n    return math.ceil ( math.sqrt ( 2 * 365 * math.log ( 1 / ( 1 - p ) ) ) ) ;\n", "CHECK_LINE_PASSES_ORIGIN": "def checkOrigin ( x1 , y1 , x2 , y2 ) :\n    return ( x1 * ( y2 - y1 ) == y1 * ( x2 - x1 ) )\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS_2": "def findElements ( arr , n ) :\n    first = - sys.maxsize\n    second = - sys.maxsize\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] > first ) :\n            second = first\n            first = arr [ i ]\n        elif ( arr [ i ] > second ) :\n            second = arr [ i ]\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] < second ) :\n            print ( arr [ i ] , end = \" \" )\n", "MINIMUM_SUM_SUBSEQUENCE_LEAST_ONE_EVERY_FOUR_CONSECUTIVE_ELEMENTS_PICKED_1": "def minSum ( ar , n ) :\n    if ( n <= 4 ) :\n        return min ( ar )\n    sum = [ 0 for i in range ( n ) ]\n    sum [ 0 ] = ar [ 0 ]\n    sum [ 1 ] = ar [ 1 ]\n    sum [ 2 ] = ar [ 2 ]\n    sum [ 3 ] = ar [ 3 ]\n    for i in range ( 4 , n ) :\n        sum [ i ] = ar [ i ] + min ( sum [ i - 4 : i ] )\n    return min ( sum [ n - 4 : n ] )\n", "CEILING_IN_A_SORTED_ARRAY": "def ceilSearch ( arr , low , high , x ) :\n    if x <= arr [ low ] :\n        return low\n    i = low\n    for i in range ( high ) :\n        if arr [ i ] == x :\n            return i\n        if arr [ i ] < x and arr [ i + 1 ] >= x :\n            return i + 1\n    return - 1\n", "SWAP_TWO_NUMBERS_WITHOUT_USING_TEMPORARY_VARIABLE_1": "def swap ( xp , yp ) :\n    if ( xp [ 0 ] == yp [ 0 ] ) :\n        return\n    xp [ 0 ] = xp [ 0 ] + yp [ 0 ]\n    yp [ 0 ] = xp [ 0 ] - yp [ 0 ]\n    xp [ 0 ] = xp [ 0 ] - yp [ 0 ]\n", "MINIMUM_NUMBER_OF_MANIPULATIONS_REQUIRED_TO_MAKE_TWO_STRINGS_ANAGRAM_WITHOUT_DELETION_OF_CHARACTER": "def countManipulations ( s1 , s2 ) :\n    count = 0\n    char_count = [ 0 ] * 26\n    for i in range ( 26 ) :\n        char_count [ i ] = 0\n    for i in range ( len ( s1 ) ) :\n        char_count [ ord ( s1 [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( len ( s2 ) ) :\n        char_count [ ord ( s2 [ i ] ) - ord ( 'a' ) ] -= 1\n        if ( char_count [ ord ( s2 [ i ] ) - ord ( 'a' ) ] < 0 ) :\n            count += 1\n    return count\n", "CHECK_IF_ALL_THE_ELEMENTS_CAN_BE_MADE_OF_SAME_PARITY_BY_INVERTING_ADJACENT_ELEMENTS": "def flipsPossible ( a , n ) :\n    count_odd = 0 ; count_even = 0 ;\n    for i in range ( n ) :\n        if ( a [ i ] & 1 ) :\n            count_odd += 1 ;\n        else :\n            count_even += 1 ;\n    if ( count_odd % 2 and count_even % 2 ) :\n        return False ;\n    else :\n        return True ;\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL": "def substringConversions ( s , k , b ) :\n    l = len ( s ) ;\n    for i in range ( l ) :\n        if ( ( i + k ) < l + 1 ) :\n            sub = s [ i : i + k ] ;\n            sum , counter = 0 , 0 ;\n            for i in range ( len ( sub ) - 1 , - 1 , - 1 ) :\n                sum = sum + ( ( ord ( sub [ i ] ) - ord ( '0' ) ) * pow ( b , counter ) ) ;\n                counter += 1 ;\n            print ( sum , end = \" \" ) ;\n", "FIND_K_SUCH_THAT_ALL_ELEMENTS_IN_KTH_ROW_ARE_0_AND_KTH_COLUMN_ARE_1_IN_A_BOOLEAN_MATRIX": "def find ( arr ) :\n    n = len ( arr )\n    i = 0\n    j = n - 1\n    res = - 1\n    while i < n and j >= 0 :\n        if arr [ i ] [ j ] == 0 :\n            while j >= 0 and ( arr [ i ] [ j ] == 0 or i == j ) :\n                j -= 1\n            if j == - 1 :\n                res = i\n                break\n            else : i += 1\n        else :\n            while i < n and ( arr [ i ] [ j ] == 1 or i == j ) :\n                i += 1\n            if i == n :\n                res = j\n                break\n            else : j -= 1\n    if res == - 1 :\n        return res\n    for i in range ( 0 , n ) :\n        if res != i and arr [ i ] [ res ] != 1 :\n            return - 1\n    for j in range ( 0 , j ) :\n        if res != j and arr [ res ] [ j ] != 0 :\n            return - 1 ;\n    return res ;\n", "NUMBER_ORDERED_PAIRS_AI_AJ_0": "def countPairs ( a , n ) :\n    count = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if ( a [ i ] & a [ j ] ) == 0 :\n                count += 2\n    return count\n", "CIRCLE_LATTICE_POINTS": "def countLattice ( r ) :\n    if ( r <= 0 ) :\n        return 0\n    result = 4\n    for x in range ( 1 , r ) :\n        ySquare = r * r - x * x\n        y = int ( math.sqrt ( ySquare ) )\n        if ( y * y == ySquare ) :\n            result += 4\n    return result\n", "MINIMUM_CHARACTERS_ADDED_FRONT_MAKE_STRING_PALINDROME": "def ispalindrome ( s ) :\n    l = len ( s )\n    i = 0\n    j = l - 1\n    while i <= j :\n        if ( s [ i ] != s [ j ] ) :\n            return False\n        i += 1\n        j -= 1\n    return True\n", "K_TH_MISSING_ELEMENT_INCREASING_SEQUENCE_NOT_PRESENT_GIVEN_SEQUENCE": "def find ( a , b , k , n1 , n2 ) :\n    s = set ( )\n    for i in range ( n2 ) :\n        s.add ( b [ i ] )\n    missing = 0\n    for i in range ( n1 ) :\n        if a [ i ] not in s :\n            missing += 1\n        if missing == k :\n            return a [ i ]\n    return - 1\n", "PROGRAM_CHECK_ISBN": "def isValidISBN ( isbn ) :\n    if len ( isbn ) != 10 :\n        return False\n    _sum = 0\n    for i in range ( 9 ) :\n        if 0 <= int ( isbn [ i ] ) <= 9 :\n            _sum += int ( isbn [ i ] ) * ( 10 - i )\n        else :\n            return False\n    if ( isbn [ 9 ] != 'X' and 0 <= int ( isbn [ 9 ] ) <= 9 ) :\n        return False\n    _sum += 10 if isbn [ 9 ] == 'X' else int ( isbn [ 9 ] )\n    return ( _sum % 11 == 0 )\n", "COUNT_WAYS_INCREASE_LCS_LENGTH_TWO_STRINGS_ONE": "def waysToIncreaseLCSBy1 ( str1 , str2 ) :\n    m = len ( str1 )\n    n = len ( str2 )\n    position = [ [ ] for i in range ( M ) ]\n    for i in range ( 1 , n + 1 , 1 ) :\n        position [ ord ( str2 [ i - 1 ] ) - 97 ].append ( i )\n    lcsl = [ [ 0 for i in range ( n + 2 ) ] for j in range ( m + 2 ) ]\n    lcsr = [ [ 0 for i in range ( n + 2 ) ] for j in range ( m + 2 ) ]\n    for i in range ( 1 , m + 1 , 1 ) :\n        for j in range ( 1 , n + 1 , 1 ) :\n            if ( str1 [ i - 1 ] == str2 [ j - 1 ] ) :\n                lcsl [ i ] [ j ] = 1 + lcsl [ i - 1 ] [ j - 1 ]\n            else :\n                lcsl [ i ] [ j ] = max ( lcsl [ i - 1 ] [ j ] , lcsl [ i ] [ j - 1 ] )\n    for i in range ( m , 0 , - 1 ) :\n        for j in range ( n , 0 , - 1 ) :\n            if ( str1 [ i - 1 ] == str2 [ j - 1 ] ) :\n                lcsr [ i ] [ j ] = 1 + lcsr [ i + 1 ] [ j + 1 ]\n            else :\n                lcsr [ i ] [ j ] = max ( lcsr [ i + 1 ] [ j ] , lcsr [ i ] [ j + 1 ] )\n    ways = 0\n    for i in range ( 0 , m + 1 , 1 ) :\n        for C in range ( 0 , 26 , 1 ) :\n            for j in range ( 0 , len ( position [ C ] ) , 1 ) :\n                p = position [ C ] [ j ]\n                if ( lcsl [ i ] [ p - 1 ] + lcsr [ i + 1 ] [ p + 1 ] == lcsl [ m ] [ n ] ) :\n                    ways += 1\n    return ways\n", "DYNAMIC_PROGRAMMING_SET_11_EGG_DROPPING_PUZZLE_1": "def eggDrop ( n , k ) :\n    eggFloor = [ [ 0 for x in range ( k + 1 ) ] for x in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        eggFloor [ i ] [ 1 ] = 1\n        eggFloor [ i ] [ 0 ] = 0\n    for j in range ( 1 , k + 1 ) :\n        eggFloor [ 1 ] [ j ] = j\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( 2 , k + 1 ) :\n            eggFloor [ i ] [ j ] = INT_MAX\n            for x in range ( 1 , j + 1 ) :\n                res = 1 + max ( eggFloor [ i - 1 ] [ x - 1 ] , eggFloor [ i ] [ j - x ] )\n                if res < eggFloor [ i ] [ j ] :\n                    eggFloor [ i ] [ j ] = res\n    return eggFloor [ n ] [ k ]\n", "WAYS_TO_WRITE_N_AS_SUM_OF_TWO_OR_MORE_POSITIVE_INTEGERS": "def CountWays ( n ) :\n    table = [ 0 ] * ( n + 1 )\n    table [ 0 ] = 1\n    for i in range ( 1 , n ) :\n        for j in range ( i , n + 1 ) :\n            table [ j ] += table [ j - i ]\n    return table [ n ]\n", "PROGRAM_SUM_COSX_SERIES": "def cosXSertiesSum ( x , n ) :\n    x = x * ( PI / 180.0 ) ;\n    res = 1 ;\n    sign = 1 ;\n    fact = 1 ;\n    pow = 1 ;\n    for i in range ( 1 , 5 ) :\n        sign = sign * - 1 ;\n        fact = fact * ( 2 * i - 1 ) * ( 2 * i ) ;\n        pow = pow * x * x ;\n        res = res + sign * pow / fact ;\n    return res ;\n", "UNIQUE_CELLS_BINARY_MATRIX": "def countUnique ( mat , n , m ) :\n    rowsum = [ 0 ] * n ;\n    colsum = [ 0 ] * m ;\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( mat [ i ] [ j ] != 0 ) :\n                rowsum [ i ] += 1 ;\n                colsum [ j ] += 1 ;\n    uniquecount = 0 ;\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( mat [ i ] [ j ] != 0 and rowsum [ i ] == 1 and colsum [ j ] == 1 ) :\n                uniquecount += 1 ;\n    return uniquecount ;\n", "GREEDY_ALGORITHM_TO_FIND_MINIMUM_NUMBER_OF_COINS": "def findMin ( V ) :\n    deno = [ 1 , 2 , 5 , 10 , 20 , 50 , 100 , 500 , 1000 ]\n    n = len ( deno )\n    ans = [ ]\n    i = n - 1\n    while ( i >= 0 ) :\n        while ( V >= deno [ i ] ) :\n            V -= deno [ i ]\n            ans.append ( deno [ i ] )\n        i -= 1\n    for i in range ( len ( ans ) ) :\n        print ( ans [ i ] , end = \" \" )\n", "CHECK_INTEGER_OVERFLOW_MULTIPLICATION": "def isOverflow ( a , b ) :\n    if ( a == 0 or b == 0 ) :\n        return False\n    result = a * b\n    if ( result >= 9223372036854775807 or result <= - 9223372036854775808 ) :\n        result = 0\n    if ( a == ( result // b ) ) :\n        print ( result // b )\n        return False\n    else :\n        return True\n", "DIFFERENCE_BETWEEN_HIGHEST_AND_LEAST_FREQUENCIES_IN_AN_ARRAY_1": "def findDiff ( arr , n ) :\n    mp = defaultdict ( lambda : 0 )\n    for i in range ( n ) :\n        mp [ arr [ i ] ] += 1\n    max_count = 0 ; min_count = n\n    for key , values in mp.items ( ) :\n        max_count = max ( max_count , values )\n        min_count = min ( min_count , values )\n    return max_count - min_count\n", "COMPOSITE_NUMBER": "def isComposite ( n ) :\n    if ( n <= 1 ) :\n        return False\n    if ( n <= 3 ) :\n        return False\n    if ( n % 2 == 0 or n % 3 == 0 ) :\n        return True\n    i = 5\n    while ( i * i <= n ) :\n        if ( n % i == 0 or n % ( i + 2 ) == 0 ) :\n            return True\n        i = i + 6\n    return False\n", "LARGEST_INCREASING_SUBSEQUENCE_OF_CONSECUTIVE_INTEGERS": "def findLIS ( A , n ) :\n    hash = dict ( )\n    LIS_size , LIS_index = 1 , 0\n    hash [ A [ 0 ] ] = 1\n    for i in range ( 1 , n ) :\n        if A [ i ] - 1 not in hash :\n            hash [ A [ i ] - 1 ] = 0\n        hash [ A [ i ] ] = hash [ A [ i ] - 1 ] + 1\n        if LIS_size < hash [ A [ i ] ] :\n            LIS_size = hash [ A [ i ] ]\n            LIS_index = A [ i ]\n    print ( \"LIS_size =\" , LIS_size )\n    print ( \"LIS : \" , end = \"\" )\n    start = LIS_index - LIS_size + 1\n    while start <= LIS_index :\n        print ( start , end = \" \" )\n        start += 1\n", "COUNT_SET_BITS_IN_AN_INTEGER_2": "def countSetBits ( n ) :\n    count = 0\n    while ( n ) :\n        n &= ( n - 1 )\n        count += 1\n    return count\n", "FIND_FOUR_ELEMENTS_A_B_C_AND_D_IN_AN_ARRAY_SUCH_THAT_AB_CD": "def findPairs ( arr , n ) :\nHash = { }\nfor i in range ( n - 1 ) :\n    for j in range ( i + 1 , n ) :\n    sum = arr [ i ] + arr [ j ]\n    if sum in Hash.keys ( ) :\n        prev = Hash.get ( sum )\n        print ( str ( prev ) + \" and (%d, %d)\" % ( arr [ i ] , arr [ j ] ) )\n        return True\n    else :\n        Hash [ sum ] = ( arr [ i ] , arr [ j ] )\n", "COUNT_OBTUSE_ANGLES_CIRCLE_K_EQUIDISTANT_POINTS_2_GIVEN_POINTS": "def countObtuseAngles ( a , b , k ) :\n    c1 = ( b - a ) - 1\n    c2 = ( k - b ) + ( a - 1 )\n    if ( c1 == c2 ) :\n        return 0\n    return min ( c1 , c2 )\n", "NUMBER_TRIANGLES_N_MOVES_1": "def numberOfTriangles ( n ) :\n    ans = 2 * ( pow ( 3 , n ) ) - 1 ;\n    return ans ;\n", "FIND_A_REPEATING_AND_A_MISSING_NUMBER": "def printTwoElements ( arr , size ) :\n    for i in range ( size ) :\n        if arr [ abs ( arr [ i ] ) - 1 ] > 0 :\n            arr [ abs ( arr [ i ] ) - 1 ] = - arr [ abs ( arr [ i ] ) - 1 ]\n        else :\n            print ( \"The repeating element is\" , abs ( arr [ i ] ) )\n    for i in range ( size ) :\n        if arr [ i ] > 0 :\n            print ( \"and the missing element is\" , i + 1 )\n", "MINIMUM_DIFFERENCE_BETWEEN_GROUPS_OF_SIZE_TWO": "def calculate ( a , n ) :\n    a.sort ( ) ;\n    s = [ ] ;\n    i = 0 ;\n    j = n - 1 ;\n    while ( i < j ) :\n        s.append ( ( a [ i ] + a [ j ] ) ) ;\n        i += 1 ;\n        j -= 1 ;\n    mini = min ( s ) ;\n    maxi = max ( s ) ;\n    return abs ( maxi - mini ) ;\n", "FIND_PERIMETER_CYLINDER": "def perimeter ( diameter , height ) :\n    return 2 * ( diameter + height )\n", "MAGICAL_INDICES_ARRAY": "def solve ( A , n ) :\n    cnt = 0\n    parent = [ None ] * ( n + 1 )\n    vis = [ None ] * ( n + 1 )\n    for i in range ( 0 , n + 1 ) :\n        parent [ i ] = - 1\n        vis [ i ] = 0\n    for i in range ( 0 , n ) :\n        j = i\n        if ( parent [ j ] == - 1 ) :\n            while ( parent [ j ] == - 1 ) :\n                parent [ j ] = i\n                j = ( j + A [ j ] + 1 ) % n\n            if ( parent [ j ] == i ) :\n                while ( vis [ j ] == 0 ) :\n                    vis [ j ] = 1\n                    cnt = cnt + 1\n                    j = ( j + A [ j ] + 1 ) % n\n    return cnt\n", "FIND_A_FIXED_POINT_IN_A_GIVEN_ARRAY_1": "def binarySearch ( arr , low , high ) :\n    if high >= low :\n        mid = ( low + high ) // 2\n    if mid is arr [ mid ] :\n        return mid\n    if mid > arr [ mid ] :\n        return binarySearch ( arr , ( mid + 1 ) , high )\n    else :\n        return binarySearch ( arr , low , ( mid - 1 ) )\n    return - 1\n", "FIND_SIZE_OF_THE_LARGEST_FORMED_BY_ALL_ONES_IN_A_BINARY_MATRIX": "def findLargestPlus ( mat ) :\n    left = [ [ 0 for x in range ( N ) ] for y in range ( N ) ]\n    right = [ [ 0 for x in range ( N ) ] for y in range ( N ) ]\n    top = [ [ 0 for x in range ( N ) ] for y in range ( N ) ]\n    bottom = [ [ 0 for x in range ( N ) ] for y in range ( N ) ]\n    for i in range ( N ) :\n        top [ 0 ] [ i ] = mat [ 0 ] [ i ]\n        bottom [ N - 1 ] [ i ] = mat [ N - 1 ] [ i ]\n        left [ i ] [ 0 ] = mat [ i ] [ 0 ]\n        right [ i ] [ N - 1 ] = mat [ i ] [ N - 1 ]\n    for i in range ( N ) :\n        for j in range ( 1 , N ) :\n            if ( mat [ i ] [ j ] == 1 ) :\n                left [ i ] [ j ] = left [ i ] [ j - 1 ] + 1\n            else :\n                left [ i ] [ j ] = 0\n            if ( mat [ j ] [ i ] == 1 ) :\n                top [ j ] [ i ] = top [ j - 1 ] [ i ] + 1\n            else :\n                top [ j ] [ i ] = 0\n            j = N - 1 - j\n            if ( mat [ j ] [ i ] == 1 ) :\n                bottom [ j ] [ i ] = bottom [ j + 1 ] [ i ] + 1\n            else :\n                bottom [ j ] [ i ] = 0\n            if ( mat [ i ] [ j ] == 1 ) :\n                right [ i ] [ j ] = right [ i ] [ j + 1 ] + 1\n            else :\n                right [ i ] [ j ] = 0\n            j = N - 1 - j\n    n = 0\n    for i in range ( N ) :\n        for j in range ( N ) :\n            l = min ( min ( top [ i ] [ j ] , bottom [ i ] [ j ] ) , min ( left [ i ] [ j ] , right [ i ] [ j ] ) )\n            if ( l > n ) :\n                n = l\n    if ( n ) :\n        return 4 * ( n - 1 ) + 1\n    return 0\n", "LEVEL_NODE_TREE_SOURCE_NODE_USING_BFS": "def printLevels ( graph , V , x ) :\n    level = [ None ] * V\n    marked = [ False ] * V\n    que = queue.Queue ( )\n    que.put ( x )\n    level [ x ] = 0\n    marked [ x ] = True\n    while ( not que.empty ( ) ) :\n        x = que.get ( )\n        for i in range ( len ( graph [ x ] ) ) :\n            b = graph [ x ] [ i ]\n            if ( not marked [ b ] ) :\n                que.put ( b )\n                level [ b ] = level [ x ] + 1\n                marked [ b ] = True\n    print ( \"Nodes\" , \" \" , \"Level\" )\n    for i in range ( V ) :\n        print ( \" \" , i , \" --> \" , level [ i ] )\n", "FIND_SQUARE_ROOT_UNDER_MODULO_P_SET_1_WHEN_P_IS_IN_FORM_OF_4I_3": "def squareRoot ( n , p ) :\n    n = n % p\n    for x in range ( 2 , p ) :\n        if ( ( x * x ) % p == n ) :\n            print ( \"Square root is \" , x )\n            return\n    print ( \"Square root doesn't exist\" )\n", "CHECK_IF_ARRAY_ELEMENTS_ARE_CONSECUTIVE": "def areConsecutive ( arr , n ) :\n    if ( n < 1 ) :\n        return False\n    Min = min ( arr )\n    Max = max ( arr )\n    if ( Max - Min + 1 == n ) :\n        visited = [ False for i in range ( n ) ]\n        for i in range ( n ) :\n            if ( visited [ arr [ i ] - Min ] != False ) :\n                return False\n            visited [ arr [ i ] - Min ] = True\n        return True\n    return False\n", "SMALLEST_SUBSET_SUM_GREATER_ELEMENTS": "def minElements ( arr , n ) :\n    halfSum = 0\n    for i in range ( n ) :\n        halfSum = halfSum + arr [ i ]\n    halfSum = int ( halfSum / 2 )\n    arr.sort ( reverse = True )\n    res = 0\n    curr_sum = 0\n    for i in range ( n ) :\n        curr_sum += arr [ i ]\n        res += 1\n        if curr_sum > halfSum :\n            return res\n    return res\n", "SUM_OF_ALL_ELEMENTS_UP_TO_NTH_ROW_IN_A_PASCALS_TRIANGLE_1": "def calculateSum ( n ) :\n    sum = 0\n    sum = 1 << n ;\n    return ( sum - 1 )\n", "SWAP_TWO_NIBBLES_BYTE": "def swapNibbles ( x ) :\n    return ( ( x & 0x0F ) << 4 | ( x & 0xF0 ) >> 4 )\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME_1": "def canFormPalindrome ( strr ) :\n    listt = [ ]\n    for i in range ( len ( strr ) ) :\n        if ( strr [ i ] in listt ) :\n            listt.remove ( strr [ i ] )\n        else :\n            listt.append ( strr [ i ] )\n    if ( len ( strr ) % 2 == 0 and len ( listt ) == 0 or \\ ( len ( strr ) % 2 == 1 and len ( listt ) == 1 ) ) :\n        return True\n    else :\n        return False\n", "WAYS_SPLIT_STRING_PARTITION_STARTS_DISTINCT_CHARACTER": "def countWays ( s ) :\n    count = [ 0 ] * 26 ;\n    for x in s :\n        count [ ord ( x ) - ord ( 'a' ) ] = ( count [ ord ( x ) - ord ( 'a' ) ] ) + 1 ;\n    count [ ord ( s [ 0 ] ) - ord ( 'a' ) ] = 1 ;\n    ans = 1 ;\n    for i in range ( 26 ) :\n        if ( count [ i ] != 0 ) :\n            ans *= count [ i ] ;\n    return ans ;\n", "ENTRINGER_NUMBER_1": "def zigzag ( n , k ) :\n    dp = [ [ 0 for x in range ( k + 1 ) ] for y in range ( n + 1 ) ]\n    dp [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , n + 1 ) :\n        dp [ i ] [ 0 ] = 0\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , k + 1 ) :\n            dp [ i ] [ j ] = ( dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ i - j ] )\n    return dp [ n ] [ k ]\n", "COUNT_PAIRS_DIFFERENCE_EQUAL_K": "def countPairsWithDiffK ( arr , n , k ) :\n    count = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if arr [ i ] - arr [ j ] == k or arr [ j ] - arr [ i ] == k :\n                count += 1\n    return count\n", "EXPECTATION_EXPECTED_VALUE_ARRAY": "def calc_Expectation ( a , n ) :\n    prb = 1 / n\n    sum = 0\n    for i in range ( 0 , n ) :\n        sum += ( a [ i ] * prb )\n    return float ( sum )\n", "GROUP_OCCURRENCES_CHARACTERS_ACCORDING_FIRST_APPEARANCE": "def printGrouped ( string ) :\n    n = len ( string )\n    count = [ 0 ] * MAX_CHAR\n    for i in range ( n ) :\n        count [ ord ( string [ i ] ) - ord ( \"a\" ) ] += 1\n    for i in range ( n ) :\n        while count [ ord ( string [ i ] ) - ord ( \"a\" ) ] :\n            print ( string [ i ] , end = \"\" )\n            count [ ord ( string [ i ] ) - ord ( \"a\" ) ] -= 1\n        count [ ord ( string [ i ] ) - ord ( \"a\" ) ] = 0\n", "MAXIMUM_PATH_SUM_POSITION_JUMPS_DIVISIBILITY_CONDITION": "def printMaxSum ( arr , n ) :\n    dp = [ 0 for i in range ( n ) ]\n    for i in range ( n ) :\n        dp [ i ] = arr [ i ]\n        maxi = 0\n        for j in range ( 1 , int ( ( i + 1 ) ** 0.5 ) + 1 ) :\n            if ( ( i + 1 ) % j == 0 and ( i + 1 ) != j ) :\n                if ( dp [ j - 1 ] > maxi ) :\n                    maxi = dp [ j - 1 ]\n                if ( dp [ ( i + 1 ) // j - 1 ] > maxi and j != 1 ) :\n                    maxi = dp [ ( i + 1 ) // j - 1 ]\n        dp [ i ] += maxi\n    for i in range ( n ) :\n        print ( dp [ i ] , end = ' ' )\n", "PROGRAM_CIRCUMFERENCE_PARALLELOGRAM": "def circumferenceparallelogram ( a , b ) :\n    return ( ( 2 * a ) + ( 2 * b ) )\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_2": "def numberOfPaths ( p , q ) :\n    dp = [ 1 for i in range ( q ) ]\n    for i in range ( p - 1 ) :\n        for j in range ( 1 , q ) :\n            dp [ j ] += dp [ j - 1 ]\n    return dp [ q - 1 ]\n", "REMOVE_MINIMUM_NUMBER_CHARACTERS_TWO_STRINGS_BECOME_ANAGRAM": "def remAnagram ( str1 , str2 ) :\n    count1 = [ 0 ] * CHARS\n    count2 = [ 0 ] * CHARS\n    i = 0\n    while i < len ( str1 ) :\n        count1 [ ord ( str1 [ i ] ) - ord ( 'a' ) ] += 1\n        i += 1\n    i = 0\n    while i < len ( str2 ) :\n        count2 [ ord ( str2 [ i ] ) - ord ( 'a' ) ] += 1\n        i += 1\n    result = 0\n    for i in range ( 26 ) :\n        result += abs ( count1 [ i ] - count2 [ i ] )\n    return result\n", "SUM_DIVISORS_1_N_1": "def divisorSum ( n ) :\n    sum = 0\n    for i in range ( 1 , n + 1 ) :\n        sum += int ( n / i ) * i\n    return int ( sum )\n", "FIND_LENGTH_LONGEST_SUBSEQUENCE_ONE_STRING_SUBSTRING_ANOTHER_STRING": "def maxSubsequenceSubstring ( x , y , n , m ) :\n    dp = [ [ 0 for i in range ( MAX ) ] for i in range ( MAX ) ]\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if ( x [ j - 1 ] == y [ i - 1 ] ) :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = dp [ i ] [ j - 1 ]\n    ans = 0\n    for i in range ( 1 , m + 1 ) :\n        ans = max ( ans , dp [ i ] [ n ] )\n    return ans\n", "SUM_FAI_AJ_PAIRS_ARRAY_N_INTEGERS": "def sum ( a , n ) :\n    cnt = dict ( )\n    ans = 0\n    pre_sum = 0\n    for i in range ( n ) :\n        ans += ( i * a [ i ] ) - pre_sum\n        pre_sum += a [ i ]\n        if ( a [ i ] - 1 ) in cnt :\n            ans -= cnt [ a [ i ] - 1 ]\n        if ( a [ i ] + 1 ) in cnt :\n            ans += cnt [ a [ i ] + 1 ]\n        if a [ i ] not in cnt :\n            cnt [ a [ i ] ] = 0\n        cnt [ a [ i ] ] += 1\n    return ans\n", "BINARY_REPRESENTATION_OF_A_GIVEN_NUMBER": "def bin ( n ) :\n    if n > 1 :\n        bin ( n // 2 )\n    print ( n % 2 , end = \"\" )\n", "KNAPSACK_PROBLEM": "def knapSack ( W , wt , val , n ) :\n    if n == 0 or W == 0 :\n        return 0\n    if ( wt [ n - 1 ] > W ) :\n        return knapSack ( W , wt , val , n - 1 )\n    else :\n        return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ] , wt , val , n - 1 ) , knapSack ( W , wt , val , n - 1 ) )\n", "DOUBLE_FACTORIAL_1": "def doublefactorial ( n ) :\n    res = 1 ;\n    for i in range ( n , - 1 , - 2 ) :\n        if ( i == 0 or i == 1 ) :\n            return res ;\n        else :\n            res *= i ;\n", "COUNT_DIGITS_FACTORIAL_SET_2": "def findDigits ( n ) :\n    if ( n < 0 ) :\n        return 0 ;\n    if ( n <= 1 ) :\n        return 1 ;\n    x = ( ( n * math.log10 ( n / math.e ) + math.log10 ( 2 * math.pi * n ) / 2.0 ) ) ;\n    return math.floor ( x ) + 1 ;\n", "DELANNOY_NUMBER_1": "def dealnnoy ( n , m ) :\n    dp = [ [ 0 for x in range ( n + 1 ) ] for x in range ( m + 1 ) ]\n    for i in range ( m ) :\n        dp [ 0 ] [ i ] = 1\n    for i in range ( 1 , m + 1 ) :\n        dp [ i ] [ 0 ] = 1\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            dp [ i ] [ j ] = dp [ i - 1 ] [ j ] + dp [ i - 1 ] [ j - 1 ] + dp [ i ] [ j - 1 ] ;\n    return dp [ m ] [ n ]\n", "FIND_THE_MISSING_NUMBER_2": "def getMissingNo ( a , n ) :\n    x1 = a [ 0 ]\n    x2 = 1\n    for i in range ( 1 , n ) :\n        x1 = x1 ^ a [ i ]\n    for i in range ( 2 , n + 2 ) :\n        x2 = x2 ^ i\n    return x1 ^ x2\n", "FIND_NUMBER_OF_TRIANGLES_POSSIBLE": "def findnumberofTriangles ( arr ) :\n    n = len ( arr )\n    arr.sort ( )\n    count = 0\n    for i in range ( 0 , n - 2 ) :\n        k = i + 2\n        for j in range ( i + 1 , n ) :\n            while ( k < n and arr [ i ] + arr [ j ] > arr [ k ] ) :\n                k += 1\n            if ( k > j ) :\n                count += k - j - 1\n    return count\n", "NUMBER_TRIANGLES_N_MOVES": "def numberOfTriangles ( n ) :\n    answer = [ None ] * ( n + 1 ) ;\n    answer [ 0 ] = 1 ;\n    i = 1\n    while i <= n :\n        answer [ i ] = answer [ i - 1 ] * 3 + 2 ;\n        i = i + 1\n    return answer [ n ] ;\n", "CHECK_SUMS_TH_ROW_TH_COLUMN_MATRIX": "def areSumSame ( a , n , m ) :\n    sum1 = 0\n    sum2 = 0\n    for i in range ( 0 , n ) :\n        sum1 = 0\n        sum2 = 0\n        for j in range ( 0 , m ) :\n            sum1 += a [ i ] [ j ]\n            sum2 += a [ j ] [ i ]\n        if ( sum1 == sum2 ) :\n            return 1\n    return 0\n", "WRITE_ONE_LINE_C_FUNCTION_TO_FIND_WHETHER_A_NO_IS_POWER_OF_TWO": "def isPowerOfTwo ( n ) :\n    if ( n == 0 ) :\n        return False\n    while ( n != 1 ) :\n        if ( n % 2 != 0 ) :\n            return False\n        n = n // 2\n    return True\n", "PUT_SPACES_WORDS_STARTING_CAPITAL_LETTERS": "def amendSentence ( string ) :\n    string = list ( string )\n    for i in range ( len ( string ) ) :\n        if string [ i ] >= 'A' and string [ i ] <= 'Z' :\n            string [ i ] = chr ( ord ( string [ i ] ) + 32 )\n            if i != 0 :\n                print ( \"\" , end = \"\" )\n            print ( string [ i ] , end = \"\" )\n        else :\n            print ( string [ i ] , end = \"\" )\n", "CHECK_DIVISIBILITY_BINARY_STRING_2K": "def isDivisible ( str , k ) :\n    n = len ( str )\n    c = 0\n    for i in range ( 0 , k ) :\n        if ( str [ n - i - 1 ] == '0' ) :\n            c += 1\n    return ( c == k )\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M": "def coutSubSeq ( A , N , M ) :\n    sum = 0\n    ans = 0\n    for i in range ( 0 , N ) :\n        for j in range ( i + 1 , N ) :\n            for k in range ( j + 1 , N ) :\n                sum = A [ i ] + A [ j ] + A [ k ]\n                if ( sum % M == 0 ) :\n                    ans = ans + 1\n    return ans\n", "LONGEST_CONSECUTIVE_SUBSEQUENCE": "def findLongestConseqSubseq ( arr , n ) :\n    s = Set ( )\n    ans = 0\n    for ele in arr :\n        s.add ( ele )\n    for i in range ( n ) :\n        if ( arr [ i ] - 1 ) not in s :\n            j = arr [ i ]\n            while ( j in s ) :\n                j += 1\n            ans = max ( ans , j - arr [ i ] )\n    return ans\n", "FIND_INDEX_GIVEN_FIBONACCI_NUMBER_CONSTANT_TIME_1": "def findIndex ( n ) :\n    fibo = 2.078087 * math.log ( n ) + 1.672276\n    return round ( fibo )\n", "LARGEST_DIVISIBLE_PAIRS_SUBSET": "def largestSubset ( a , n ) :\n    a.sort ( )\n    dp = [ 0 for i in range ( n ) ]\n    dp [ n - 1 ] = 1 ;\n    for i in range ( n - 2 , - 1 , - 1 ) :\n        mxm = 0 ;\n        for j in range ( i + 1 , n ) :\n            if a [ j ] % a [ i ] == 0 :\n                mxm = max ( mxm , dp [ j ] )\n        dp [ i ] = 1 + mxm\n    return max ( dp )\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT_2": "def isPowerOfFour ( n ) :\n    return ( n != 0 and ( ( n & ( n - 1 ) ) == 0 ) and not ( n & 0xAAAAAAAA ) ) ;\n", "COMPUTE_NCR_P_SET_1_INTRODUCTION_AND_DYNAMIC_PROGRAMMING_SOLUTION": "def nCrModp ( n , r , p ) :\n    C = [ 0 for i in range ( r + 1 ) ]\n    C [ 0 ] = 1\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( min ( i , r ) , 0 , - 1 ) :\n            C [ j ] = ( C [ j ] + C [ j - 1 ] ) % p\n    return C [ r ]\n", "ROUND_THE_GIVEN_NUMBER_TO_NEAREST_MULTIPLE_OF_10": "def round ( n ) :\n    a = ( n // 10 ) * 10\n    b = a + 10\n    return ( b if n - a > b - n else a )\n", "SORT_EVEN_NUMBERS_ASCENDING_ORDER_SORT_ODD_NUMBERS_DESCENDING_ORDER_1": "def twoWaySort ( arr , n ) :\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] & 1 ) :\n            arr [ i ] *= - 1\n    arr.sort ( )\n    for i in range ( 0 , n ) :\n        if ( arr [ i ] & 1 ) :\n            arr [ i ] *= - 1\n", "POINT_CLIPPING_ALGORITHM_COMPUTER_GRAPHICS": "def pointClip ( XY , n , Xmin , Ymin , Xmax , Ymax ) :\n    print ( \"Point inside the viewing pane:\" )\n    for i in range ( n ) :\n        if ( ( XY [ i ] [ 0 ] >= Xmin ) and ( XY [ i ] [ 0 ] <= Xmax ) ) :\n            if ( ( XY [ i ] [ 1 ] >= Ymin ) and ( XY [ i ] [ 1 ] <= Ymax ) ) :\n                print ( \"[\" , XY [ i ] [ 0 ] , \", \" , XY [ i ] [ 1 ] , \"]\" , sep = \"\" , end = \"\" )\n    print ( \"\\n\\nPoint outside the viewing pane:\" )\n    for i in range ( n ) :\n        if ( ( XY [ i ] [ 0 ] < Xmin ) or ( XY [ i ] [ 0 ] > Xmax ) ) :\n            print ( \"[\" , XY [ i ] [ 0 ] , \", \" , XY [ i ] [ 1 ] , \"]\" , sep = \"\" , end = \"\" )\n        if ( ( XY [ i ] [ 1 ] < Ymin ) or ( XY [ i ] [ 1 ] > Ymax ) ) :\n            print ( \"[\" , XY [ i ] [ 0 ] , \", \" , XY [ i ] [ 1 ] , \"]\" , sep = \"\" , end = \"\" )\n", "WAYS_TRANSFORMING_ONE_STRING_REMOVING_0_CHARACTERS": "def countTransformation ( a , b ) :\n    n = len ( a )\n    m = len ( b )\n    if m == 0 :\n        return 1\n    dp = [ [ 0 ] * ( n + 1 ) for _ in range ( m + 1 ) ]\n    for i in range ( m ) :\n        for j in range ( i , n ) :\n            if i == 0 :\n                if j == 0 :\n                    if a [ j ] == b [ i ] :\n                        dp [ i ] [ j ] = 1\n                    else :\n                        dp [ i ] [ j ] = 0\n                elif a [ j ] == b [ i ] :\n                    dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + 1\n                else :\n                    dp [ i ] [ j ] = dp [ i ] [ j - 1 ]\n            else :\n                if a [ j ] == b [ i ] :\n                    dp [ i ] [ j ] = ( dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ j - 1 ] )\n                else :\n                    dp [ i ] [ j ] = dp [ i ] [ j - 1 ]\n    return dp [ m - 1 ] [ n - 1 ]\n", "FIND_RELATIVE_COMPLEMENT_TWO_SORTED_ARRAYS": "def relativeComplement ( arr1 , arr2 , n , m ) :\n    i = 0\n    j = 0\n    while ( i < n and j < m ) :\n        if ( arr1 [ i ] < arr2 [ j ] ) :\n            print ( arr1 [ i ] , \"\" , end = \"\" )\n            i += 1\n        elif ( arr1 [ i ] > arr2 [ j ] ) :\n            j += 1\n        elif ( arr1 [ i ] == arr2 [ j ] ) :\n            i += 1\n            j += 1\n    while ( i < n ) :\n        print ( arr1 [ i ] , \"\" , end = \"\" )\n", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY": "def countPairs ( arr , n ) :\n    ans = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n ) :\n            if ( arr [ i ] == arr [ j ] ) :\n                ans += 1\n    return ans\n", "GIVEN_AN_ARRAY_OF_PAIRS_FIND_ALL_SYMMETRIC_PAIRS_IN_IT": "def findSymPairs ( arr , row ) :\n    hM = dict ( )\n    for i in range ( row ) :\n        first = arr [ i ] [ 0 ]\n        sec = arr [ i ] [ 1 ]\n        if ( sec in hM.keys ( ) and hM [ sec ] == first ) :\n            print ( \"(\" , sec , \",\" , first , \")\" )\n        else :\n            hM [ first ] = sec\n", "COUNT_SUBSEQUENCES_PRODUCT_LESS_K": "def productSubSeqCount ( arr , k ) :\n    n = len ( arr )\n    dp = [ [ 0 for i in range ( n + 1 ) ] for j in range ( k + 1 ) ]\n    for i in range ( 1 , k + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            dp [ i ] [ j ] = dp [ i ] [ j - 1 ]\n            if arr [ j - 1 ] <= i and arr [ j - 1 ] > 0 :\n                dp [ i ] [ j ] += dp [ i // arr [ j - 1 ] ] [ j - 1 ] + 1\n    return dp [ k ] [ n ]\n", "REARRANGE_ARRAY_ARRI_ARRJ_EVEN_ARRI": "def rearrangeArr ( arr , n ) :\n    evenPos = int ( n / 2 )\n    oddPos = n - evenPos\n    tempArr = np.empty ( n , dtype = object )\n    for i in range ( 0 , n ) :\n        tempArr [ i ] = arr [ i ]\n    tempArr.sort ( )\n    j = oddPos - 1\n    for i in range ( 0 , n , 2 ) :\n        arr [ i ] = tempArr [ j ]\n        j = j - 1\n    j = oddPos\n    for i in range ( 1 , n , 2 ) :\n        arr [ i ] = tempArr [ j ]\n        j = j + 1\n    for i in range ( 0 , n ) :\n        print ( arr [ i ] , end = ' ' )\n", "MINIMUM_ROTATIONS_UNLOCK_CIRCULAR_LOCK": "def minRotation ( input , unlock_code ) :\n    rotation = 0 ;\n    while ( input > 0 or unlock_code > 0 ) :\n        input_digit = input % 10 ;\n        code_digit = unlock_code % 10 ;\n        rotation += min ( abs ( input_digit - code_digit ) , 10 - abs ( input_digit - code_digit ) ) ;\n        input = int ( input / 10 ) ;\n        unlock_code = int ( unlock_code / 10 ) ;\n    return rotation ;\n", "REARRANGE_BINARY_STRING_ALTERNATE_X_Y_OCCURRENCES": "def arrangeString ( str1 , x , y ) :\n    count_0 = 0\n    count_1 = 0\n    n = len ( str1 )\n    for i in range ( n ) :\n        if str1 [ i ] == '0' :\n            count_0 += 1\n        else :\n            count_1 += 1\n    while count_0 > 0 or count_1 > 0 :\n        for i in range ( 0 , x ) :\n            if count_0 > 0 :\n                print ( \"0\" , end = \"\" )\n                count_0 -= 1\n        for j in range ( 0 , y ) :\n            if count_1 > 0 :\n                print ( \"1\" , end = \"\" )\n                count_1 -= 1\n", "DYNAMIC_PROGRAMMING_SET_14_MAXIMUM_SUM_INCREASING_SUBSEQUENCE": "def maxSumIS ( arr , n ) :\n    max = 0\n    msis = [ 0 for x in range ( n ) ]\n    for i in range ( n ) :\n        msis [ i ] = arr [ i ]\n    for i in range ( 1 , n ) :\n        for j in range ( i ) :\n            if ( arr [ i ] > arr [ j ] and msis [ i ] < msis [ j ] + arr [ i ] ) :\n                msis [ i ] = msis [ j ] + arr [ i ]\n    for i in range ( n ) :\n        if max < msis [ i ] :\n            max = msis [ i ]\n    return max\n", "NUMBER_UNIQUE_RECTANGLES_FORMED_USING_N_UNIT_SQUARES": "def countRect ( n ) :\n    ans = 0\n    for length in range ( 1 , int ( math.sqrt ( n ) ) + 1 ) :\n        height = length\n        while ( height * length <= n ) :\n            ans += 1\n            height += 1\n    return ans\n", "PROGRAM_TO_PRINT_TETRAHEDRAL_NUMBERS_UPTO_NTH_TERM": "def printSeries ( n ) :\n    for i in range ( 1 , n + 1 ) :\n        num = i * ( i + 1 ) * ( i + 2 ) // 6\n        print ( num , end = ' ' )\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX": "def transpose ( A , B ) :\n    for i in range ( N ) :\n        for j in range ( N ) :\n            B [ i ] [ j ] = A [ j ] [ i ]\n", "PROGRAM_DECIMAL_BINARY_CONVERSION_1": "def decToBinary ( n ) :\n    for i in range ( 31 , - 1 , - 1 ) :\n        k = n >> i ;\n        if ( k & 1 ) :\n            print ( \"1\" , end = \"\" ) ;\n        else :\n            print ( \"0\" , end = \"\" ) ;\n", "REARRANGE_ARRAY_ORDER_SMALLEST_LARGEST_2ND_SMALLEST_2ND_LARGEST": "def rearrangeArray ( arr , n ) :\n    arr.sort ( )\n    tempArr = [ 0 ] * ( n + 1 )\n    ArrIndex = 0\n    i = 0\n    j = n - 1\n    while ( i <= n // 2 or j > n // 2 ) :\n        tempArr [ ArrIndex ] = arr [ i ]\n        ArrIndex = ArrIndex + 1\n        tempArr [ ArrIndex ] = arr [ j ]\n        ArrIndex = ArrIndex + 1\n        i = i + 1\n        j = j - 1\n    for i in range ( 0 , n ) :\n        arr [ i ] = tempArr [ i ]\n", "SUM_AREA_RECTANGLES_POSSIBLE_ARRAY": "def MaxTotalRectangleArea ( a , n ) :\n    a.sort ( reverse = True )\n    sum = 0\n    flag = False\n    len = 0\n    i = 0\n    while ( i < n - 1 ) :\n        if ( i != 0 ) :\n            i = i + 1\n        if ( ( a [ i ] == a [ i + 1 ] or a [ i ] - a [ i + 1 ] == 1 ) and flag == False ) :\n            flag = True\n            len = a [ i + 1 ]\n            i = i + 1\n        elif ( ( a [ i ] == a [ i + 1 ] or a [ i ] - a [ i + 1 ] == 1 ) and flag == True ) :\n            sum = sum + a [ i + 1 ] * len\n            flag = False\n            i = i + 1\n    return sum\n", "GIVEN_BINARY_STRING_COUNT_NUMBER_SUBSTRINGS_START_END_1": "def countSubStr ( st , n ) :\n    res = 0\n    for i in range ( 0 , n ) :\n        if ( st [ i ] == '1' ) :\n            for j in range ( i + 1 , n ) :\n                if ( st [ j ] == '1' ) :\n                    res = res + 1\n    return res\n", "DYNAMIC_PROGRAMMING_SET_31_OPTIMAL_STRATEGY_FOR_A_GAME": "def optimalStrategyOfGame ( arr , n ) :\n    table = [ [ 0 for i in range ( n ) ] for i in range ( n ) ]\n    for gap in range ( n ) :\n        for j in range ( gap , n ) :\n            i = j - gap\n            x = 0\n            if ( ( i + 2 ) <= j ) :\n                x = table [ i + 2 ] [ j ]\n            y = 0\n            if ( ( i + 1 ) <= ( j - 1 ) ) :\n                y = table [ i + 1 ] [ j - 1 ]\n            z = 0\n            if ( i <= ( j - 2 ) ) :\n                z = table [ i ] [ j - 2 ]\n            table [ i ] [ j ] = max ( arr [ i ] + min ( x , y ) , arr [ j ] + min ( y , z ) )\n    return table [ 0 ] [ n - 1 ]\n", "REPLACE_CHARACTER_C1_C2_C2_C1_STRING_S": "def replace ( s , c1 , c2 ) :\n    l = len ( s )\n    for i in range ( l ) :\n        if ( s [ i ] == c1 ) :\n            s = s [ 0 : i ] + c2 + s [ i + 1 : ]\n        elif ( s [ i ] == c2 ) :\n            s = s [ 0 : i ] + c1 + s [ i + 1 : ]\n    return s\n", "FIND_THE_LARGEST_SUBARRAY_WITH_0_SUM_1": "def maxLen ( arr ) :\n    hash_map = { }\n    max_len = 0\n    curr_sum = 0\n    for i in range ( len ( arr ) ) :\n        curr_sum += arr [ i ]\n        if arr [ i ] is 0 and max_len is 0 :\n            max_len = 1\n        if curr_sum is 0 :\n            max_len = i + 1\n        if curr_sum in hash_map :\n            max_len = max ( max_len , i - hash_map [ curr_sum ] )\n        else :\n            hash_map [ curr_sum ] = i\n    return max_len\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM_1": "def summingSeries ( n ) :\n    return math.pow ( n , 2 )\n", "RECURSIVE_C_PROGRAM_LINEARLY_SEARCH_ELEMENT_GIVEN_ARRAY": "def recSearch ( arr , l , r , x ) :\n    if r < l :\n        return - 1\n    if arr [ l ] == x :\n        return l\n    if arr [ r ] == x :\n        return r\n    return recSearch ( arr , l + 1 , r - 1 , x )\n", "PRINT_SHORTEST_PATH_PRINT_STRING_SCREEN": "def printPath ( str ) :\n    i = 0\n    curX = 0\n    curY = 0\n    while ( i < len ( str ) ) :\n        nextX = int ( ( ord ( str [ i ] ) - ord ( 'A' ) ) / 5 )\n        nextY = ( ord ( str [ i ] ) - ord ( 'B' ) + 1 ) % 5\n        while ( curX > nextX ) :\n            print ( \"Move Up\" )\n            curX -= 1\n        while ( curY > nextY ) :\n            print ( \"Move Left\" )\n            curY -= 1\n        while ( curX < nextX ) :\n            print ( \"Move Down\" )\n            curX += 1\n        while ( curY < nextY ) :\n            print ( \"Move Right\" )\n            curY += 1\n        print ( \"Press OK\" )\n        i += 1\n", "COUNT_ENTRIES_EQUAL_TO_X_IN_A_SPECIAL_MATRIX": "def count ( n , x ) :\n    cnt = 0\n    for i in range ( 1 , n + 1 ) :\n        if i <= x :\n            if x // i <= n and x % i == 0 :\n                cnt += 1\n    return cnt\n", "PROGRAM_FIND_LINE_PASSING_2_POINTS": "def lineFromPoints ( P , Q ) :\n    a = Q [ 1 ] - P [ 1 ]\n    b = P [ 0 ] - Q [ 0 ]\n    c = a * ( P [ 0 ] ) + b * ( P [ 1 ] )\n    if ( b < 0 ) :\n        print ( \"The line passing through points P and Q is:\" , a , \"x \" , b , \"y = \" , c , \"\\n\" )\n    else :\n        print ( \"The line passing through points P and Q is: \" , a , \"x + \" , b , \"y = \" , c , \"\\n\" )\n", "REMOVE_ARRAY_END_ELEMENT_MAXIMIZE_SUM_PRODUCT": "def solve ( dp , a , low , high , turn ) :\n    if ( low == high ) :\n        return a [ low ] * turn\n    if ( dp [ low ] [ high ] != 0 ) :\n        return dp [ low ] [ high ]\n    dp [ low ] [ high ] = max ( a [ low ] * turn + solve ( dp , a , low + 1 , high , turn + 1 ) , a [ high ] * turn + solve ( dp , a , low , high - 1 , turn + 1 ) ) ;\n    return dp [ low ] [ high ]\n", "CHECK_GRAPHS_CYCLE_ODD_LENGTH": "def containsOdd ( G , src ) :\n    global V\n    colorArr = [ - 1 ] * V\n    colorArr [ src ] = 1\n    q = queue.Queue ( )\n    q.put ( src )\n    while ( not q.empty ( ) ) :\n        u = q.get ( )\n        if ( G [ u ] [ u ] == 1 ) :\n            return True\n        for v in range ( V ) :\n            if ( G [ u ] [ v ] and colorArr [ v ] == - 1 ) :\n                colorArr [ v ] = 1 - colorArr [ u ]\n                q.put ( v )\n            elif ( G [ u ] [ v ] and colorArr [ v ] == colorArr [ u ] ) :\n                return True\n    return False\n", "SUM_SERIES_ALTERNATE_SIGNED_SQUARES_AP": "def seiresSum ( n , a ) :\n    res = 0\n    for i in range ( 0 , 2 * n ) :\n        if ( i % 2 == 0 ) :\n            res += a [ i ] * a [ i ]\n        else :\n            res -= a [ i ] * a [ i ]\n    return res\n", "PROGRAM_DECIMAL_BINARY_CONVERSION": "def decToBinary ( n ) :\n    binaryNum = [ 0 ] * n ;\n    i = 0 ;\n    while ( n > 0 ) :\n        binaryNum [ i ] = n % 2 ;\n        n = int ( n / 2 ) ;\n        i += 1 ;\n    for j in range ( i - 1 , - 1 , - 1 ) :\n        print ( binaryNum [ j ] , end = \"\" ) ;\n", "LONGEST_ALTERNATING_POSITIVE_NEGATIVE_SUBARRAY_STARTING_EVERY_INDEX": "def longestAlternating ( arr , n ) :\n    count = [ None ] * n\n    count [ n - 1 ] = 1\n    i = n - 2\n    while i >= 0 :\n        if ( arr [ i ] * arr [ i + 1 ] < 0 ) :\n            count [ i ] = count [ i + 1 ] + 1\n        else :\n            count [ i ] = 1 ;\n        i = i - 1\n    i = 0\n    while i < n :\n        print ( count [ i ] , end = \" \" )\n        i = i + 1\n", "FIND_STRING_LEXICOGRAPHIC_ORDER_GIVEN_TWO_STRINGS": "def lexNext ( s , n ) :\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if s [ i ] != 'z' :\n            k = ord ( s [ i ] )\n            s [ i ] = chr ( k + 1 )\n            return ''.join ( s )\n        s [ i ] = 'a'\n", "NUMBER_DECIMAL_NUMBERS_LENGTH_K_STRICT_MONOTONE": "def getNumStrictMonotone ( ln ) :\n    DP = [ [ 0 ] * DP_s for _ in range ( ln ) ]\n    for i in range ( DP_s ) :\n        DP [ 0 ] [ i ] = i + 1\n    for i in range ( 1 , ln ) :\n        for j in range ( 1 , DP_s ) :\n            DP [ i ] [ j ] = DP [ i - 1 ] [ j - 1 ] + DP [ i ] [ j - 1 ]\n    return DP [ ln - 1 ] [ DP_s - 1 ]\n", "PRINT_POSSIBLE_EDGES_TREE_GIVEN_DIAMETER_HEIGHT_VERTICES": "def constructTree ( n , d , h ) :\n    if d == 1 :\n        if n == 2 and h == 1 :\n            print ( \"1 2\" )\n            return 0\n        print ( \"-1\" )\n        return 0\n    if d > 2 * h :\n        print ( \"-1\" )\n        return 0\n    for i in range ( 1 , h + 1 ) :\n        print ( i , \" \" , i + 1 )\n    if d > h :\n        print ( 1 , \"  \" , h + 2 )\n        for i in range ( h + 2 , d + 1 ) :\n            print ( i , \" \" , i + 1 )\n    for i in range ( d + 1 , n ) :\n        k = 1\n        if d == h :\n            k = 2\n        print ( k , \" \" , i + 1 )\n", "MINIMAL_OPERATIONS_MAKE_NUMBER_MAGICAL": "def calculate ( s ) :\n    ans = 6\n    for i in range ( 10 ) :\n        for j in range ( 10 ) :\n            for k in range ( 10 ) :\n                for l in range ( 10 ) :\n                    for m in range ( 10 ) :\n                        for n in range ( 10 ) :\n                            if ( i + j + k == l + m + n ) :\n                                c = 0\n                                if ( i != ord ( s [ 0 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( j != ord ( s [ 1 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( k != ord ( s [ 2 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( l != ord ( s [ 3 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( m != ord ( s [ 4 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( n != ord ( s [ 5 ] ) - ord ( '0' ) ) :\n                                    c += 1\n                                if ( c < ans ) :\n                                    ans = c\n    return ans\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE": "def find3Numbers ( A , arr_size , sum ) :\n    for i in range ( 0 , arr_size - 2 ) :\n        for j in range ( i + 1 , arr_size - 1 ) :\n            for k in range ( j + 1 , arr_size ) :\n                if A [ i ] + A [ j ] + A [ k ] == sum :\n                    print ( \"Triplet is\" , A [ i ] , \", \" , A [ j ] , \", \" , A [ k ] )\n                    return True\n    return False\n", "AREA_OF_THE_CIRCLE_THAT_HAS_A_SQUARE_AND_A_CIRCLE_INSCRIBED_IN_IT": "def getArea ( a ) :\n    area = ( math.pi * a * a ) / 4\n    return area\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X_1": "def findPairs ( arr1 , arr2 , n , m , x ) :\n    s = set ( )\n    for i in range ( 0 , n ) :\n        s.add ( arr1 [ i ] )\n    for j in range ( 0 , m ) :\n        if ( ( x - arr2 [ j ] ) in s ) :\n            print ( ( x - arr2 [ j ] ) , '' , arr2 [ j ] )\n", "QUICK_WAY_CHECK_CHARACTERS_STRING": "def allCharactersSame ( s ) :\n    n = len ( s )\n    for i in range ( 1 , n ) :\n        if s [ i ] != s [ 0 ] :\n            return False\n    return True\n", "REARRANGE_ARRAY_ARRI": "def fix ( A , len ) :\n    for i in range ( 0 , len ) :\n        if ( A [ i ] != - 1 and A [ i ] != i ) :\n            x = A [ i ] ;\n            while ( A [ x ] != - 1 and A [ x ] != x ) :\n                y = A [ x ]\n                A [ x ] = x\n                x = y\n            A [ x ] = x ;\n            if ( A [ i ] != i ) :\n                A [ i ] = - 1 ;\n", "PAIR_WITH_GIVEN_PRODUCT_SET_1_FIND_IF_ANY_PAIR_EXISTS": "def isProduct ( arr , n , x ) :\n    for i in arr :\n        for j in arr :\n            if i * j == x :\n                return True\n    return False\n", "SORT_GIVEN_STRING_USING_CHARACTER_SEARCH": "def sortString ( str , n ) :\n    new_str = \"\"\n    for i in range ( ord ( 'a' ) , ord ( 'z' ) + 1 ) :\n        for j in range ( n ) :\n            if ( str [ j ] == chr ( i ) ) :\n                new_str += str [ j ]\n    return new_str\n", "COUNT_OF_OCCURRENCES_OF_A_101_PATTERN_IN_A_STRING": "def countPattern ( s ) :\n    length = len ( s )\n    oneSeen = False\n    count = 0\n    for i in range ( length ) :\n        if ( s [ i ] == '1' and oneSeen ) :\n            if ( s [ i - 1 ] == '0' ) :\n                count += 1\n        if ( s [ i ] == '1' and oneSeen == 0 ) :\n            oneSeen = True\n        if ( s [ i ] != '0' and s [ i ] != '1' ) :\n            oneSeen = False\n    return count\n", "C_PROGRAM_CYCLICALLY_ROTATE_ARRAY_ONE": "def rotate ( arr , n ) :\n    x = arr [ n - 1 ]\n    for i in range ( n - 1 , 0 , - 1 ) :\n        arr [ i ] = arr [ i - 1 ] ;\n    arr [ 0 ] = x ;\n", "QUEUE_BASED_APPROACH_FOR_FIRST_NON_REPEATING_CHARACTER_IN_A_STREAM": "def firstnonrepeating ( Str ) :\n    global MAX_CHAR\n    q = Queue ( )\n    charCount = [ 0 ] * MAX_CHAR\n    for i in range ( len ( Str ) ) :\n        q.put ( Str [ i ] )\n        charCount [ ord ( Str [ i ] ) - ord ( 'a' ) ] += 1\n        while ( not q.empty ( ) ) :\n            if ( charCount [ ord ( q.queue [ 0 ] ) - ord ( 'a' ) ] > 1 ) :\n                q.get ( )\n            else :\n                print ( q.queue [ 0 ] , end = \" \" )\n                break\n        if ( q.empty ( ) ) :\n            print ( - 1 , end = \" \" )\n    print ( )\n", "CHECK_LARGE_NUMBER_DIVISIBLE_6_NOT": "def check ( st ) :\n    n = len ( st )\n    if ( ( ( int ) ( st [ n - 1 ] ) % 2 ) != 0 ) :\n        return False\n    digitSum = 0\n    for i in range ( 0 , n ) :\n        digitSum = digitSum + ( int ) ( st [ i ] )\n    return ( digitSum % 3 == 0 )\n", "MINIMUM_NUMBER_OF_SQUARES_WHOSE_SUM_EQUALS_TO_GIVEN_NUMBER_N": "def getMinSquares ( n ) :\n    if n <= 3 :\n        return n ;\n    res = n\n    for x in range ( 1 , n + 1 ) :\n        temp = x * x ;\n        if temp > n :\n            break\n        else :\n            res = min ( res , 1 + getMinSquares ( n - temp ) )\n    return res ;\n", "OVERLAPPING_SUM_TWO_ARRAY": "def findSum ( A , B , n ) :\n    Hash = defaultdict ( lambda : 0 )\n    for i in range ( 0 , n ) :\n        Hash [ A [ i ] ] += 1\n        Hash [ B [ i ] ] += 1\n    Sum = 0\n    for x in Hash :\n        if Hash [ x ] == 1 :\n            Sum += x\n    return Sum\n", "MOBILE_NUMERIC_KEYPAD_PROBLEM": "def getCount ( keypad , n ) :\n    if ( not keypad or n <= 0 ) :\n        return 0\n    if ( n == 1 ) :\n        return 10\n    odd = [ 0 ] * 10\n    even = [ 0 ] * 10\n    i = 0\n    j = 0\n    useOdd = 0\n    totalCount = 0\n    for i in range ( 10 ) :\n        odd [ i ] = 1\n    for j in range ( 2 , n + 1 ) :\n        useOdd = 1 - useOdd\n        if ( useOdd == 1 ) :\n            even [ 0 ] = odd [ 0 ] + odd [ 8 ]\n            even [ 1 ] = odd [ 1 ] + odd [ 2 ] + odd [ 4 ]\n            even [ 2 ] = odd [ 2 ] + odd [ 1 ] + odd [ 3 ] + odd [ 5 ]\n            even [ 3 ] = odd [ 3 ] + odd [ 2 ] + odd [ 6 ]\n            even [ 4 ] = odd [ 4 ] + odd [ 1 ] + odd [ 5 ] + odd [ 7 ]\n            even [ 5 ] = odd [ 5 ] + odd [ 2 ] + odd [ 4 ] + odd [ 8 ] + odd [ 6 ]\n            even [ 6 ] = odd [ 6 ] + odd [ 3 ] + odd [ 5 ] + odd [ 9 ]\n            even [ 7 ] = odd [ 7 ] + odd [ 4 ] + odd [ 8 ]\n            even [ 8 ] = odd [ 8 ] + odd [ 0 ] + odd [ 5 ] + odd [ 7 ] + odd [ 9 ]\n            even [ 9 ] = odd [ 9 ] + odd [ 6 ] + odd [ 8 ]\n        else :\n            odd [ 0 ] = even [ 0 ] + even [ 8 ]\n            odd [ 1 ] = even [ 1 ] + even [ 2 ] + even [ 4 ]\n            odd [ 2 ] = even [ 2 ] + even [ 1 ] + even [ 3 ] + even [ 5 ]\n            odd [ 3 ] = even [ 3 ] + even [ 2 ] + even [ 6 ]\n            odd [ 4 ] = even [ 4 ] + even [ 1 ] + even [ 5 ] + even [ 7 ]\n            odd [ 5 ] = even [ 5 ] + even [ 2 ] + even [ 4 ] + even [ 8 ] + even [ 6 ]\n            odd [ 6 ] = even [ 6 ] + even [ 3 ] + even [ 5 ] + even [ 9 ]\n            odd [ 7 ] = even [ 7 ] + even [ 4 ] + even [ 8 ]\n            odd [ 8 ] = even [ 8 ] + even [ 0 ] + even [ 5 ] + even [ 7 ] + even [ 9 ]\n            odd [ 9 ] = even [ 9 ] + even [ 6 ] + even [ 8 ]\n    totalCount = 0\n    if ( useOdd == 1 ) :\n        for i in range ( 10 ) :\n            totalCount += even [ i ]\n    else :\n        for i in range ( 10 ) :\n            totalCount += odd [ i ]\n    return totalCount\n", "FIND_ELEMENTS_LARGER_HALF_ELEMENTS_ARRAY": "def findLarger ( arr , n ) :\n    x = sorted ( arr )\n    for i in range ( n / 2 , n ) :\n        print ( x [ i ] ) ,\n", "SUM_BINOMIAL_COEFFICIENTS": "def binomialCoeffSum ( n ) :\n    C = [ [ 0 ] * ( n + 2 ) for i in range ( 0 , n + 2 ) ]\n    for i in range ( 0 , n + 1 ) :\n        for j in range ( 0 , min ( i , n ) + 1 ) :\n            if ( j == 0 or j == i ) :\n                C [ i ] [ j ] = 1\n            else :\n                C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ]\n    sum = 0\n    for i in range ( 0 , n + 1 ) :\n        sum += C [ n ] [ i ]\n    return sum\n", "FIND_COMMON_ELEMENT_ROWS_ROW_WISE_SORTED_MATRIX_1": "def findCommon ( mat ) :\n    global M\n    global N\n    cnt = dict ( )\n    cnt = defaultdict ( lambda : 0 , cnt )\n    i = 0\n    j = 0\n    while ( i < M ) :\n        cnt [ mat [ i ] [ 0 ] ] = cnt [ mat [ i ] [ 0 ] ] + 1\n        j = 1\n        while ( j < N ) :\n            if ( mat [ i ] [ j ] != mat [ i ] [ j - 1 ] ) :\n                cnt [ mat [ i ] [ j ] ] = cnt [ mat [ i ] [ j ] ] + 1\n            j = j + 1\n        i = i + 1\n    for ele in cnt :\n        if ( cnt [ ele ] == M ) :\n            return ele\n    return - 1\n", "SIEVE_ERATOSTHENES_0N_TIME_COMPLEXITY": "def manipulated_seive ( N ) :\n    isprime [ 0 ] = isprime [ 1 ] = False\n    for i in range ( 2 , N ) :\n        if isprime [ i ] == True :\n            prime.append ( i )\n            SPF [ i ] = i\n        j = 0\n        while ( j < len ( prime ) and i * prime [ j ] < N and prime [ j ] <= SPF [ i ] ) :\n            isprime [ i * prime [ j ] ] = False\n            SPF [ i * prime [ j ] ] = prime [ j ]\n            j += 1\n", "COUNT_SORTED_ROWS_MATRIX": "def sortedCount ( mat , r , c ) :\n    result = 0\n    for i in range ( r ) :\n        j = 0\n        for j in range ( c - 1 ) :\n            if mat [ i ] [ j + 1 ] <= mat [ i ] [ j ] :\n                break\n        if j == c - 2 :\n            result += 1\n    for i in range ( 0 , r ) :\n        j = 0\n        for j in range ( c - 1 , 0 , - 1 ) :\n            if mat [ i ] [ j - 1 ] <= mat [ i ] [ j ] :\n                break\n        if c > 1 and j == 1 :\n            result += 1\n    return result\n", "NUMBER_WAYS_NODE_MAKE_LOOP_SIZE_K_UNDIRECTED_COMPLETE_CONNECTED_GRAPH_N_NODES": "def numOfways ( n , k ) :\n    p = 1\n    if ( k % 2 ) :\n        p = - 1\n    return ( pow ( n - 1 , k ) + p * ( n - 1 ) ) / n\n", "DICE_THROW_PROBLEM": "def findWays ( m , n , x ) :\n    table = [ [ 0 ] * ( x + 1 ) for i in range ( n + 1 ) ]\n    for j in range ( 1 , min ( m + 1 , x + 1 ) ) :\n        table [ 1 ] [ j ] = 1\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( 1 , x + 1 ) :\n            for k in range ( 1 , min ( m + 1 , j ) ) :\n                table [ i ] [ j ] += table [ i - 1 ] [ j - k ]\n    return table [ - 1 ] [ - 1 ]\n", "MINIMUM_NUMBER_DELETIONS_MAKE_STRING_PALINDROME_SET_2": "def getLevenstein ( inpt ) :\n    revInput = inpt [ : : - 1 ]\n    n = len ( inpt )\n    dp = [ [ - 1 for _ in range ( n + 1 ) ] for __ in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        dp [ 0 ] [ i ] = i\n        dp [ i ] [ 0 ] = i\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if inpt [ i - 1 ] == revInput [ j - 1 ] :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = 1 + min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] )\n    res = INT_MAX\n    i , j = n , 0\n    while i >= 0 :\n        res = min ( res , dp [ i ] [ j ] )\n        if i < n :\n            res = min ( res , dp [ i + 1 ] [ j ] )\n        if i > 0 :\n            res = min ( res , dp [ i - 1 ] [ j ] )\n        i -= 1\n        j += 1\n    return res\n", "DYNAMIC_PROGRAMMING_SET_37_BOOLEAN_PARENTHESIZATION_PROBLEM": "def countParenth ( symb , oper , n ) :\n    F = [ [ 0 for i in range ( n + 1 ) ] for i in range ( n + 1 ) ]\n    T = [ [ 0 for i in range ( n + 1 ) ] for i in range ( n + 1 ) ]\n    for i in range ( n ) :\n        if symb [ i ] == 'F' :\n            F [ i ] [ i ] = 1\n        else :\n            F [ i ] [ i ] = 0\n        if symb [ i ] == 'T' :\n            T [ i ] [ i ] = 1\n        else :\n            T [ i ] [ i ] = 0\n    for gap in range ( 1 , n ) :\n        i = 0\n        for j in range ( gap , n ) :\n            T [ i ] [ j ] = F [ i ] [ j ] = 0\n            for g in range ( gap ) :\n                k = i + g\n                tik = T [ i ] [ k ] + F [ i ] [ k ] ;\n                tkj = T [ k + 1 ] [ j ] + F [ k + 1 ] [ j ] ;\n                if oper [ k ] == '&' :\n                    T [ i ] [ j ] += T [ i ] [ k ] * T [ k + 1 ] [ j ]\n                    F [ i ] [ j ] += ( tik * tkj - T [ i ] [ k ] * T [ k + 1 ] [ j ] )\n                if oper [ k ] == '|' :\n                    F [ i ] [ j ] += F [ i ] [ k ] * F [ k + 1 ] [ j ]\n                    T [ i ] [ j ] += ( tik * tkj - F [ i ] [ k ] * F [ k + 1 ] [ j ] )\n                if oper [ k ] == '^' :\n                    T [ i ] [ j ] += ( F [ i ] [ k ] * T [ k + 1 ] [ j ] + T [ i ] [ k ] * F [ k + 1 ] [ j ] )\n                    F [ i ] [ j ] += ( T [ i ] [ k ] * T [ k + 1 ] [ j ] + F [ i ] [ k ] * F [ k + 1 ] [ j ] )\n            i += 1\n    return T [ 0 ] [ n - 1 ]\n", "PYTHON_PROGRAM_FIND_PERIMETER_CIRCUMFERENCE_SQUARE_RECTANGLE_1": "def Circumference ( l , w ) :\n    return ( 2 * ( l + w ) )\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS_1": "def thirdLargest ( arr , arr_size ) :\n    if ( arr_size < 3 ) :\n        print ( \" Invalid Input \" )\n        return\n    first = arr [ 0 ]\n    second = - sys.maxsize\n    third = - sys.maxsize\n    for i in range ( 1 , arr_size ) :\n        if ( arr [ i ] > first ) :\n            third = second\n            second = first\n            first = arr [ i ]\n        elif ( arr [ i ] > second ) :\n            third = second\n            second = arr [ i ]\n        elif ( arr [ i ] > third ) :\n            third = arr [ i ]\n    print ( \"The third Largest\" , \"element is\" , third )\n", "MINIMUM_ROOMS_FOR_M_EVENTS_OF_N_BATCHES_WITH_GIVEN_SCHEDULE": "def findMinRooms ( slots , n , m ) :\n    counts = [ 0 ] * m ;\n    for i in range ( n ) :\n        for j in range ( m ) :\n            if ( slots [ i ] [ j ] == '1' ) :\n                counts [ j ] += 1 ;\n    return max ( counts ) ;\n", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM": "def isSubsetSum ( set , n , sum ) :\n    if ( sum == 0 ) :\n        return True\n    if ( n == 0 and sum != 0 ) :\n        return False\n    if ( set [ n - 1 ] > sum ) :\n        return isSubsetSum ( set , n - 1 , sum ) ;\n    return isSubsetSum ( set , n - 1 , sum ) or isSubsetSum ( set , n - 1 , sum - set [ n - 1 ] )\n", "COUNT_WAYS_DIVIDE_CIRCLE_USING_N_NON_INTERSECTING_CHORDS": "def chordCnt ( A ) :\n    n = 2 * A\n    dpArray = [ 0 ] * ( n + 1 )\n    dpArray [ 0 ] = 1\n    dpArray [ 2 ] = 1\n    for i in range ( 4 , n + 1 , 2 ) :\n        for j in range ( 0 , i - 1 , 2 ) :\n            dpArray [ i ] += ( dpArray [ j ] * dpArray [ i - 2 - j ] )\n    return int ( dpArray [ n ] )\n", "BREAK_NUMBER_THREE_PARTS_1": "def count_of_ways ( n ) :\n    count = 0\n    count = ( n + 1 ) * ( n + 2 ) // 2\n    return count\n", "PRINT_DIGITS_POSITION_REMOVED_MAKE_NUMBER_DIVISIBLE_6": "def greatest ( s ) :\n    n = len ( s )\n    a = [ 0 for i in range ( n ) ]\n    Sum = 0\n    for i in range ( n ) :\n        a [ i ] = ord ( s [ i ] ) - ord ( '0' )\n        Sum += a [ i ]\n    if ( a [ n - 1 ] % 2 ) :\n        if ( a [ n - 2 ] % 2 != 0 or ( Sum - a [ n - 1 ] ) % 3 != 0 ) :\n            print ( \"-1\" )\n        else :\n            print ( n )\n    else :\n        re = Sum % 3\n        dell = - 1\n        flag = 0\n        for i in range ( n - 1 ) :\n            if ( ( a [ i ] ) % 3 == re ) :\n                if ( a [ i + 1 ] > a [ i ] ) :\n                    dell = i\n                    flag = 1\n                    break\n                else :\n                    dell = i\n        if ( flag == 0 ) :\n            if ( a [ n - 2 ] % 2 == 0 and re == a [ n - 1 ] % 3 ) :\n                dell = n - 1\n        if ( dell == - 1 ) :\n            print ( \"-1\" )\n        else :\n            print ( dell + 1 )\n", "MAXIMUM_HEIGHT_OF_TRIANGULAR_ARRANGEMENT_OF_ARRAY_VALUES": "def MaximumHeight ( a , n ) :\n    result = 1\n    for i in range ( 1 , n ) :\n        y = ( i * ( i + 1 ) ) / 2\n        if ( y < n ) :\n            result = i\n        else :\n            break\n    return result\n", "SQUARED_TRIANGULAR_NUMBER_SUM_CUBES": "def findS ( s ) :\n    _sum = 0\n    n = 1\n    while ( _sum < s ) :\n        _sum += n * n * n\n        n += 1\n    n -= 1\n    if _sum == s :\n        return n\n    return - 1\n", "EVALUATE_A_BOOLEAN_EXPRESSION_REPRESENTED_AS_STRING": "def evaluateBoolExpr ( s ) :\n    n = len ( s )\n    for i in range ( 0 , n - 2 , 2 ) :\n        if ( s [ i + 1 ] == \"A\" ) :\n            if ( s [ i + 2 ] == \"0\" or s [ i ] == \"0\" ) :\n                s [ i + 2 ] = \"0\"\n            else :\n                s [ i + 2 ] = \"1\"\n        elif ( s [ i + 1 ] == \"B\" ) :\n            if ( s [ i + 2 ] == \"1\" or s [ i ] == \"1\" ) :\n                s [ i + 2 ] = \"1\"\n            else :\n                s [ i + 2 ] = \"0\"\n        else :\n            if ( s [ i + 2 ] == s [ i ] ) :\n                s [ i + 2 ] = \"0\"\n            else :\n                s [ i + 2 ] = \"1\"\n    return ord ( s [ n - 1 ] ) - ord ( \"0\" )\n", "PROGRAMMING_PUZZLE_ASSIGN_VALUE_WITHOUT_CONTROL_STATEMENT": "def assignValue ( a , b , x ) :\n    arr = [ a , b ]\n    return ( arr [ x ] )\n", "MINIMUM_SUM_SQUARES_CHARACTERS_COUNTS_GIVEN_STRING_REMOVING_K_CHARACTERS": "def minStringValue ( str , k ) :\n    l = len ( str )\n    if ( k >= l ) :\n        return 0\n    frequency = [ 0 ] * MAX_CHAR\n    for i in range ( 0 , l ) :\n        frequency [ ord ( str [ i ] ) - 97 ] += 1\n    q = PriorityQueue ( )\n    for i in range ( 0 , MAX_CHAR ) :\n        q.put ( - frequency [ i ] )\n    while ( k > 0 ) :\n        temp = q.get ( )\n        temp = temp + 1\n        q.put ( temp , temp )\n        k = k - 1\n    result = 0 ;\n    while not q.empty ( ) :\n        temp = q.get ( )\n        temp = temp * ( - 1 )\n        result += temp * temp\n    return result\n", "MAJORITY_ELEMENT_1": "def findMajority ( arr , size ) :\n    m = { }\n    for i in range ( size ) :\n        if arr [ i ] in m :\n            m [ arr [ i ] ] += 1\n        else :\n            m [ arr [ i ] ] = 1\n    count = 0\n    for key in m :\n        if m [ key ] > size / 2 :\n            count = 1\n            print ( \"Majority found :-\" , key )\n            break\n    if ( count == 0 ) :\n        print ( \"No Majority element\" )\n", "LARGEST_SUBSET_GRAPH_VERTICES_EDGES_2_COLORS": "def subsetGraph ( C ) :\n    global N\n    vertices = set ( )\n    for i in range ( N ) :\n        vertices.add ( i )\n    while ( len ( vertices ) != 0 ) :\n        if ( len ( vertices ) == 1 ) :\n            return 1\n        someone_removed = False\n        for x in vertices :\n            values = set ( )\n            for y in vertices :\n                if ( y != x ) :\n                    values.add ( C [ x ] [ y ] )\n            if ( len ( values ) == 1 ) :\n                vertices.remove ( x )\n                someone_removed = True\n                break\n        if ( not someone_removed ) :\n            break\n    return len ( vertices )\n", "FLOOR_IN_A_SORTED_ARRAY_1": "def floorSearch ( arr , low , high , x ) :\n    if ( low > high ) :\n        return - 1\n    if ( x >= arr [ high ] ) :\n        return high\n    mid = int ( ( low + high ) / 2 )\n    if ( arr [ mid ] == x ) :\n        return mid\n    if ( mid > 0 and arr [ mid - 1 ] <= x and x < arr [ mid ] ) :\n        return mid - 1\n    if ( x < arr [ mid ] ) :\n        return floorSearch ( arr , low , mid - 1 , x )\n    return floorSearch ( arr , mid + 1 , high , x )\n", "LONGEST_PREFIX_ALSO_SUFFIX_1": "def longestPrefixSuffix ( s ) :\n    n = len ( s )\n    lps = [ 0 ] * n\n    l = 0\n    i = 1\n    while ( i < n ) :\n        if ( s [ i ] == s [ l ] ) :\n            l = l + 1\n            lps [ i ] = l\n            i = i + 1\n        else :\n            if ( l != 0 ) :\n                l = lps [ l - 1 ]\n            else :\n                lps [ i ] = 0\n                i = i + 1\n    res = lps [ n - 1 ]\n    if ( res > n / 2 ) :\n        return n // 2\n    else :\n        return res\n", "COUNT_NUMBER_OF_WAYS_TO_PARTITION_A_SET_INTO_K_SUBSETS": "def countP ( n , k ) :\n    if ( n == 0 or k == 0 or k > n ) :\n        return 0\n    if ( k == 1 or k == n ) :\n        return 1\n    return ( k * countP ( n - 1 , k ) + countP ( n - 1 , k - 1 ) )\n", "C_PROGRAM_FACTORIAL_NUMBER_2": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 )\n", "FIND_REPEATED_CHARACTER_PRESENT_FIRST_STRING_1": "def findRepeatFirst ( s ) :\n    p = - 1\n    hash = [ 0 for i in range ( MAX_CHAR ) ]\n    pos = [ 0 for i in range ( MAX_CHAR ) ]\n    for i in range ( len ( s ) ) :\n        k = ord ( s [ i ] )\n        if ( hash [ k ] == 0 ) :\n            hash [ k ] += 1\n            pos [ k ] = i\n        elif ( hash [ k ] == 1 ) :\n            hash [ k ] += 1\n    for i in range ( MAX_CHAR ) :\n        if ( hash [ i ] == 2 ) :\n            if ( p == - 1 ) :\n                p = pos [ i ]\n            elif ( p > pos [ i ] ) :\n                p = pos [ i ]\n    return p\n", "NUMBER_OF_PERMUTATION_WITH_K_INVERSIONS": "def numberOfPermWithKInversion ( N , K ) :\n    if ( N == 0 ) : return 0\n    if ( K == 0 ) : return 1\n    if ( memo [ N ] [ K ] != 0 ) :\n        return memo [ N ] [ K ]\n    sum = 0\n    for i in range ( K + 1 ) :\n        if ( i <= N - 1 ) :\n            sum += numberOfPermWithKInversion ( N - 1 , K - i )\n    memo [ N ] [ K ] = sum\n    return sum\n", "K_TH_LARGEST_SUM_CONTIGUOUS_SUBARRAY": "def kthLargestSum ( arr , n , k ) :\n    sum = [ ]\n    sum.append ( 0 )\n    sum.append ( arr [ 0 ] )\n    for i in range ( 2 , n + 1 ) :\n        sum.append ( sum [ i - 1 ] + arr [ i - 1 ] )\n    Q = [ ]\n    heapq.heapify ( Q )\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( i , n + 1 ) :\n            x = sum [ j ] - sum [ i - 1 ]\n            if len ( Q ) < k :\n                heapq.heappush ( Q , x )\n            else :\n                if Q [ 0 ] < x :\n                    heapq.heappop ( Q )\n                    heapq.heappush ( Q , x )\n    return Q [ 0 ]\n", "FIND_THE_LARGEST_THREE_ELEMENTS_IN_AN_ARRAY": "def find3largest ( arr , n ) :\n    arr = sorted ( arr )\n    check = 0\n    count = 1\n    for i in range ( 1 , n + 1 ) :\n        if ( count < 4 ) :\n            if ( check != arr [ n - i ] ) :\n                print ( arr [ n - i ] , end = \" \" )\n                check = arr [ n - i ]\n                count += 1\n        else :\n            break\n", "MAXIMUM_DISTINCT_LOWERCASE_ALPHABETS_TWO_UPPERCASE": "def maxLower ( str ) :\n    n = len ( str )\n    i = 0\n    for i in range ( n ) :\n        if str [ i ] >= 'A' and str [ i ] <= 'Z' :\n            i += 1\n            break\n    maxCount = 0\n    count = [ ]\n    for j in range ( MAX_CHAR ) :\n        count.append ( 0 )\n    for j in range ( i , n ) :\n        if str [ j ] >= 'A' and str [ j ] <= 'Z' :\n            currCount = 0\n            for k in range ( MAX_CHAR ) :\n                if count [ k ] > 0 :\n                    currCount += 1\n            maxCount = max ( maxCount , currCount )\n            for y in count :\n                y = 0\n        if str [ j ] >= 'a' and str [ j ] <= 'z' :\n            count [ ord ( str [ j ] ) - ord ( 'a' ) ] += 1\n    return maxCount\n", "CHECK_IF_A_STRING_HAS_ALL_CHARACTERS_WITH_SAME_FREQUENCY_WITH_ONE_VARIATION_ALLOWED": "def isValidString ( str ) :\n    freq = [ 0 ] * CHARS\n    for i in range ( len ( str ) ) :\n        freq [ ord ( str [ i ] ) - ord ( 'a' ) ] += 1\n    freq1 = 0\n    count_freq1 = 0\n    for i in range ( CHARS ) :\n        if ( freq [ i ] != 0 ) :\n            freq1 = freq [ i ]\n            count_freq1 = 1\n            break\n    freq2 = 0\n    count_freq2 = 0\n    for j in range ( i + 1 , CHARS ) :\n        if ( freq [ j ] != 0 ) :\n            if ( freq [ j ] == freq1 ) :\n                count_freq1 += 1\n            else :\n                count_freq2 = 1\n                freq2 = freq [ j ]\n                break\n    for k in range ( j + 1 , CHARS ) :\n        if ( freq [ k ] != 0 ) :\n            if ( freq [ k ] == freq1 ) :\n                count_freq1 += 1\n            if ( freq [ k ] == freq2 ) :\n                count_freq2 += 1\n            else :\n                return False\n        if ( count_freq1 > 1 and count_freq2 > 1 ) :\n            return False\n    return True\n", "MAXIMUM_AVERAGE_SUM_PARTITION_ARRAY": "def largestSumOfAverages ( A , K ) :\n    n = len ( A ) ;\n    pre_sum = [ 0 ] * ( n + 1 ) ;\n    pre_sum [ 0 ] = 0 ;\n    for i in range ( n ) :\n        pre_sum [ i + 1 ] = pre_sum [ i ] + A [ i ] ;\n    dp = [ 0 ] * n ;\n    sum = 0 ;\n    for i in range ( n ) :\n        dp [ i ] = ( pre_sum [ n ] - pre_sum [ i ] ) / ( n - i ) ;\n    for k in range ( K - 1 ) :\n        for i in range ( n ) :\n            for j in range ( i + 1 , n ) :\n                dp [ i ] = max ( dp [ i ] , ( pre_sum [ j ] - pre_sum [ i ] ) / ( j - i ) + dp [ j ] ) ;\n    return int ( dp [ 0 ] ) ;\n", "FIND_SUBARRAY_WITH_GIVEN_SUM_IN_ARRAY_OF_INTEGERS": "def subArraySum ( arr , n , Sum ) :\n    Map = { }\n    curr_sum = 0\n    for i in range ( 0 , n ) :\n        curr_sum = curr_sum + arr [ i ]\n        if curr_sum == Sum :\n            print ( \"Sum found between indexes 0 to\" , i )\n            return\n        if ( curr_sum - Sum ) in Map :\n            print ( \"Sum found between indexes\" , \\ Map [ curr_sum - Sum ] + 1 , \"to\" , i )\n            return\n        Map [ curr_sum ] = i\n    print ( \"No subarray with given sum exists\" )\n", "REMOVE_MINIMUM_ELEMENTS_EITHER_SIDE_2MIN_MAX": "def minRemovalsDP ( arr , n ) :\n    longest_start = - 1 ;\n    longest_end = 0 ;\n    for start in range ( n ) :\n        min = sys.maxsize ;\n        max = - sys.maxsize ;\n        for end in range ( start , n ) :\n            val = arr [ end ] ;\n            if ( val < min ) :\n                min = val ;\n            if ( val > max ) :\n                max = val ;\n            if ( 2 * min <= max ) :\n                break ;\n            if ( end - start > longest_end - longest_start or longest_start == - 1 ) :\n                longest_start = start ;\n                longest_end = end ;\n    if ( longest_start == - 1 ) :\n        return n ;\n    return ( n - ( longest_end - longest_start + 1 ) ) ;\n", "FIND_THE_MISSING_NUMBER_1": "def getMissingNo ( a , n ) :\n    i , total = 0 , 1\n    for i in range ( 2 , n + 2 ) :\n        total += i\n        total -= a [ i - 2 ]\n    return total\n", "SIEVE_SUNDARAM_PRINT_PRIMES_SMALLER_N": "def SieveOfSundaram ( n ) :\n    nNew = int ( ( n - 2 ) / 2 ) ;\n    marked = [ 0 ] * ( nNew + 1 ) ;\n    for i in range ( 1 , nNew + 1 ) :\n        j = i ;\n        while ( ( i + j + 2 * i * j ) <= nNew ) :\n            marked [ i + j + 2 * i * j ] = 1 ;\n            j += 1 ;\n    if ( n > 2 ) :\n        print ( 2 , end = \" \" ) ;\n    for i in range ( 1 , nNew + 1 ) :\n        if ( marked [ i ] == 0 ) :\n            print ( ( 2 * i + 1 ) , end = \" \" ) ;\n", "MAXIMUM_PRODUCT_SUBSET_ARRAY": "def maxProductSubset ( a , n ) :\n    if n == 1 :\n        return a [ 0 ]\n    max_neg = - 999999999999\n    count_neg = 0\n    count_zero = 0\n    prod = 1\n    for i in range ( n ) :\n        if a [ i ] == 0 :\n            count_zero += 1\n            continue\n        if a [ i ] < 0 :\n            count_neg += 1\n            max_neg = max ( max_neg , a [ i ] )\n        prod = prod * a [ i ]\n    if count_zero == n :\n        return 0\n    if count_neg & 1 :\n        if ( count_neg == 1 and count_zero > 0 and count_zero + count_neg == n ) :\n            return 0\n        prod = int ( prod / max_neg )\n    return prod\n", "FIND_THE_NEAREST_SMALLER_NUMBERS_ON_LEFT_SIDE_IN_AN_ARRAY": "def printPrevSmaller ( arr , n ) :\n    print ( \"_, \" , end = \"\" )\n    for i in range ( 1 , n ) :\n        for j in range ( i - 1 , - 2 , - 1 ) :\n            if ( arr [ j ] < arr [ i ] ) :\n                print ( arr [ j ] , \", \" , end = \"\" )\n                break\n        if ( j == - 1 ) :\n            print ( \"_, \" , end = \"\" )\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0_1": "def calculate ( a ) :\n    maximum = max ( a )\n    frequency = [ 0 for x in range ( maximum + 1 ) ]\n    for i in a :\n        frequency [ i ] += 1\n    answer = 0\n    for i in frequency :\n        answer = answer + i * ( i - 1 ) // 2\n    return answer\n", "SUM_BINOMIAL_COEFFICIENTS_1": "def binomialCoeffSum ( n ) :\n    return ( 1 << n ) ;\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE_1": "def maxSumPairWithDifferenceLessThanK ( arr , N , k ) :\n    maxSum = 0 ;\n    arr.sort ( ) ;\n    i = N - 1 ;\n    while ( i >= 0 ) :\n        if ( arr [ i ] - arr [ i - 1 ] < k ) :\n            maxSum += arr [ i ] ;\n            maxSum += arr [ i - 1 ] ;\n            i -= 1 ;\n        i -= 1 ;\n    return maxSum ;\n", "KTH_ADJACENT_NODE_GRAPH_VERTEX_WEIGHT": "def printkthnode ( adj , wt , n , k ) :\n    for i in range ( n ) :\n        adj [ i ].sort ( )\n    for i in range ( n ) :\n        if ( len ( adj [ i ] ) >= k ) :\n            print ( adj [ i ] [ len ( adj [ i ] ) - k ] [ 1 ] , end = \" \" )\n        else :\n            print ( \"-1\" , end = \" \" )\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM": "def KnapSack ( val , wt , n , W ) :\n    mat = [ [ 0 for i in range ( W + 1 ) ] for i in range ( 2 ) ]\n    i = 0\n    while i < n :\n        j = 0\n        if i % 2 == 0 :\n            while j < W :\n                j += 1\n                if wt [ i ] <= j :\n                    mat [ 1 ] [ j ] = max ( val [ i ] + mat [ 0 ] [ j - wt [ i ] ] , mat [ 0 ] [ j ] )\n                else :\n                    mat [ 1 ] [ j ] = mat [ 0 ] [ j ]\n        else :\n            while j < W :\n                j += 1\n                if wt [ i ] <= j :\n                    mat [ 0 ] [ j ] = max ( val [ i ] + mat [ 1 ] [ j - wt [ i ] ] , mat [ 1 ] [ j ] )\n                else :\n                    mat [ 0 ] [ j ] = mat [ 1 ] [ j ]\n        i += 1\n    if n % 2 == 0 :\n        return mat [ 0 ] [ W ]\n    else :\n        return mat [ 1 ] [ W ]\n", "BINARY_REPRESENTATION_OF_A_GIVEN_NUMBER_1": "def bin ( n ) :\n    if ( n > 1 ) :\n        bin ( n >> 1 )\n    print ( n & 1 , end = \"\" )\n", "PRIME_FACTORS_BIG_NUMBER": "def factorize ( n ) :\n    count = 0 ;\n    while ( ( n % 2 > 0 ) == False ) :\n        n >>= 1 ;\n        count += 1 ;\n    if ( count > 0 ) :\n        print ( 2 , count ) ;\n    for i in range ( 3 , int ( math.sqrt ( n ) ) + 1 ) :\n        count = 0 ;\n        while ( n % i == 0 ) :\n            count += 1 ;\n            n = int ( n / i ) ;\n        if ( count > 0 ) :\n            print ( i , count ) ;\n        i += 2 ;\n    if ( n > 2 ) :\n        print ( n , 1 ) ;\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS_1": "def countSubstringWithEqualEnds ( s ) :\n    result = 0 ;\n    n = len ( s ) ;\n    count = [ 0 ] * MAX_CHAR ;\n    for i in range ( n ) :\n        count [ ord ( s [ i ] ) - ord ( 'a' ) ] += 1 ;\n    for i in range ( MAX_CHAR ) :\n        result += ( count [ i ] * ( count [ i ] + 1 ) / 2 ) ;\n    return result ;\n", "LONGEST_PALINDROME_SUBSTRING_SET_1": "def printSubStr ( st , low , high ) :\n    sys.stdout.write ( st [ low : high + 1 ] )\n    sys.stdout.flush ( )\n    return ''\n", "FIND_THE_SMALLEST_WINDOW_IN_A_STRING_CONTAINING_ALL_CHARACTERS_OF_ANOTHER_STRING": "def findSubString ( string , pat ) :\n    len1 = len ( string )\n    len2 = len ( pat )\n    if len1 < len2 :\n        print ( \"No such window exists\" )\n        return \"\"\n    hash_pat = [ 0 ] * no_of_chars\n    hash_str = [ 0 ] * no_of_chars\n    for i in range ( 0 , len2 ) :\n        hash_pat [ ord ( pat [ i ] ) ] += 1\n    start , start_index , min_len = 0 , - 1 , float ( 'inf' )\n    count = 0\n    for j in range ( 0 , len1 ) :\n        hash_str [ ord ( string [ j ] ) ] += 1\n        if ( hash_pat [ ord ( string [ j ] ) ] != 0 and hash_str [ ord ( string [ j ] ) ] <= hash_pat [ ord ( string [ j ] ) ] ) :\n            count += 1\n        if count == len2 :\n            while ( hash_str [ ord ( string [ start ] ) ] > hash_pat [ ord ( string [ start ] ) ] or hash_pat [ ord ( string [ start ] ) ] == 0 ) :\n                if ( hash_str [ ord ( string [ start ] ) ] > hash_pat [ ord ( string [ start ] ) ] ) :\n                    hash_str [ ord ( string [ start ] ) ] -= 1\n                start += 1\n            len_window = j - start + 1\n            if min_len > len_window :\n                min_len = len_window\n                start_index = start\n    if start_index == - 1 :\n        print ( \"No such window exists\" )\n        return \"\"\n    return string [ start_index : start_index + min_len ]\n", "MARKOV_MATRIX": "def checkMarkov ( m ) :\n    for i in range ( 0 , len ( m ) ) :\n        sm = 0\n        for j in range ( 0 , len ( m [ i ] ) ) :\n            sm = sm + m [ i ] [ j ]\n        if ( sm != 1 ) :\n            return False\n    return True\n", "LEAF_NODES_PREORDER_BINARY_SEARCH_TREE": "def leafNode ( preorder , n ) :\n    s = [ ]\n    i = 0\n    for j in range ( 1 , n ) :\n        found = False\n        if preorder [ i ] > preorder [ j ] :\n            s.append ( preorder [ i ] )\n        else :\n            while len ( s ) != 0 :\n                if preorder [ j ] > s [ - 1 ] :\n                    s.pop ( - 1 )\n                    found = True\n                else :\n                    break\n        if found :\n            print ( preorder [ i ] , end = \" \" )\n        i += 1\n    print ( preorder [ n - 1 ] )\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N": "def nextPowerOf2 ( n ) :\n    count = 0 ;\n    if ( n and not ( n & ( n - 1 ) ) ) :\n        return n\n    while ( n != 0 ) :\n        n >>= 1\n        count += 1\n    return 1 << count ;\n", "PROGRAM_CHECK_WATER_TANK_OVERFLOWS_N_SOLID_BALLS_DIPPED_WATER_TANK": "def overflow ( H , r , h , N , R ) :\n    tank_cap = 3.14 * r * r * H\n    water_vol = 3.14 * r * r * h\n    balls_vol = N * ( 4 / 3 ) * 3.14 * R * R * R\n    vol = water_vol + balls_vol\n    if vol > tank_cap :\n        print ( \"Overflow\" )\n    else :\n        print ( \"Not in overflow state\" )\n", "SMALLEST_DERANGEMENT_SEQUENCE": "def generate_derangement ( N ) :\n    S = [ 0 ] * ( N + 1 )\n    for i in range ( 1 , N + 1 ) :\n        S [ i ] = i\n    D = [ 0 ] * ( N + 1 )\n    for i in range ( 1 , N + 1 , 2 ) :\n        if i == N :\n            D [ N ] = S [ N - 1 ]\n            D [ N - 1 ] = S [ N ]\n        else :\n            D [ i ] = i + 1\n            D [ i + 1 ] = i\n    for i in range ( 1 , N + 1 ) :\n        print ( D [ i ] , end = \" \" )\n    print ( )\n", "MAXIMUM_PRODUCT_INCREASING_SUBSEQUENCE": "def lis ( arr , n ) :\n    mpis = [ 0 ] * ( n )\n    for i in range ( n ) :\n        mpis [ i ] = arr [ i ]\n    for i in range ( 1 , n ) :\n        for j in range ( i ) :\n            if ( arr [ i ] > arr [ j ] and mpis [ i ] < ( mpis [ j ] * arr [ i ] ) ) :\n                mpis [ i ] = mpis [ j ] * arr [ i ]\n    return max ( mpis )\n", "CHANGE_BITS_CAN_MADE_ONE_FLIP": "def canMakeAllSame ( str ) :\n    zeros = 0\n    ones = 0\n    for i in range ( 0 , len ( str ) ) :\n        ch = str [ i ] ;\n        if ( ch == '0' ) :\n            zeros = zeros + 1\n        else :\n            ones = ones + 1\n    return ( zeros == 1 or ones == 1 ) ;\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0": "def calculate ( a ) :\n    a.sort ( )\n    count = 1\n    answer = 0\n    for i in range ( 1 , len ( a ) ) :\n        if a [ i ] == a [ i - 1 ] :\n            count += 1\n        else :\n            answer = answer + count * ( count - 1 ) // 2\n            count = 1\n    answer = answer + count * ( count - 1 ) // 2\n    return answer\n", "FIND_ROOT_TREE_CHILDREN_ID_SUM_EVERY_NODE_GIVEN": "def findRoot ( arr , n ) :\n    root = 0\n    for i in range ( n ) :\n        root += ( arr [ i ] [ 0 ] - arr [ i ] [ 1 ] )\n    return root\n", "BINARY_SEARCH": "def binarySearch ( arr , l , r , x ) :\n    if r >= l :\n        mid = l + ( r - l ) // 2\n        if arr [ mid ] == x :\n            return mid\n        elif arr [ mid ] > x :\n            return binarySearch ( arr , l , mid - 1 , x )\n        else :\n            return binarySearch ( arr , mid + 1 , r , x )\n    else :\n        return - 1\n", "FIBONACCI_MODULO_P": "def findMinZero ( p ) :\n    first = 1\n    second = 1\n    number = 2\n    next = 1\n    while ( next ) :\n        next = ( first + second ) % p\n        first = second\n        second = next\n        number = number + 1\n    return number\n", "K_LARGESTOR_SMALLEST_ELEMENTS_IN_AN_ARRAY": "def kLargest ( arr , k ) :\n    arr.sort ( reverse = True )\n    for i in range ( k ) :\n        print ( arr [ i ] , end = \" \" )\n", "C_PROGRAM_FIND_AREA_CIRCLE": "def findArea ( r ) :\n    PI = 3.142\n    return PI * ( r * r ) ;\n", "SUM_TWO_LARGE_NUMBERS": "def findSum ( str1 , str2 ) :\n    if ( len ( str1 ) > len ( str2 ) ) :\n        t = str1 ;\n        str1 = str2 ;\n        str2 = t ;\n    str = \"\" ;\n    n1 = len ( str1 ) ;\n    n2 = len ( str2 ) ;\n    str1 = str1 [ : : - 1 ] ;\n    str2 = str2 [ : : - 1 ] ;\n    carry = 0 ;\n    for i in range ( n1 ) :\n        sum = ( ( ord ( str1 [ i ] ) - 48 ) + ( ( ord ( str2 [ i ] ) - 48 ) + carry ) ) ;\n        str += chr ( sum % 10 + 48 ) ;\n        carry = int ( sum / 10 ) ;\n    for i in range ( n1 , n2 ) :\n        sum = ( ( ord ( str2 [ i ] ) - 48 ) + carry ) ;\n        str += chr ( sum % 10 + 48 ) ;\n        carry = ( int ) ( sum / 10 ) ;\n    if ( carry ) :\n        str += chr ( carry + 48 ) ;\n    str = str [ : : - 1 ] ;\n    return str ;\n", "ARRAY_RANGE_QUERIES_ELEMENTS_FREQUENCY_VALUE": "def solveQuery ( start , end , arr ) :\n    frequency = dict ( )\n    for i in range ( start , end + 1 ) :\n        if arr [ i ] in frequency.keys ( ) :\n            frequency [ arr [ i ] ] += 1\n        else :\n            frequency [ arr [ i ] ] = 1\n    count = 0\n    for x in frequency :\n        if x == frequency [ x ] :\n            count += 1\n    return count\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS": "def countSubstringWithEqualEnds ( s ) :\n    result = 0 ;\n    n = len ( s ) ;\n    for i in range ( n ) :\n        for j in range ( i , n ) :\n            if ( s [ i ] == s [ j ] ) :\n                result = result + 1\n    return result\n", "DYNAMIC_PROGRAMMING_HIGH_EFFORT_VS_LOW_EFFORT_TASKS_PROBLEM": "def maxTasks ( high , low , n ) :\n    if ( n <= 0 ) :\n        return 0\n    return max ( high [ n - 1 ] + maxTasks ( high , low , ( n - 2 ) ) , low [ n - 1 ] + maxTasks ( high , low , ( n - 1 ) ) ) ;\n", "MAXIMUM_DIFFERENCE_SUM_ELEMENTS_TWO_ROWS_MATRIX": "def maxRowDiff ( mat , m , n ) :\n    rowSum = [ 0 ] * m\n    for i in range ( 0 , m ) :\n        sum = 0\n        for j in range ( 0 , n ) :\n            sum += mat [ i ] [ j ]\n        rowSum [ i ] = sum\n    max_diff = rowSum [ 1 ] - rowSum [ 0 ]\n    min_element = rowSum [ 0 ]\n    for i in range ( 1 , m ) :\n        if ( rowSum [ i ] - min_element > max_diff ) :\n            max_diff = rowSum [ i ] - min_element\n        if ( rowSum [ i ] < min_element ) :\n            min_element = rowSum [ i ]\n    return max_diff\n", "PAPER_CUT_MINIMUM_NUMBER_SQUARES": "def minimumSquare ( a , b ) :\n    result = 0\n    rem = 0\n    if ( a < b ) :\n        a , b = b , a\n    while ( b > 0 ) :\n        result += int ( a / b )\n        rem = int ( a % b )\n        a = b\n        b = rem\n    return result\n", "SEARCH_AN_ELEMENT_IN_AN_ARRAY_WHERE_DIFFERENCE_BETWEEN_ADJACENT_ELEMENTS_IS_1": "def search ( arr , n , x ) :\n    i = 0\n    while ( i < n ) :\n        if ( arr [ i ] == x ) :\n            return i\n        i = i + abs ( arr [ i ] - x )\n    print ( \"number is not present!\" )\n    return - 1\n", "PANGRAM_CHECKING": "def checkPangram ( s ) :\n    List = [ ]\n    for i in range ( 26 ) :\n        List.append ( False )\n    for c in s.lower ( ) :\n        if not c == \" \" :\n            List [ ord ( c ) - ord ( 'a' ) ] = True\n    for ch in List :\n        if ch == False :\n            return False\n    return True\n", "PRINT_SHORTEST_COMMON_SUPERSEQUENCE": "def printShortestSuperSeq ( x , y ) :\n    m = len ( x )\n    n = len ( y )\n    dp = [ [ 0 for i in range ( n + 1 ) ] for j in range ( n + 1 ) ]\n    for i in range ( m + 1 ) :\n        for j in range ( n + 1 ) :\n            if i == 0 :\n                dp [ i ] [ j ] = j\n            elif j == 0 :\n                dp [ i ] [ j ] = i\n            elif x [ i - 1 ] == y [ j - 1 ] :\n                dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ]\n            else :\n                dp [ i ] [ j ] = 1 + min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] )\n    index = dp [ m ] [ n ]\n    string = \"\"\n    i = m\n    j = n\n    while i > 0 and j > 0 :\n        if x [ i - 1 ] == y [ j - 1 ] :\n            string += x [ i - 1 ]\n            i -= 1\n            j -= 1\n            index -= 1\n        elif dp [ i - 1 ] [ j ] > dp [ i ] [ j - 1 ] :\n            string += y [ j - 1 ]\n            j -= 1\n            index -= 1\n        else :\n            string += x [ i - 1 ]\n            i -= 1\n            index -= 1\n    while i > 0 :\n        string += x [ i - 1 ]\n        i -= 1\n        index -= 1\n    while j > 0 :\n        string += y [ j - 1 ]\n        j -= 1\n        index -= 1\n    string = list ( string )\n    string.reverse ( )\n    return ''.join ( string )\n", "FIND_PAIR_MAXIMUM_GCD_ARRAY_1": "def findMaxGCD ( arr , n ) :\n    high = 0\n    for i in range ( 0 , n ) :\n        high = max ( high , arr [ i ] )\n    count = [ 0 ] * ( high + 1 )\n    for i in range ( 0 , n ) :\n        count [ arr [ i ] ] += 1\n    counter = 0\n    for i in range ( high , 0 , - 1 ) :\n        j = i\n        while ( j <= high ) :\n            if ( count [ j ] > 0 ) :\n                counter += count [ j ]\n            j += i\n            if ( counter == 2 ) :\n                return i\n        counter = 0\n", "PROGRAM_CALCULATE_AREA_OCTAGON": "def areaOctagon ( side ) :\n    return ( 2 * ( 1 + ( math.sqrt ( 2 ) ) ) * side * side )\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY_1": "def findExtra ( arr1 , arr2 , n ) :\n    index = n\n    left = 0\n    right = n - 1\n    while ( left <= right ) :\n        mid = ( int ) ( ( left + right ) / 2 )\n        if ( arr2 [ mid ] == arr1 [ mid ] ) :\n            left = mid + 1\n        else :\n            index = mid\n            right = mid - 1\n    return index\n", "NOBLE_INTEGERS_IN_AN_ARRAY_COUNT_OF_GREATER_ELEMENTS_IS_EQUAL_TO_VALUE_1": "def nobleInteger ( arr ) :\n    arr.sort ( )\n    n = len ( arr )\n    for i in range ( n - 1 ) :\n        if arr [ i ] == arr [ i + 1 ] :\n            continue\n        if arr [ i ] == n - i - 1 :\n            return arr [ i ]\n    if arr [ n - 1 ] == 0 :\n        return arr [ n - 1 ]\n    return - 1\n", "MAXIMUM_NUMBER_OF_SQUARES_THAT_CAN_BE_FIT_IN_A_RIGHT_ANGLE_ISOSCELES_TRIANGLE": "def maxSquare ( b , m ) :\n    return ( b / m - 1 ) * ( b / m ) / 2\n", "HOW_TO_COMPUTE_MOD_OF_A_BIG_NUMBER": "def mod ( num , a ) :\n    res = 0\n    for i in range ( 0 , len ( num ) ) :\n        res = ( res * 10 + int ( num [ i ] ) ) % a ;\n    return res\n", "LONGEST_COMMON_SUBSTRING_1": "def lcs ( i , j , count ) :\n    if ( i == 0 or j == 0 ) :\n        return count\n    if ( X [ i - 1 ] == Y [ j - 1 ] ) :\n        count = lcs ( i - 1 , j - 1 , count + 1 )\n    count = max ( count , max ( lcs ( i , j - 1 , 0 ) , lcs ( i - 1 , j , 0 ) ) )\n    return count\n", "FIND_PATTERNS_101_GIVEN_STRING": "def patternCount ( str ) :\n    last = str [ 0 ]\n    i = 1 ; counter = 0\n    while ( i < len ( str ) ) :\n        if ( str [ i ] == '0' and last == '1' ) :\n            while ( str [ i ] == '0' ) :\n                i += 1\n                if ( str [ i ] == '1' ) :\n                    counter += 1\n        last = str [ i ]\n        i += 1\n    return counter\n", "LONGEST_INCREASING_ODD_EVEN_SUBSEQUENCE": "def longOddEvenIncSeq ( arr , n ) :\n    lioes = list ( )\n    maxLen = 0\n    for i in range ( n ) :\n        lioes.append ( 1 )\n    i = 1\n    for i in range ( n ) :\n        for j in range ( i ) :\n            if ( arr [ i ] > arr [ j ] and ( arr [ i ] + arr [ j ] ) % 2 != 0 and lioes [ i ] < lioes [ j ] + 1 ) :\n                lioes [ i ] = lioes [ j ] + 1\n    for i in range ( n ) :\n        if maxLen < lioes [ i ] :\n            maxLen = lioes [ i ]\n    return maxLen\n", "COUNT_NUMBER_OF_SUBSTRINGS_WITH_EXACTLY_K_DISTINCT_CHARACTERS": "def countkDist ( str1 , k ) :\n    n = len ( str1 )\n    res = 0\n    cnt = [ 0 ] * 27\n    for i in range ( 0 , n ) :\n        dist_count = 0\n        cnt = [ 0 ] * 27\n        for j in range ( i , n ) :\n            if ( cnt [ ord ( str1 [ j ] ) - 97 ] == 0 ) :\n                dist_count += 1\n            cnt [ ord ( str1 [ j ] ) - 97 ] += 1\n            if ( dist_count == k ) :\n                res += 1\n            if ( dist_count > k ) :\n                break\n    return res\n", "C_PROGRAM_FACTORIAL_NUMBER_1": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 ) ;\n", "K_MAXIMUM_SUMS_NON_OVERLAPPING_CONTIGUOUS_SUB_ARRAYS": "def kmax ( arr , k , n ) :\n    for c in range ( k ) :\n        max_so_far = - float ( \"inf\" )\n        max_here = 0\n        start = 0\n        end = 0\n        s = 0\n        for i in range ( n ) :\n            max_here += arr [ i ]\n            if ( max_so_far < max_here ) :\n                max_so_far = max_here\n                start = s\n                end = i\n            if ( max_here < 0 ) :\n                max_here = 0\n                s = i + 1\n        print ( \"Maximum non-overlapping sub-array sum\" , c + 1 , \": \" , max_so_far , \", starting index: \" , start , \", ending index: \" , end , \".\" , sep = \"\" )\n        for l in range ( start , end + 1 ) :\n            arr [ l ] = - float ( \"inf\" )\n    print ( )\n", "DISTANCE_NEAREST_CELL_1_BINARY_MATRIX": "def printDistance ( mat ) :\n    global N , M\n    ans = [ [ None ] * M for i in range ( N ) ]\n    for i in range ( N ) :\n        for j in range ( M ) :\n            ans [ i ] [ j ] = 999999999999\n    for i in range ( N ) :\n        for j in range ( M ) :\n            for k in range ( N ) :\n                for l in range ( M ) :\n                    if ( mat [ k ] [ l ] == 1 ) :\n                        ans [ i ] [ j ] = min ( ans [ i ] [ j ] , abs ( i - k ) + abs ( j - l ) )\n    for i in range ( N ) :\n        for j in range ( M ) :\n            print ( ans [ i ] [ j ] , end = \" \" )\n        print ( )\n", "MINIMUM_NUMBER_OF_BRACKET_REVERSALS_NEEDED_TO_MAKE_AN_EXPRESSION_BALANCED": "def countMinReversals ( expr ) :\n    lenn = len ( expr )\n    if ( lenn % 2 ) :\n        return - 1\n    s = [ ]\n    for i in range ( lenn ) :\n        if ( expr [ i ] == '' and len ( s ) ) :\n            if ( s [ 0 ] == '' ) :\n                s.pop ( 0 )\n            else :\n                s.insert ( 0 , expr [ i ] )\n        else :\n            s.insert ( 0 , expr [ i ] )\n    red_len = len ( s )\n    n = 0\n    while ( len ( s ) and s [ 0 ] == '' ) :\n        s.pop ( 0 )\n        n += 1\n    return ( red_len // 2 + n % 2 )\n", "FIRST_NEGATIVE_INTEGER_EVERY_WINDOW_SIZE_K_1": "def printFirstNegativeInteger ( arr , n , k ) :\n    Di = deque ( )\n    for i in range ( k ) :\n        if ( arr [ i ] < 0 ) :\n            Di.append ( i ) ;\n    for i in range ( k , n ) :\n        if ( not Di ) :\n            print ( 0 , end = ' ' )\n        else :\n            print ( arr [ Di [ 0 ] ] , end = ' ' ) ;\n        while Di and Di [ 0 ] <= ( i - k ) :\n            Di.popleft ( )\n        if ( arr [ i ] < 0 ) :\n            Di.append ( i ) ;\n    if not Di :\n        print ( 0 )\n    else :\n        print ( arr [ Di [ 0 ] ] , end = \" \" )\n", "MAGIC_SQUARE": "def generateSquare ( n ) :\n    magicSquare = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    i = n / 2\n    j = n - 1\n    num = 1\n    while num <= ( n * n ) :\n        if i == - 1 and j == n :\n            j = n - 2\n            i = 0\n        else :\n            if j == n :\n                j = 0\n            if i < 0 :\n                i = n - 1\n        if magicSquare [ int ( i ) ] [ int ( j ) ] :\n            j = j - 2\n            i = i + 1\n            continue\n        else :\n            magicSquare [ int ( i ) ] [ int ( j ) ] = num\n            num = num + 1\n        j = j + 1\n        i = i - 1\n    print ( \"Magic Squre for n =\" , n )\n    print ( \"Sum of each row or column\" , n * ( n * n + 1 ) / 2 , \"\\n\" )\n    for i in range ( 0 , n ) :\n        for j in range ( 0 , n ) :\n            print ( '%2d ' % ( magicSquare [ i ] [ j ] ) , end = '' )\n            if j == n - 1 :\n                print ( )\n", "PROGRAM_BINOMIAL_COEFFICIENTS_TABLE": "def printbinomial ( max ) :\n    for m in range ( max + 1 ) :\n        print ( '% 2d' % m , end = '' )\n        binom = 1\n        for x in range ( m + 1 ) :\n            if m != 0 and x != 0 :\n                binom = binom * ( m - x + 1 ) / x\n            print ( '% 4d' % binom , end = '' )\n        print ( \"\\n\" , end = '' )\n", "CHINESE_REMAINDER_THEOREM_SET_1_INTRODUCTION": "def findMinX ( num , rem , k ) :\n    x = 1 ;\n    while ( True ) :\n        j = 0 ;\n        while ( j < k ) :\n            if ( x % num [ j ] != rem [ j ] ) :\n                break ;\n            j += 1 ;\n        if ( j == k ) :\n            return x ;\n        x += 1 ;\n", "MINIMUM_NUMBER_POINTS_REMOVED_GET_REMAINING_POINTS_ONE_SIDE_AXIS": "def findmin ( p , n ) :\n    a , b , c , d = 0 , 0 , 0 , 0\n    for i in range ( n ) :\n        if ( p [ i ] [ 0 ] <= 0 ) :\n            a += 1\n        elif ( p [ i ] [ 0 ] >= 0 ) :\n            b += 1\n        if ( p [ i ] [ 1 ] >= 0 ) :\n            c += 1\n        elif ( p [ i ] [ 1 ] <= 0 ) :\n            d += 1\n    return min ( [ a , b , c , d ] )\n", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE": "def translate ( st ) :\n    for i in range ( 1 , len ( st ) ) :\n        if ( st [ i - 1 ] == 'A' and st [ i ] == 'B' ) :\n            st [ i - 1 ] = 'C'\n            for j in range ( i , len ( st ) - 1 ) :\n                st [ j ] = st [ j + 1 ]\n            st [ len ( st ) - 1 ] = ' '\n    return\n", "PAIRS_OF_POSITIVE_NEGATIVE_VALUES_IN_AN_ARRAY": "def printPairs ( arr , n ) :\n    v = [ ]\n    for i in range ( n ) :\n        for j in range ( i + 1 , n ) :\n            if ( abs ( arr [ i ] ) == abs ( arr [ j ] ) ) :\n                v.append ( abs ( arr [ i ] ) )\n    if ( len ( v ) == 0 ) :\n        return ;\n    v.sort ( )\n    for i in range ( len ( v ) ) :\n        print ( - v [ i ] , \"\" , v [ i ] , end = \" \" )\n", "NON_REPEATING_ELEMENT_1": "def firstNonRepeating ( arr , n ) :\n    mp = defaultdict ( lambda : 0 )\n    for i in range ( n ) :\n        mp [ arr [ i ] ] += 1\n    for i in range ( n ) :\n        if mp [ arr [ i ] ] == 1 :\n            return arr [ i ]\n    return - 1\n", "PRINT_FIBONACCI_SERIES_REVERSE_ORDER": "def reverseFibonacci ( n ) :\n    a = [ 0 ] * n\n    a [ 0 ] = 0\n    a [ 1 ] = 1\n    for i in range ( 2 , n ) :\n        a [ i ] = a [ i - 2 ] + a [ i - 1 ]\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        print ( a [ i ] , end = \" \" )\n", "FIND_MINIMUM_DIFFERENCE_PAIR_1": "def findMinDiff ( arr , n ) :\n    arr = sorted ( arr )\n    diff = 10 ** 20\n    for i in range ( n - 1 ) :\n        if arr [ i + 1 ] - arr [ i ] < diff :\n            diff = arr [ i + 1 ] - arr [ i ]\n    return diff\n", "MINIMUM_NUMBER_PLATFORMS_REQUIRED_RAILWAYBUS_STATION": "def findPlatform ( arr , dep , n ) :\n    arr.sort ( )\n    dep.sort ( )\n    plat_needed = 1\n    result = 1\n    i = 1\n    j = 0\n    while ( i < n and j < n ) :\n        if ( arr [ i ] < dep [ j ] ) :\n            plat_needed += 1\n            i += 1\n            if ( plat_needed > result ) :\n                result = plat_needed\n        else :\n            plat_needed -= 1\n            j += 1\n    return result\n", "MULTIPLICATIVE_INVERSE_UNDER_MODULO_M_1": "def modInverse ( a , m ) :\n    m0 = m\n    y = 0\n    x = 1\n    if ( m == 1 ) :\n        return 0\n    while ( a > 1 ) :\n        q = a // m\n        t = m\n        m = a % m\n        a = t\n        t = y\n        y = x - q * y\n        x = t\n    if ( x < 0 ) :\n        x = x + m0\n    return x\n", "NUMBER_N_DIGIT_STEPPING_NUMBERS": "def answer ( n ) :\n    dp = [ [ 0 for x in range ( 10 ) ] for y in range ( n + 1 ) ] ;\n    if ( n == 1 ) :\n        return 10 ;\n    for j in range ( 10 ) :\n        dp [ 1 ] [ j ] = 1 ;\n    for i in range ( 2 , n + 1 ) :\n        for j in range ( 10 ) :\n            if ( j == 0 ) :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ] ;\n            elif ( j == 9 ) :\n                dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] ;\n            else :\n                dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] ) ;\n    sum = 0 ;\n    for j in range ( 1 , 10 ) :\n        sum = sum + dp [ n ] [ j ] ;\n    return sum ;\n", "CREATE_A_MATRIX_WITH_ALTERNATING_RECTANGLES_OF_0_AND_X": "def fill0X ( m , n ) :\n    i , k , l = 0 , 0 , 0\n    r = m\n    c = n\n    a = [ [ None ] * n for i in range ( m ) ]\n    x = 'X'\n    while k < m and l < n :\n        for i in range ( l , n ) :\n            a [ k ] [ i ] = x\n        k += 1\n        for i in range ( k , m ) :\n            a [ i ] [ n - 1 ] = x\n        n -= 1\n        if k < m :\n            for i in range ( n - 1 , l - 1 , - 1 ) :\n                a [ m - 1 ] [ i ] = x\n            m -= 1\n        if l < n :\n            for i in range ( m - 1 , k - 1 , - 1 ) :\n                a [ i ] [ l ] = x\n            l += 1\n        x = 'X' if x == '0' else '0'\n    for i in range ( r ) :\n        for j in range ( c ) :\n            print ( a [ i ] [ j ] , end = \" \" )\n        print ( )\n", "FIND_SUM_UNIQUE_SUB_ARRAY_SUM_GIVEN_ARRAY": "def findSubarraySum ( arr , n ) :\n    res = 0\n    m = dict ( )\n    for i in range ( n ) :\n        Sum = 0\n        for j in range ( i , n ) :\n            Sum += arr [ j ]\n            m [ Sum ] = m.get ( Sum , 0 ) + 1\n    for x in m :\n        if m [ x ] == 1 :\n            res += x\n    return res\n", "REVERSE_A_STRING_USING_RECURSION": "def reverse ( string ) :\n    if len ( string ) == 0 :\n        return\n    temp = string [ 0 ]\n    reverse ( string [ 1 : ] )\n    print ( temp , end = '' )\n", "PRINTING_ITEMS_01_KNAPSACK": "def printknapSack ( W , wt , val , n ) :\n    K = [ [ 0 for w in range ( W + 1 ) ] for i in range ( n + 1 ) ]\n    for i in range ( n + 1 ) :\n        for w in range ( W + 1 ) :\n            if i == 0 or w == 0 :\n                K [ i ] [ w ] = 0\n            elif wt [ i - 1 ] <= w :\n                K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ] , K [ i - 1 ] [ w ] )\n            else :\n                K [ i ] [ w ] = K [ i - 1 ] [ w ]\n    res = K [ n ] [ W ]\n    print ( res )\n    w = W\n    for i in range ( n , 0 , - 1 ) :\n        if res <= 0 :\n            break\n        if res == K [ i - 1 ] [ w ] :\n            continue\n        else :\n            print ( wt [ i - 1 ] )\n            res = res - val [ i - 1 ]\n            w = w - wt [ i - 1 ]\n", "FIND_LARGEST_PRIME_FACTOR_NUMBER": "def maxPrimeFactors ( n ) :\n    maxPrime = - 1\n    while n % 2 == 0 :\n        maxPrime = 2\n        n >>= 1\n    for i in range ( 3 , int ( math.sqrt ( n ) ) + 1 , 2 ) :\n        while n % i == 0 :\n            maxPrime = i\n            n = n / i\n    if n > 2 :\n        maxPrime = n\n    return int ( maxPrime )\n", "FIND_THE_ELEMENT_BEFORE_WHICH_ALL_THE_ELEMENTS_ARE_SMALLER_THAN_IT_AND_AFTER_WHICH_ALL_ARE_GREATER_THAN_IT": "def findElement ( arr , n ) :\n    leftMax = [ None ] * n\n    leftMax [ 0 ] = float ( '-inf' )\n    for i in range ( 1 , n ) :\n        leftMax [ i ] = max ( leftMax [ i - 1 ] , arr [ i - 1 ] )\n    rightMin = float ( 'inf' )\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if leftMax [ i ] < arr [ i ] and rightMin > arr [ i ] :\n            return i\n        rightMin = min ( rightMin , arr [ i ] )\n    return - 1\n", "COMMON_CHARACTERS_N_STRINGS": "def commonCharacters ( strings , n ) :\n    prim = [ True ] * MAX_CHAR\n    for i in range ( n ) :\n        sec = [ False ] * MAX_CHAR\n        for j in range ( len ( strings [ i ] ) ) :\n            if ( prim [ ord ( strings [ i ] [ j ] ) - ord ( 'a' ) ] ) :\n                sec [ ord ( strings [ i ] [ j ] ) - ord ( 'a' ) ] = True\n        for i in range ( MAX_CHAR ) :\n            prim [ i ] = sec [ i ]\n    for i in range ( 26 ) :\n        if ( prim [ i ] ) :\n            print ( \"%c \" % ( i + ord ( 'a' ) ) , end = \"\" )\n", "MINIMAL_MOVES_FORM_STRING_ADDING_CHARACTERS_APPENDING_STRING": "def minimalSteps ( s , n ) :\n    dp = [ INT_MAX for i in range ( n ) ]\n    s1 = \"\"\n    s2 = \"\"\n    dp [ 0 ] = 1\n    s1 += s [ 0 ]\n    for i in range ( 1 , n ) :\n        s1 += s [ i ]\n        s2 = s [ i + 1 : i + 1 + i + 1 ]\n        dp [ i ] = min ( dp [ i ] , dp [ i - 1 ] + 1 )\n        if ( s1 == s2 ) :\n            dp [ i * 2 + 1 ] = min ( dp [ i ] + 1 , dp [ i * 2 + 1 ] )\n    return dp [ n - 1 ]\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS_1": "def findSum ( n ) :\n    sum = 0\n    for i in range ( n ) :\n        sum += i * ( n - i )\n    return 2 * sum\n", "FIND_FREQUENCY_EVEN_ODD_NUMBERS_MATRIX": "def freq ( ar , m , n ) :\n    even = 0\n    odd = 0\n    for i in range ( m ) :\n        for j in range ( n ) :\n            if ( ( ar [ i ] [ j ] % 2 ) == 0 ) :\n                even += 1\n            else :\n                odd += 1\n    print ( \" Frequency of odd number =\" , odd )\n    print ( \" Frequency of even number =\" , even )\n", "COUNT_SUBARRAYS_WITH_SAME_EVEN_AND_ODD_ELEMENTS": "def countSubarrays ( arr , n ) :\n    difference = 0\n    ans = 0\n    hash_positive = [ 0 ] * ( n + 1 )\n    hash_negative = [ 0 ] * ( n + 1 )\n    hash_positive [ 0 ] = 1\n    for i in range ( n ) :\n        if ( arr [ i ] & 1 == 1 ) :\n            difference = difference + 1\n        else :\n            difference = difference - 1\n        if ( difference < 0 ) :\n            ans += hash_negative [ - difference ]\n            hash_negative [ - difference ] = hash_negative [ - difference ] + 1\n        else :\n            ans += hash_positive [ difference ]\n            hash_positive [ difference ] = hash_positive [ difference ] + 1\n    return ans\n", "PASCAL_TRIANGLE_1": "def printPascal ( n ) :\n    for line in range ( 1 , n + 1 ) :\n        C = 1 ;\n        for i in range ( 1 , line + 1 ) :\n            print ( C , end = \"\" ) ;\n            C = int ( C * ( line - i ) / i ) ;\n        print ( \"\" ) ;\n", "NUMBER_OF_TRIANGLES_IN_A_PLANE_IF_NO_MORE_THAN_TWO_POINTS_ARE_COLLINEAR": "def countNumberOfTriangles ( n ) :\n    return ( n * ( n - 1 ) * ( n - 2 ) // 6 )\n", "MERGE_TWO_SORTED_ARRAYS_O1_EXTRA_SPACE": "def merge ( ar1 , ar2 , m , n ) :\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        last = ar1 [ m - 1 ]\n        j = m - 2\n        while ( j >= 0 and ar1 [ j ] > ar2 [ i ] ) :\n            ar1 [ j + 1 ] = ar1 [ j ]\n            j -= 1\n        if ( j != m - 2 or last > ar2 [ i ] ) :\n            ar1 [ j + 1 ] = ar2 [ i ]\n            ar2 [ i ] = last\n", "NEWMAN_SHANKS_WILLIAMS_PRIME": "def nswp ( n ) :\n    if n == 0 or n == 1 :\n        return 1\n    return 2 * nswp ( n - 1 ) + nswp ( n - 2 )\n", "SMALLEST_OF_THREE_INTEGERS_WITHOUT_COMPARISON_OPERATORS": "def smallest ( x , y , z ) :\n    c = 0\n    while ( x and y and z ) :\n        x = x - 1\n        y = y - 1\n        z = z - 1\n        c = c + 1\n    return c\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X": "def countPairs ( arr1 , arr2 , m , n , x ) :\n    count = 0\n    for i in range ( m ) :\n        for j in range ( n ) :\n            if arr1 [ i ] + arr2 [ j ] == x :\n                count = count + 1\n    return count\n", "SORT_ARRAY_APPLYING_GIVEN_EQUATION": "def sortArray ( arr , n , A , B , C ) :\n    for i in range ( n ) :\n        arr [ i ] = ( A * arr [ i ] * arr [ i ] + B * arr [ i ] + C )\n    index = - ( sys.maxsize - 1 )\n    maximum = - ( sys.maxsize - 1 )\n    for i in range ( n ) :\n        if maximum < arr [ i ] :\n            index = i\n            maximum = arr [ i ]\n    i = 0 ; j = n - 1 ;\n    new_arr = [ 0 ] * n\n    k = 0\n    while i < index and j > index :\n        if arr [ i ] < arr [ j ] :\n            new_arr [ k ] = arr [ i ]\n            k += 1\n            i += 1\n        else :\n            new_arr [ k ] = arr [ j ]\n            k += 1\n            j -= 1\n    while i < index :\n        new_arr [ k ] = arr [ i ]\n        k += 1\n        i += 1\n    while j > index :\n        new_arr [ k ] = arr [ j ]\n        k += 1\n        j -= 1\n        new_arr [ n - 1 ] = maximum\n    for i in range ( n ) :\n        arr [ i ] = new_arr [ i ]\n", "PROGRAM_TO_FIND_THE_AREA_OF_PENTAGON": "def findArea ( a ) :\n    area = ( sqrt ( 5 * ( 5 + 2 * ( sqrt ( 5 ) ) ) ) * a * a ) / 4\n    return area\n", "MAXIMIZE_SUM_CONSECUTIVE_DIFFERENCES_CIRCULAR_ARRAY": "def maxSum ( arr , n ) :\n    sum = 0\n    arr.sort ( )\n    for i in range ( 0 , int ( n / 2 ) ) :\n        sum -= ( 2 * arr [ i ] )\n        sum += ( 2 * arr [ n - i - 1 ] )\n    return sum\n", "COUNT_ARRAYS_CONSECUTIVE_ELEMENT_DIFFERENT_VALUES": "def countarray ( n , k , x ) :\n    dp = list ( )\n    dp.append ( 0 )\n    dp.append ( 1 )\n    i = 2\n    while i < n :\n        dp.append ( ( k - 2 ) * dp [ i - 1 ] + ( k - 1 ) * dp [ i - 2 ] )\n        i = i + 1\n    return ( ( k - 1 ) * dp [ n - 2 ] if x == 1 else dp [ n - 1 ] )\n", "SUM_SERIES_12_32_52_2N_12": "def sumOfSeries ( n ) :\n    sum = 0\n    for i in range ( 1 , n + 1 ) :\n        sum = sum + ( 2 * i - 1 ) * ( 2 * i - 1 )\n    return sum\n", "FIND_THE_NEAREST_SMALLER_NUMBERS_ON_LEFT_SIDE_IN_AN_ARRAY_1": "def printPrevSmaller ( arr , n ) :\n    S = list ( )\n    for i in range ( n ) :\n        while ( len ( S ) > 0 and S [ - 1 ] >= arr [ i ] ) :\n            S.pop ( )\n        if ( len ( S ) == 0 ) :\n            print ( \"_, \" , end = \"\" )\n        else :\n            print ( S [ - 1 ] , end = \", \" )\n        S.append ( arr [ i ] )\n", "FIND_NUMBER_OF_TRIANGLES_POSSIBLE_1": "def CountTriangles ( A ) :\n    n = len ( A ) ;\n    A.sort ( ) ;\n    count = 0 ;\n    for i in range ( n - 1 , 0 , - 1 ) :\n        l = 0 ;\n        r = i - 1 ;\n        while ( l < r ) :\n            if ( A [ l ] + A [ r ] > A [ i ] ) :\n                count += r - l ;\n                r -= 1 ;\n            else :\n                l += 1 ;\n    print ( \"No of possible solutions: \" , count ) ;\n", "MAXIMUM_GAMES_PLAYED_WINNER": "def maxGameByWinner ( N ) :\n    dp = [ 0 for i in range ( N ) ]\n    dp [ 0 ] = 1\n    dp [ 1 ] = 2\n    i = 1\n    while dp [ i ] <= N :\n        i = i + 1\n        dp [ i ] = dp [ i - 1 ] + dp [ i - 2 ]\n    return ( i - 1 )\n", "NUMBER_OF_SUBSTRINGS_WITH_ODD_DECIMAL_VALUE_IN_A_BINARY_STRING": "def countSubstr ( s ) :\n    n = len ( s )\n    auxArr = [ 0 for i in range ( n ) ]\n    if ( s [ 0 ] == '1' ) :\n        auxArr [ 0 ] = 1\n    for i in range ( 0 , n ) :\n        if ( s [ i ] == '1' ) :\n            auxArr [ i ] = auxArr [ i - 1 ] + 1\n        else :\n            auxArr [ i ] = auxArr [ i - 1 ]\n    count = 0\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if ( s [ i ] == '1' ) :\n            count += auxArr [ i ]\n    return count\n", "ELEMENTS_TO_BE_ADDED_SO_THAT_ALL_ELEMENTS_OF_A_RANGE_ARE_PRESENT_IN_ARRAY_1": "def countNum ( arr , n ) :\n    s = dict ( )\n    count , maxm , minm = 0 , - 10 ** 9 , 10 ** 9\n    for i in range ( n ) :\n        s [ arr [ i ] ] = 1\n        if ( arr [ i ] < minm ) :\n            minm = arr [ i ]\n        if ( arr [ i ] > maxm ) :\n            maxm = arr [ i ]\n    for i in range ( minm , maxm + 1 ) :\n        if i not in s.keys ( ) :\n            count += 1\n    return count\n", "WRITE_A_C_PROGRAM_TO_CALCULATE_POWXN_1": "def power ( x , y ) :\n    if ( y == 0 ) : return 1\n    temp = power ( x , int ( y / 2 ) )\n    if ( y % 2 == 0 ) :\n        return temp * temp\n    else :\n        if ( y > 0 ) : return x * temp * temp\n        else : return ( temp * temp ) / x\n", "N_TH_TERM_SERIES_2_12_36_80_150": "def nthTerm ( n ) :\n    return ( n * n ) + ( n * n * n )\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES": "def getOddOccurrence ( arr , arr_size ) :\n    for i in range ( 0 , arr_size ) :\n        count = 0\n        for j in range ( 0 , arr_size ) :\n            if arr [ i ] == arr [ j ] :\n                count += 1\n        if ( count % 2 != 0 ) :\n            return arr [ i ]\n    return - 1\n", "EFFICIENT_METHOD_2S_COMPLEMENT_BINARY_STRING": "def findTwoscomplement ( str ) :\n    n = len ( str )\n    i = n - 1\n    while ( i >= 0 ) :\n        if ( str [ i ] == '1' ) :\n            break\n        i -= 1\n    if ( i == - 1 ) :\n        return '1' + str\n    k = i - 1\n    while ( k >= 0 ) :\n        if ( str [ k ] == '1' ) :\n            str = list ( str )\n            str [ k ] = '0'\n            str = ''.join ( str )\n        else :\n            str = list ( str )\n            str [ k ] = '1'\n            str = ''.join ( str )\n        k -= 1\n    return str\n", "PAPER_CUT_MINIMUM_NUMBER_SQUARES_SET_2": "def minimumSquare ( m , n ) :\n    vertical_min = 10000000000\n    horizontal_min = 10000000000\n    if m == n :\n        return 1\n    if dp [ m ] [ n ] != 0 :\n        return dp [ m ] [ n ]\n    for i in range ( 1 , m // 2 + 1 ) :\n        horizontal_min = min ( minimumSquare ( i , n ) + minimumSquare ( m - i , n ) , horizontal_min )\n    for j in range ( 1 , n // 2 + 1 ) :\n        vertical_min = min ( minimumSquare ( m , j ) + minimumSquare ( m , n - j ) , vertical_min )\n    dp [ m ] [ n ] = min ( vertical_min , horizontal_min )\n    return dp [ m ] [ n ]\n", "MINIMIZE_ABSOLUTE_DIFFERENCE_SUM_TWO_SUBSETS": "def subsetDifference ( n ) :\n    s = int ( n * ( n + 1 ) / 2 )\n    if n % 4 == 0 :\n        print ( \"First subset sum = \" , int ( s / 2 ) )\n        print ( \"Second subset sum = \" , int ( s / 2 ) )\n        print ( \"Difference = \" , 0 )\n    else :\n        if n % 4 == 1 or n % 4 == 2 :\n            print ( \"First subset sum = \" , int ( s / 2 ) )\n            print ( \"Second subset sum = \" , int ( s / 2 ) + 1 )\n            print ( \"Difference = \" , 1 )\n        else :\n            print ( \"First subset sum = \" , int ( s / 2 ) )\n            print ( \"Second subset sum = \" , int ( s / 2 ) )\n            print ( \"Difference = \" , 0 )\n", "PROGRAM_CALCULATE_VOLUME_ELLIPSOID": "def volumeOfEllipsoid ( r1 , r2 , r3 ) :\n    return 1.33 * math.pi * r1 * r2 * r3\n", "DYNAMIC_PROGRAMMING_SET_13_CUTTING_A_ROD": "def cutRod ( price , n ) :\n    val = [ 0 for x in range ( n + 1 ) ]\n    val [ 0 ] = 0\n    for i in range ( 1 , n + 1 ) :\n        max_val = INT_MIN\n        for j in range ( i ) :\n            max_val = max ( max_val , price [ j ] + val [ i - j - 1 ] )\n        val [ i ] = max_val\n    return val [ n ]\n", "RECURSIVE_INSERTION_SORT": "def insertionSortRecursive ( arr , n ) :\n    if n <= 1 :\n        return\n    insertionSortRecursive ( arr , n - 1 )\n    last = arr [ n - 1 ]\n    j = n - 2\n    while ( j >= 0 and arr [ j ] > last ) :\n        arr [ j + 1 ] = arr [ j ]\n        j = j - 1\n    arr [ j + 1 ] = last\n", "FIND_EXPRESSION_DUPLICATE_PARENTHESIS_NOT": "def findDuplicateparenthesis ( string ) :\n    Stack = [ ]\n    for ch in string :\n        if ch == ')' :\n            top = Stack.pop ( )\n            elementsInside = 0\n            while top != '(' :\n                elementsInside += 1\n                top = Stack.pop ( )\n            if elementsInside < 1 :\n                return True\n        else :\n            Stack.append ( ch )\n    return False\n", "FIND_REPETITIVE_ELEMENT_1_N_1": "def findRepeating ( arr , n ) :\n    return sum ( arr ) - ( ( ( n - 1 ) * n ) // 2 )\n", "CHECK_ARRAY_CONTAINS_CONTIGUOUS_INTEGERS_DUPLICATES_ALLOWED": "def areElementsContiguous ( arr , n ) :\n    max1 = max ( arr )\n    min1 = min ( arr )\n    m = max1 - min1 + 1\n    if ( m > n ) :\n        return False\n    visited = [ 0 ] * m\n    for i in range ( 0 , n ) :\n        visited [ arr [ i ] - min1 ] = True\n    for i in range ( 0 , m ) :\n        if ( visited [ i ] == False ) :\n            return False\n    return True\n", "LENGTH_LONGEST_BALANCED_SUBSEQUENCE_1": "def maxLength ( s , n ) :\n    invalidOpenBraces = 0 ;\n    invalidCloseBraces = 0 ;\n    for i in range ( n ) :\n        if ( s [ i ] == '(' ) :\n            invalidOpenBraces += 1\n        else :\n            if ( invalidOpenBraces == 0 ) :\n                invalidCloseBraces += 1\n            else :\n                invalidOpenBraces -= 1\n    return ( n - ( invalidOpenBraces + invalidCloseBraces ) )\n", "SUM_SERIES_ALTERNATE_SIGNED_SQUARES_AP_1": "def seiresSum ( n , a ) :\n    return ( n * ( a [ 0 ] * a [ 0 ] - a [ 2 * n - 1 ] * a [ 2 * n - 1 ] ) / ( 2 * n - 1 ) )\n", "EQUILIBRIUM_INDEX_OF_AN_ARRAY": "def equilibrium ( arr ) :\n    leftsum = 0\n    rightsum = 0\n    n = len ( arr )\n    for i in range ( n ) :\n        leftsum = 0\n        rightsum = 0\n        for j in range ( i ) :\n            leftsum += arr [ j ]\n        for j in range ( i + 1 , n ) :\n            rightsum += arr [ j ]\n        if leftsum == rightsum :\n            return i\n    return - 1\n", "COUNT_WAYS_REACH_NTH_STAIR_USING_STEP_1_2_3": "def findStep ( n ) :\n    if ( n == 1 or n == 0 ) :\n        return 1\n    elif ( n == 2 ) :\n        return 2\n    else :\n        return findStep ( n - 3 ) + findStep ( n - 2 ) + findStep ( n - 1 )\n", "FIND_MINIMUM_NUMBER_OF_COINS_THAT_MAKE_A_CHANGE": "def minCoins ( coins , m , V ) :\n    if ( V == 0 ) :\n        return 0\n    res = sys.maxsize\n    for i in range ( 0 , m ) :\n        if ( coins [ i ] <= V ) :\n            sub_res = minCoins ( coins , m , V - coins [ i ] )\n            if ( sub_res != sys.maxsize and sub_res + 1 < res ) :\n                res = sub_res + 1\n    return res\n", "BELL_NUMBERS_NUMBER_OF_WAYS_TO_PARTITION_A_SET": "def bellNumber ( n ) :\n    bell = [ [ 0 for i in range ( n + 1 ) ] for j in range ( n + 1 ) ]\n    bell [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , n + 1 ) :\n        bell [ i ] [ 0 ] = bell [ i - 1 ] [ i - 1 ]\n        for j in range ( 1 , i + 1 ) :\n            bell [ i ] [ j ] = bell [ i - 1 ] [ j - 1 ] + bell [ i ] [ j - 1 ]\n    return bell [ n ] [ 0 ]\n", "FIND_ELEMENT_GIVEN_INDEX_NUMBER_ROTATIONS": "def findElement ( arr , ranges , rotations , index ) :\n    for i in range ( rotations - 1 , - 1 , - 1 ) :\n        left = ranges [ i ] [ 0 ]\n        right = ranges [ i ] [ 1 ]\n        if ( left <= index and right >= index ) :\n            if ( index == left ) :\n                index = right\n            else :\n                index = index - 1\n    return arr [ index ]\n", "DYCK_PATH": "def countDyckPaths ( n ) :\n    res = 1\n    for i in range ( 0 , n ) :\n        res *= ( 2 * n - i )\n        res /= ( i + 1 )\n    return res / ( n + 1 )\n", "COUNTING_PAIRS_PERSON_CAN_FORM_PAIR_ONE": "def numberOfWays ( x ) :\n    if x == 0 or x == 1 :\n        return 1\n    else :\n        return ( numberOfWays ( x - 1 ) + ( x - 1 ) * numberOfWays ( x - 2 ) )\n", "PROGRAM_DISPLAY_ASTROLOGICAL_SIGN_ZODIAC_SIGN_GIVEN_DATE_BIRTH": "def zodiac_sign ( day , month ) :\n    if month == 'december' :\n        astro_sign = 'Sagittarius' if ( day < 22 ) else 'capricorn'\n    elif month == 'january' :\n        astro_sign = 'Capricorn' if ( day < 20 ) else 'aquarius'\n    elif month == 'february' :\n        astro_sign = 'Aquarius' if ( day < 19 ) else 'pisces'\n    elif month == 'march' :\n        astro_sign = 'Pisces' if ( day < 21 ) else 'aries'\n    elif month == 'april' :\n        astro_sign = 'Aries' if ( day < 20 ) else 'taurus'\n    elif month == 'may' :\n        astro_sign = 'Taurus' if ( day < 21 ) else 'gemini'\n    elif month == 'june' :\n        astro_sign = 'Gemini' if ( day < 21 ) else 'cancer'\n    elif month == 'july' :\n        astro_sign = 'Cancer' if ( day < 23 ) else 'leo'\n    elif month == 'august' :\n        astro_sign = 'Leo' if ( day < 23 ) else 'virgo'\n    elif month == 'september' :\n        astro_sign = 'Virgo' if ( day < 23 ) else 'libra'\n    elif month == 'october' :\n        astro_sign = 'Libra' if ( day < 23 ) else 'scorpio'\n    elif month == 'november' :\n        astro_sign = 'scorpio' if ( day < 22 ) else 'sagittarius'\n    print ( astro_sign )\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE_2": "def recursiveReverse ( str , i = 0 ) :\n    n = len ( str )\n    if i == n // 2 :\n        return\n    str [ i ] , str [ n - i - 1 ] = str [ n - i - 1 ] , str [ i ]\n    recursiveReverse ( str , i + 1 )\n", "K_TH_DIGIT_RAISED_POWER_B": "def kthdigit ( a , b , k ) :\n    p = a ** b\n    count = 0\n    while ( p > 0 and count < k ) :\n        rem = p % 10\n        count = count + 1\n        if ( count == k ) :\n            return rem\n        p = p / 10 ;\n", "SMALLEST_DIFFERENCE_PAIR_VALUES_TWO_UNSORTED_ARRAYS": "def findSmallestDifference ( A , B , m , n ) :\n    A.sort ( )\n    B.sort ( )\n    a = 0\n    b = 0\n    result = sys.maxsize\n    while ( a < m and b < n ) :\n        if ( abs ( A [ a ] - B [ b ] ) < result ) :\n            result = abs ( A [ a ] - B [ b ] )\n        if ( A [ a ] < B [ b ] ) :\n            a += 1\n        else :\n            b += 1\n    return result\n", "MAXIMUM_AREA_RECTANGLE_PICKING_FOUR_SIDES_ARRAY_1": "def findArea ( arr , n ) :\n    s = [ ]\n    first = 0\n    second = 0\n    for i in range ( n ) :\n        if arr [ i ] not in s :\n            s.append ( arr [ i ] )\n            continue\n        if ( arr [ i ] > first ) :\n            second = first\n            first = arr [ i ]\n        elif ( arr [ i ] > second ) :\n            second = arr [ i ]\n    return ( first * second )\n", "PROGRAM_PAGE_REPLACEMENT_ALGORITHMS_SET_2_FIFO": "def pageFaults ( pages , n , capacity ) :\n    s = set ( )\n    indexes = Queue ( )\n    page_faults = 0\n    for i in range ( n ) :\n        if ( len ( s ) < capacity ) :\n            if ( pages [ i ] not in s ) :\n                s.add ( pages [ i ] )\n                page_faults += 1\n                indexes.put ( pages [ i ] )\n        else :\n            if ( pages [ i ] not in s ) :\n                val = indexes.queue [ 0 ]\n                indexes.get ( )\n                s.remove ( val )\n                s.add ( pages [ i ] )\n                indexes.put ( pages [ i ] )\n                page_faults += 1\n    return page_faults\n", "FIND_LARGEST_D_IN_ARRAY_SUCH_THAT_A_B_C_D_1": "def findFourElements ( arr , n ) :\n    mp = dict ( )\n    for i in range ( n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            mp [ arr [ i ] + arr [ j ] ] = ( i , j )\n    d = - 10 ** 9\n    for i in range ( n - 1 ) :\n        for j in range ( i + 1 , n ) :\n            abs_diff = abs ( arr [ i ] - arr [ j ] )\n            if abs_diff in mp.keys ( ) :\n                p = mp [ abs_diff ]\n                if ( p [ 0 ] != i and p [ 0 ] != j and p [ 1 ] != i and p [ 1 ] != j ) :\n                    d = max ( d , max ( arr [ i ] , arr [ j ] ) )\n    return d\n", "PRINT_GIVEN_MATRIX_REVERSE_SPIRAL_FORM": "def ReversespiralPrint ( m , n , a ) :\n    b = [ 0 for i in range ( 100 ) ]\n    i , k , l = 0 , 0 , 0\n    z = 0\n    size = m * n\n    while ( k < m and l < n ) :\n        val = 0\n        for i in range ( l , n ) :\n            val = a [ k ] [ i ]\n            b [ z ] = val\n            z += 1\n        k += 1\n        for i in range ( k , m ) :\n            val = a [ i ] [ n - 1 ]\n            b [ z ] = val\n            z += 1\n        n -= 1\n        if ( k < m ) :\n            for i in range ( n - 1 , l - 1 , - 1 ) :\n                val = a [ m - 1 ] [ i ]\n                b [ z ] = val\n                z += 1\n        m -= 1\n        if ( l < n ) :\n            for i in range ( m - 1 , k - 1 , - 1 ) :\n                val = a [ i ] [ l ]\n                b [ z ] = val\n                z += 1\n            l += 1\n    for i in range ( size - 1 , - 1 , - 1 ) :\n        print ( b [ i ] , end = \" \" )\n", "NUMBER_N_DIGITS_NON_DECREASING_INTEGERS": "def nonDecNums ( n ) :\n    a = np.zeros ( ( n + 1 , 10 ) )\n    for i in range ( 10 ) :\n        a [ 0 ] [ i ] = 1\n    for i in range ( 1 , n + 1 ) :\n        a [ i ] [ 9 ] = 1\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 8 , - 1 , - 1 ) :\n            a [ i ] [ j ] = a [ i - 1 ] [ j ] + a [ i ] [ j + 1 ]\n    return int ( a [ n ] [ 0 ] )\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF": "def findLength ( str ) :\n    n = len ( str )\n    maxlen = 0\n    for i in range ( 0 , n ) :\n        for j in range ( i + 1 , n , 2 ) :\n            length = j - i + 1\n            leftsum = 0\n            rightsum = 0\n            for k in range ( 0 , int ( length / 2 ) ) :\n                leftsum += ( int ( str [ i + k ] ) - int ( '0' ) )\n                rightsum += ( int ( str [ i + k + int ( length / 2 ) ] ) - int ( '0' ) )\n            if ( leftsum == rightsum and maxlen < length ) :\n                maxlen = length\n    return maxlen\n", "PROGRAM_WORST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "def worstFit ( blockSize , m , processSize , n ) :\n    allocation = [ - 1 ] * n\n    for i in range ( n ) :\n        wstIdx = - 1\n        for j in range ( m ) :\n            if blockSize [ j ] >= processSize [ i ] :\n                if wstIdx == - 1 :\n                    wstIdx = j\n                elif blockSize [ wstIdx ] < blockSize [ j ] :\n                    wstIdx = j\n        if wstIdx != - 1 :\n            allocation [ i ] = wstIdx\n            blockSize [ wstIdx ] -= processSize [ i ]\n    print ( \"Process No.Process Size Block no.\" )\n    for i in range ( n ) :\n        print ( i + 1 , \"         \" , processSize [ i ] , end = \"     \" )\n        if allocation [ i ] != - 1 :\n            print ( allocation [ i ] + 1 )\n        else :\n            print ( \"Not Allocated\" )\n", "SUM_SUBSETS_SET_FORMED_FIRST_N_NATURAL_NUMBERS": "def findSumSubsets ( n ) :\n    return ( n * ( n + 1 ) / 2 ) * ( 1 << ( n - 1 ) )\n", "ADD_TWO_NUMBERS_WITHOUT_USING_ARITHMETIC_OPERATORS": "def Add ( x , y ) :\n    while ( y != 0 ) :\n        carry = x & y\n        x = x ^ y\n        y = carry << 1\n    return x\n", "MAXIMUM_BINOMIAL_COEFFICIENT_TERM_VALUE": "def maxcoefficientvalue ( n ) :\n    C = [ [ 0 for x in range ( n + 1 ) ] for y in range ( n + 1 ) ] ;\n    for i in range ( n + 1 ) :\n        for j in range ( min ( i , n ) + 1 ) :\n            if ( j == 0 or j == i ) :\n                C [ i ] [ j ] = 1 ;\n            else :\n                C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] ) ;\n    maxvalue = 0 ;\n    for i in range ( n + 1 ) :\n        maxvalue = max ( maxvalue , C [ n ] [ i ] ) ;\n    return maxvalue ;\n", "EULERIAN_PATH_UNDIRECTED_GRAPH": "def findpath ( graph ) :\n    n = len ( graph )\n    numofadj = list ( )\n    for i in range ( n ) :\n        numofadj.append ( sum ( graph [ i ] ) )\n    startpoint = 0\n    numofodd = 0\n    for i in range ( n - 1 , - 1 , - 1 ) :\n        if ( numofadj [ i ] % 2 == 1 ) :\n            numofodd += 1\n            startpoint = i\n    if ( numofodd > 2 ) :\n        print ( \"No Solution\" )\n        return\n    stack = list ( )\n    path = list ( )\n    cur = startpoint\n    while ( stack != [ ] or sum ( graph [ cur ] ) != 0 ) :\n        if ( sum ( graph [ cur ] ) == 0 ) :\n            path.append ( cur + 1 )\n            cur = stack.pop ( - 1 )\n        else :\n            for i in range ( n ) :\n                if graph [ cur ] [ i ] == 1 :\n                    stack.append ( cur )\n                    graph [ cur ] [ i ] = 0\n                    graph [ i ] [ cur ] = 0\n                    cur = i\n                    break\n    for ele in path :\n        print ( ele , \"-> \" , end = '' )\n    print ( cur + 1 )\n", "RECURSIVE_SOLUTION_COUNT_SUBSTRINGS_FIRST_LAST_CHARACTERS": "def countSubstrs ( str , i , j , n ) :\n    if ( n == 1 ) :\n        return 1\n    if ( n <= 0 ) :\n        return 0\n    res = ( countSubstrs ( str , i + 1 , j , n - 1 ) + countSubstrs ( str , i , j - 1 , n - 1 ) - countSubstrs ( str , i + 1 , j - 1 , n - 2 ) )\n    if ( str [ i ] == str [ j ] ) :\n        res += 1\n    return res\n", "FIND_NUMBER_TIMES_STRING_OCCURS_GIVEN_STRING_1": "def count ( a , b ) :\n    m = len ( a )\n    n = len ( b )\n    lookup = [ [ 0 ] * ( n + 1 ) for i in range ( m + 1 ) ]\n    for i in range ( n + 1 ) :\n        lookup [ 0 ] [ i ] = 0\n    for i in range ( m + 1 ) :\n        lookup [ i ] [ 0 ] = 1\n    for i in range ( 1 , m + 1 ) :\n        for j in range ( 1 , n + 1 ) :\n            if a [ i - 1 ] == b [ j - 1 ] :\n                lookup [ i ] [ j ] = lookup [ i - 1 ] [ j - 1 ] + lookup [ i - 1 ] [ j ]\n            else :\n                lookup [ i ] [ j ] = lookup [ i - 1 ] [ j ]\n    return lookup [ m ] [ n ]\n", "AREA_OF_A_POLYGON_WITH_GIVEN_N_ORDERED_VERTICES": "def polygonArea ( X , Y , n ) :\n    area = 0.0\n    j = n - 1\n    for i in range ( 0 , n ) :\n        area += ( X [ j ] + X [ i ] ) * ( Y [ j ] - Y [ i ] )\n        j = i\n    return int ( abs ( area / 2.0 ) )\n", "PRINT_POSSIBLE_SUMS_CONSECUTIVE_NUMBERS_SUM_N": "def findConsecutive ( N ) :\n    start = 1\n    end = ( N + 1 ) // 2\n    while ( start < end ) :\n        Sum = 0\n        for i in range ( start , end + 1 ) :\n            Sum = Sum + i\n            if ( Sum == N ) :\n                for j in range ( start , i + 1 ) :\n                    print ( j , end = \" \" )\n                print ( )\n                break\n            if ( Sum > N ) :\n                break\n        Sum = 0\n        start += 1\n", "BALANCED_EXPRESSIONS_SUCH_THAT_GIVEN_POSITIONS_HAVE_OPENING_BRACKETS": "def arrangeBraces ( n , pos , k ) :\n    h = [ False for i in range ( N ) ]\n    dp = [ [ 0 for i in range ( N ) ] for i in range ( N ) ]\n    for i in range ( k ) :\n        h [ pos [ i ] ] = 1\n    dp [ 0 ] [ 0 ] = 1\n    for i in range ( 1 , 2 * n + 1 ) :\n        for j in range ( 2 * n + 1 ) :\n            if ( h [ i ] ) :\n                if ( j != 0 ) :\n                    dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ]\n                else :\n                    dp [ i ] [ j ] = 0\n            else :\n                if ( j != 0 ) :\n                    dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] )\n                else :\n                    dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ]\n    return dp [ 2 * n ] [ 0 ]\n", "GIVEN_1S_2S_3S_KS_PRINT_ZIG_ZAG_WAY": "def ZigZag ( rows , columns , numbers ) :\n    k = 0\n    arr = [ [ 0 for i in range ( columns ) ] for j in range ( rows ) ]\n    for i in range ( rows ) :\n        if ( i % 2 == 0 ) :\n            j = 0\n            while j < columns and numbers [ k ] > 0 :\n                arr [ i ] [ j ] = k + 1\n                numbers [ k ] -= 1\n                if numbers [ k ] == 0 :\n                    k += 1\n                j += 1\n        else :\n            j = columns - 1\n            while j >= 0 and numbers [ k ] > 0 :\n                arr [ i ] [ j ] = k + 1\n                numbers [ k ] -= 1\n                if numbers [ k ] == 0 :\n                    k += 1\n                j -= 1\n    for i in arr :\n        for j in i :\n            print ( j , end = \" \" )\n        print ( )\n", "CONVERT_STRING_BINARY_SEQUENCE": "def strToBinary ( s ) :\n    bin_conv = [ ]\n    for c in s :\n        ascii_val = ord ( c )\n        binary_val = bin ( ascii_val )\n        bin_conv.append ( binary_val [ 2 : ] )\n    return ( ' '.join ( bin_conv ) )\n", "LUCKY_NUMBERS": "def isLucky ( n ) :\n    next_position = n\n    if isLucky.counter > n :\n        return 1\n    if n % isLucky.counter == 0 :\n        return 0\n    next_position = next_position - next_position / isLucky.counter\n    isLucky.counter = isLucky.counter + 1\n    return isLucky ( next_position )\n", "SMALLEST_SUM_CONTIGUOUS_SUBARRAY": "def smallestSumSubarr ( arr , n ) :\n    min_ending_here = sys.maxsize\n    min_so_far = sys.maxsize\n    for i in range ( n ) :\n        if ( min_ending_here > 0 ) :\n            min_ending_here = arr [ i ]\n        else :\n            min_ending_here += arr [ i ]\n        min_so_far = min ( min_so_far , min_ending_here )\n    return min_so_far\n", "PRINT_N_TERMS_NEWMAN_CONWAY_SEQUENCE": "def sequence ( n ) :\n    f = [ 0 , 1 , 1 ]\n    print ( f [ 1 ] , end = \" \" ) ,\n    print ( f [ 2 ] , end = \" \" ) ,\n    for i in range ( 3 , n + 1 ) :\n        f.append ( f [ f [ i - 1 ] ] + f [ i - f [ i - 1 ] ] )\n        print ( f [ i ] , end = \" \" ) ,\n", "MASTER_THEOREM_SUBTRACT_CONQUER_RECURRENCES": "def fib ( n ) :\n    if ( n <= 1 ) :\n        return n\n    return fib ( n - 1 ) + fib ( n - 2 )\n", "MINIMUM_COST_MAKE_ARRAY_SIZE_1_REMOVING_LARGER_PAIRS": "def cost ( a , n ) :\n    return ( ( n - 1 ) * min ( a ) )\n", "CHOCOLATE_DISTRIBUTION_PROBLEM": "def findMinDiff ( arr , n , m ) :\n    if ( m == 0 or n == 0 ) :\n        return 0\n    arr.sort ( )\n    if ( n < m ) :\n        return - 1\n    min_diff = sys.maxsize\n    first = 0\n    last = 0\n    i = 0\n    while ( i + m - 1 < n ) :\n        diff = arr [ i + m - 1 ] - arr [ i ]\n        if ( diff < min_diff ) :\n            min_diff = diff\n            first = i\n            last = i + m - 1\n        i += 1\n    return ( arr [ last ] - arr [ first ] )\n", "FIND_ONE_EXTRA_CHARACTER_STRING_1": "def findExtraCharcter ( strA , strB ) :\n    res = 0\n    for i in range ( 0 , len ( strA ) ) :\n        res = res ^ ( ord ) ( strA [ i ] )\n    for i in range ( 0 , len ( strB ) ) :\n        res = res ^ ( ord ) ( strB [ i ] )\n    return ( ( chr ) ( res ) ) ;\n", "CHECK_WHETHER_TWO_STRINGS_ARE_ANAGRAM_OF_EACH_OTHER": "def areAnagram ( str1 , str2 ) :\n    n1 = len ( str1 )\n    n2 = len ( str2 )\n    if n1 != n2 :\n        return 0\n    str1 = sorted ( str1 )\n    str2 = sorted ( str2 )\n    for i in range ( 0 , n1 ) :\n        if str1 [ i ] != str2 [ i ] :\n            return 0\n    return 1\n", "CALCULATE_MAXIMUM_VALUE_USING_SIGN_TWO_NUMBERS_STRING": "def calcMaxValue ( str ) :\n    res = ord ( str [ 0 ] ) - 48\n    for i in range ( 1 , len ( str ) ) :\n        if ( str [ i ] == '0' or str [ i ] == '1' or res < 2 ) :\n            res += ord ( str [ i ] ) - 48\n        else :\n            res *= ord ( str [ i ] ) - 48\n    return res\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER": "def findSum ( N , K ) :\n    ans = 0 ;\n    for i in range ( 1 , N + 1 ) :\n        ans += ( i % K ) ;\n    return ans ;\n", "DISTRIBUTING_ITEMS_PERSON_CANNOT_TAKE_TWO_ITEMS_TYPE_1": "def checkCount ( arr , n , k ) :\n    mp = defaultdict ( lambda : 0 )\n    for i in range ( n ) :\n        mp [ arr [ i ] ] += 1\n    for key , values in mp.items ( ) :\n        if values > 2 * k :\n            return False\n    return True\n", "SEARCH_IN_ROW_WISE_AND_COLUMN_WISE_SORTED_MATRIX": "def search ( mat , n , x ) :\n    i = 0\n    j = n - 1\n    while ( i < n and j >= 0 ) :\n        if ( mat [ i ] [ j ] == x ) :\n            print ( \"n Found at \" , i , \", \" , j )\n            return 1\n        if ( mat [ i ] [ j ] > x ) :\n            j -= 1\n        else :\n            i += 1\n    print ( \"Element not found\" )\n    return 0\n", "RETURN_PREVIOUS_ELEMENT_IN_AN_EXPANDING_MATRIX": "def findLeft ( str ) :\n    n = len ( str ) - 1 ;\n    while ( n > 0 ) :\n        if ( str [ n ] == 'd' ) :\n            str = str [ 0 : n ] + 'c' + str [ n + 1 : ] ;\n            break ;\n        if ( str [ n ] == 'b' ) :\n            str = str [ 0 : n ] + 'a' + str [ n + 1 : ] ;\n            break ;\n        if ( str [ n ] == 'a' ) :\n            str = str [ 0 : n ] + 'b' + str [ n + 1 : ] ;\n        elif ( str [ n ] == 'c' ) :\n            str = str [ 0 : n ] + 'd' + str [ n + 1 : ] ;\n        n -= 1 ;\n    return str ;\n", "SUM_FACTORS_NUMBER": "def divSum ( n ) :\n    result = 0\n    for i in range ( 2 , ( int ) ( math.sqrt ( n ) ) + 1 ) :\n        if ( n % i == 0 ) :\n            if ( i == ( n / i ) ) :\n                result = result + i\n            else :\n                result = result + ( i + n // i )\n    return ( result + n + 1 )\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT_2": "def sumDigits ( no ) :\n    return 0 if no == 0 else int ( no % 10 ) + sumDigits ( int ( no / 10 ) )\n", "CHECK_POSSIBLE_SORT_ARRAY_CONDITIONAL_SWAPPING_ADJACENT_ALLOWED": "def checkForSorting ( arr , n ) :\n    for i in range ( 0 , n - 1 ) :\n        if ( arr [ i ] > arr [ i + 1 ] ) :\n            if ( arr [ i ] - arr [ i + 1 ] == 1 ) :\n                arr [ i ] , arr [ i + 1 ] = arr [ i + 1 ] , arr [ i ]\n            else :\n                return False\n    return True\n", "SUPER_PRIME": "def SieveOfEratosthenes ( n , isPrime ) :\n    isPrime [ 0 ] = isPrime [ 1 ] = False\n    for i in range ( 2 , n + 1 ) :\n        isPrime [ i ] = True\n    for p in range ( 2 , n + 1 ) :\n        if ( p * p <= n and isPrime [ p ] == True ) :\n            for i in range ( p * 2 , n + 1 , p ) :\n                isPrime [ i ] = False\n                p += 1\n", "PROGRAM_BINARY_DECIMAL_CONVERSION_1": "def binaryToDecimal ( n ) :\n    num = n ;\n    dec_value = 0 ;\n    base1 = 1 ;\n    len1 = len ( num ) ;\n    for i in range ( len1 - 1 , - 1 , - 1 ) :\n        if ( num [ i ] == '1' ) :\n            dec_value += base1 ;\n        base1 = base1 * 2 ;\n    return dec_value ;\n", "LEONARDO_NUMBER": "def leonardo ( n ) :\n    if ( n == 0 or n == 1 ) :\n        return 1\n    return ( leonardo ( n - 1 ) + leonardo ( n - 2 ) + 1 ) ;\n", "CHECK_ARRAY_CONTAINS_CONTIGUOUS_INTEGERS_DUPLICATES_ALLOWED_1": "def areElementsContiguous ( arr ) :\n    us = set ( )\n    for i in arr : us.add ( i )\n    count = 1\n    curr_ele = arr [ 0 ] - 1\n    while curr_ele in us :\n        count += 1\n        curr_ele -= 1\n    curr_ele = arr [ 0 ] + 1\n    while curr_ele in us :\n        count += 1\n        curr_ele += 1\n    return ( count == len ( us ) )\n", "SQUARE_ROOT_OF_AN_INTEGER": "def floorSqrt ( x ) :\n    if ( x == 0 or x == 1 ) :\n        return x\n    i = 1 ; result = 1\n    while ( result <= x ) :\n        i += 1\n        result = i * i\n    return i - 1\n", "LEXICOGRAPHICALLY_LARGEST_SUBSEQUENCE_EVERY_CHARACTER_OCCURS_LEAST_K_TIMES": "def subsequence ( s , t , n , k ) :\n    last = 0\n    cnt = 0\n    new_last = 0\n    size = 0\n    string = 'zyxwvutsrqponmlkjihgfedcba'\n    for ch in string :\n        cnt = 0\n        for i in range ( last , n ) :\n            if s [ i ] == ch :\n                cnt += 1\n        if cnt >= k :\n            for i in range ( last , n ) :\n                if s [ i ] == ch :\n                    t [ size ] = ch\n                    new_last = i\n                    size += 1\n            last = new_last\n", "RECURSIVELY_BREAK_NUMBER_3_PARTS_GET_MAXIMUM_SUM": "def breakSum ( n ) :\n    if ( n == 0 or n == 1 ) :\n        return n\n    return max ( ( breakSum ( n // 2 ) + breakSum ( n // 3 ) + breakSum ( n // 4 ) ) , n )\n", "MINIMUM_NUMBER_SWAPS_REQUIRED_SORT_ARRAY": "def minSwaps ( arr ) :\n    n = len ( arr )\n    arrpos = [ * enumerate ( arr ) ]\n    arrpos.sort ( key = lambda it : it [ 1 ] )\n    vis = { k : False for k in range ( n ) }\n    ans = 0\n    for i in range ( n ) :\n        if vis [ i ] or arrpos [ i ] [ 0 ] == i :\n            continue\n        cycle_size = 0\n        j = i\n        while not vis [ j ] :\n            vis [ j ] = True\n            j = arrpos [ j ] [ 0 ]\n            cycle_size += 1\n        if cycle_size > 0 :\n            ans += ( cycle_size - 1 )\n    return ans\n", "DIAGONALLY_DOMINANT_MATRIX": "def isDDM ( m , n ) :\n    for i in range ( 0 , n ) :\n        sum = 0\n        for j in range ( 0 , n ) :\n            sum = sum + abs ( m [ i ] [ j ] )\n        sum = sum - abs ( m [ i ] [ i ] )\n        if ( abs ( m [ i ] [ i ] ) < sum ) :\n            return False\n    return True\n", "SPLIT_N_MAXIMUM_COMPOSITE_NUMBERS": "def count ( n ) :\n    if ( n < 4 ) :\n        return - 1\n    rem = n % 4\n    if ( rem == 0 ) :\n        return n // 4\n    if ( rem == 1 ) :\n        if ( n < 9 ) :\n            return - 1\n        return ( n - 9 ) // 4 + 1\n    if ( rem == 2 ) :\n        return ( n - 6 ) // 4 + 1\n    if ( rem == 3 ) :\n        if ( n < 15 ) :\n            return - 1\n        return ( n - 15 ) // 4 + 2\n", "FIND_DIMENSIONS_RIGHT_ANGLED_TRIANGLE": "def findDimen ( H , A ) :\n    if H * H < 4 * A :\n        print ( \"Not Possible\" )\n        return\n    apb = sqrt ( H * H + 4 * A )\n    asb = sqrt ( H * H - 4 * A )\n    print ( \"P = \" , \"%.2f\" % ( ( apb - asb ) / 2.0 ) )\n    print ( \"B = \" , \"%.2f\" % ( ( apb + asb ) / 2.0 ) )\n", "PRODUCT_MAXIMUM_FIRST_ARRAY_MINIMUM_SECOND_1": "def minMaxProduct ( arr1 , arr2 , n1 , n2 ) :\n    max = arr1 [ 0 ]\n    min = arr2 [ 0 ]\n    i = 1\n    while ( i < n1 and i < n2 ) :\n        if ( arr1 [ i ] > max ) :\n            max = arr1 [ i ]\n        if ( arr2 [ i ] < min ) :\n            min = arr2 [ i ]\n        i += 1\n    while ( i < n1 ) :\n        if ( arr1 [ i ] > max ) :\n            max = arr1 [ i ]\n            i += 1\n    while ( i < n2 ) :\n        if ( arr2 [ i ] < min ) :\n            min = arr2 [ i ]\n            i += 1\n    return max * min\n", "PROGRAM_CALCULATE_VOLUME_OCTAHEDRON": "def vol_of_octahedron ( side ) :\n    return ( ( side * side * side ) * ( math.sqrt ( 2 ) / 3 ) )\n", "SORT_STRING_CHARACTERS_1": "def sortString ( str ) :\n    charCount = [ 0 for i in range ( MAX_CHAR ) ]\n    for i in range ( 0 , len ( str ) , 1 ) :\n        charCount [ ord ( str [ i ] ) - ord ( 'a' ) ] += 1\n    for i in range ( 0 , MAX_CHAR , 1 ) :\n        for j in range ( 0 , charCount [ i ] , 1 ) :\n            print ( chr ( ord ( 'a' ) + i ) , end = \"\" )\n", "MOVE_SPACES_FRONT_STRING_SINGLE_TRAVERSAL": "def moveSpaceInFront ( s ) :\n    i = len ( s ) - 1 ;\n    for j in range ( i , - 1 , - 1 ) :\n        if ( s [ j ] != ' ' ) :\n            s = s [ : i ] + s [ j ] + s [ i + 1 : ]\n            i -= 1 ;\n    while ( i >= 0 ) :\n        s = s [ : i ] + ' ' + s [ i + 1 : ]\n        i -= 1\n    return s ;\n", "MINIMUM_INCREMENT_K_OPERATIONS_MAKE_ELEMENTS_EQUAL": "def minOps ( arr , n , k ) :\n    max1 = max ( arr )\n    res = 0\n    for i in range ( 0 , n ) :\n        if ( ( max1 - arr [ i ] ) % k != 0 ) :\n            return - 1\n        else :\n            res += ( max1 - arr [ i ] ) / k\n    return int ( res )\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER_1": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 ) ;\n", "MINIMUM_TIME_TO_FINISH_TASKS_WITHOUT_SKIPPING_TWO_CONSECUTIVE": "def minTime ( arr , n ) :\n    if ( n <= 0 ) : return 0\n    incl = arr [ 0 ]\n    excl = 0\n    for i in range ( 1 , n ) :\n        incl_new = arr [ i ] + min ( excl , incl )\n        excl_new = incl\n        incl = incl_new\n        excl = excl_new\n    return min ( incl , excl )\n", "CHECK_IF_TWO_ARRAYS_ARE_EQUAL_OR_NOT": "def areEqual ( arr1 , arr2 , n , m ) :\n    if ( n != m ) :\n        return False ;\n    arr1.sort ( ) ;\n    arr2.sort ( ) ;\n    for i in range ( 0 , n - 1 ) :\n        if ( arr1 [ i ] != arr2 [ i ] ) :\n            return False ;\n    return True ;\n", "MINIMUM_DIFFERENCE_MAX_MIN_K_SIZE_SUBSETS": "def minDifferenceAmongMaxMin ( arr , N , K ) :\n    arr.sort ( )\n    res = 2147483647\n    for i in range ( ( N - K ) + 1 ) :\n        curSeqDiff = arr [ i + K - 1 ] - arr [ i ]\n        res = min ( res , curSeqDiff )\n    return res\n", "SWAP_BITS_IN_A_GIVEN_NUMBER": "def swapBits ( x , p1 , p2 , n ) :\n    set1 = ( x >> p1 ) & ( ( 1 << n ) - 1 )\n    set2 = ( x >> p2 ) & ( ( 1 << n ) - 1 )\n    xor = ( set1 ^ set2 )\n    xor = ( xor << p1 ) | ( xor << p2 )\n    result = x ^ xor\n    return result\n", "COUNT_NUMBER_OF_WAYS_TO_FILL_A_N_X_4_GRID_USING_1_X_4_TILES": "def count ( n ) :\n    dp = [ 0 for _ in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        if i <= 3 :\n            dp [ i ] = 1\n        elif i == 4 :\n            dp [ i ] = 2\n        else :\n            dp [ i ] = dp [ i - 1 ] + dp [ i - 4 ]\n    return dp [ n ]\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING_1": "def maxRepeating ( str ) :\n    n = len ( str )\n    count = 0\n    res = str [ 0 ]\n    cur_count = 1\n    for i in range ( n ) :\n        if ( i < n - 1 and str [ i ] == str [ i + 1 ] ) :\n            cur_count += 1\n        else :\n            if cur_count > count :\n                count = cur_count\n                res = str [ i ]\n            cur_count = 1\n    return res\n", "PASCAL_TRIANGLE": "def printPascal ( n : int ) :\n    arr = [ [ 0 for x in range ( n ) ] for y in range ( n ) ]\n    for line in range ( 0 , n ) :\n        for i in range ( 0 , line + 1 ) :\n            if ( i is 0 or i is line ) :\n                arr [ line ] [ i ] = 1\n                print ( arr [ line ] [ i ] , end = \"\" )\n            else :\n                arr [ line ] [ i ] = ( arr [ line - 1 ] [ i - 1 ] + arr [ line - 1 ] [ i ] )\n                print ( arr [ line ] [ i ] , end = \"\" )\n        print ( \"\\n\" , end = \"\" )\n", "TURN_OFF_THE_RIGHTMOST_SET_BIT": "def fun ( n ) :\n    return n & ( n - 1 )\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM_SET_2_O1_EXTRA_SPACE": "def rearrange ( arr , n ) :\n    max_idx = n - 1\n    min_idx = 0\n    max_elem = arr [ n - 1 ] + 1\n    for i in range ( 0 , n ) :\n        if i % 2 == 0 :\n            arr [ i ] += ( arr [ max_idx ] % max_elem ) * max_elem\n            max_idx -= 1\n        else :\n            arr [ i ] += ( arr [ min_idx ] % max_elem ) * max_elem\n            min_idx += 1\n    for i in range ( 0 , n ) :\n        arr [ i ] = arr [ i ] / max_elem\n", "COUNT_ZEROS_IN_A_ROW_WISE_AND_COLUMN_WISE_SORTED_MATRIX": "def countZeroes ( mat ) :\n    N = 5 ;\n    row = N - 1 ;\n    col = 0 ;\n    count = 0 ;\n    while ( col < N ) :\n        while ( mat [ row ] [ col ] ) :\n            if ( row < 0 ) :\n                return count ;\n            row = row - 1 ;\n        count = count + ( row + 1 ) ;\n        col = col + 1 ;\n    return count ;\n", "MINIMUM_COST_FOR_ACQUIRING_ALL_COINS_WITH_K_EXTRA_COINS_ALLOWED_WITH_EVERY_COIN": "def minCost ( coin , n , k ) :\n    coin.sort ( )\n    coins_needed = math.ceil ( 1.0 * n // ( k + 1 ) ) ;\n    ans = 0\n    for i in range ( coins_needed - 1 + 1 ) :\n        ans += coin [ i ]\n    return ans\n", "COUNT_SUBARRAYS_TOTAL_DISTINCT_ELEMENTS_ORIGINAL_ARRAY": "def countDistictSubarray ( arr , n ) :\n    vis = dict ( )\n    for i in range ( n ) :\n        vis [ arr [ i ] ] = 1\n    k = len ( vis )\n    vid = dict ( )\n    ans = 0\n    right = 0\n    window = 0\n    for left in range ( n ) :\n        while ( right < n and window < k ) :\n            if arr [ right ] in vid.keys ( ) :\n                vid [ arr [ right ] ] += 1\n            else :\n                vid [ arr [ right ] ] = 1\n            if ( vid [ arr [ right ] ] == 1 ) :\n                window += 1\n            right += 1\n        if ( window == k ) :\n            ans += ( n - right + 1 )\n        vid [ arr [ left ] ] -= 1\n        if ( vid [ arr [ left ] ] == 0 ) :\n            window -= 1\n    return ans\n", "FIND_POSSIBLE_ROTATE_PAGE_ANGLE_NOT": "def possibleOrNot ( a1 , a2 , b1 , b2 , c1 , c2 ) :\n    dis1 = ( pow ( b1 - a1 , 2 ) + pow ( b2 - a2 , 2 ) )\n    dis2 = ( pow ( c1 - b1 , 2 ) + pow ( c2 - b2 , 2 ) )\n    if ( dis1 != dis2 ) :\n        print ( \"No\" )\n    elif ( b1 == ( ( a1 + c1 ) // 2.0 ) and b2 == ( ( a2 + c2 ) // 2.0 ) ) :\n        print ( \"No\" )\n    else :\n        print ( \"Yes\" )\n", "TIME_MEET_ANIMALS": "def timeToMeet ( s , v ) :\n    V = 3 * v / 2 ;\n    time = s / V ;\n    print ( time ) ;\n", "BRESENHAMS_LINE_GENERATION_ALGORITHM": "def bresenham ( x1 , y1 , x2 , y2 ) :\n    m_new = 2 * ( y2 - y1 )\n    slope_error_new = m_new - ( x2 - x1 )\n    y = y1\n    for x in range ( x1 , x2 + 1 ) :\n        print ( \"(\" , x , \",\" , y , \")\\n\" )\n        slope_error_new = slope_error_new + m_new\n        if ( slope_error_new >= 0 ) :\n            y = y + 1\n            slope_error_new = slope_error_new - 2 * ( x2 - x1 )\n", "MAXIMUM_NUMBER_CHOCOLATES_DISTRIBUTED_EQUALLY_AMONG_K_STUDENTS": "def maxNumOfChocolates ( arr , n , k ) :\n    um , curr_rem , maxSum = { } , 0 , 0\n    sm = [ 0 ] * n\n    sm [ 0 ] = arr [ 0 ]\n    for i in range ( 1 , n ) :\n        sm [ i ] = sm [ i - 1 ] + arr [ i ]\n    for i in range ( n ) :\n        curr_rem = sm [ i ] % k\n        if ( not curr_rem and maxSum < sm [ i ] ) :\n            maxSum = sm [ i ]\n        elif ( not curr_rem in um ) :\n            um [ curr_rem ] = i\n        elif ( maxSum < ( sm [ i ] - sm [ um [ curr_rem ] ] ) ) :\n            maxSum = sm [ i ] - sm [ um [ curr_rem ] ]\n    return maxSum // k\n", "CHECK_TWO_STRINGS_K_ANAGRAMS_NOT_1": "def areKAnagrams ( str1 , str2 , k ) :\n    n = len ( str1 ) ;\n    if ( len ( str2 ) != n ) :\n        return False ;\n    hash_str1 = [ 0 ] * ( MAX_CHAR ) ;\n    for i in range ( n ) :\n        hash_str1 [ ord ( str1 [ i ] ) - ord ( 'a' ) ] += 1 ;\n    count = 0 ;\n    for i in range ( n ) :\n        if ( hash_str1 [ ord ( str2 [ i ] ) - ord ( 'a' ) ] > 0 ) :\n            hash_str1 [ ord ( str2 [ i ] ) - ord ( 'a' ) ] -= 1 ;\n        else :\n            count += 1 ;\n        if ( count > k ) :\n            return False ;\n    return True ;\n", "DIVISIBILITY_CHECK": "def divisibilityCheck ( arr , n ) :\n    s = dict ( )\n    max_ele = - 10 ** 9\n    for i in range ( n ) :\n        s [ arr [ i ] ] = 1\n        max_ele = max ( max_ele , arr [ i ] )\n    res = dict ( )\n    for i in range ( n ) :\n        if ( arr [ i ] != 0 ) :\n            for j in range ( arr [ i ] * 2 , max_ele + 1 , arr [ i ] ) :\n                if ( j in s.keys ( ) ) :\n                    res [ j ] = 1\n    for x in res :\n        print ( x , end = \" \" )\n", "MAXIMUM_LENGTH_PREFIX_ONE_STRING_OCCURS_SUBSEQUENCE_ANOTHER": "def maxPrefix ( s , t ) :\n    count = 0\n    for i in range ( 0 , len ( t ) ) :\n        if ( count == len ( s ) ) :\n            break\n        if ( t [ i ] == s [ count ] ) :\n            count = count + 1\n    return count\n", "COUNT_DISTINCT_ELEMENTS_IN_EVERY_WINDOW_OF_SIZE_K": "def countDistinct ( arr , k , n ) :\n    mp = defaultdict ( lambda : 0 )\n    dist_count = 0\n    for i in range ( k ) :\n        if mp [ arr [ i ] ] == 0 :\n            dist_count += 1\n        mp [ arr [ i ] ] += 1\n    print ( dist_count )\n    for i in range ( k , n ) :\n        if mp [ arr [ i - k ] ] == 1 :\n            dist_count -= 1\n        mp [ arr [ i - k ] ] -= 1\n        if mp [ arr [ i ] ] == 0 :\n            dist_count += 1\n        mp [ arr [ i ] ] += 1\n        print ( dist_count )\n", "LCS_FORMED_CONSECUTIVE_SEGMENTS_LEAST_LENGTH_K": "def longestSubsequenceCommonSegment ( k , s1 , s2 ) :\n    n = len ( s1 )\n    m = len ( s2 )\n    lcs = [ [ 0 for x in range ( m + 1 ) ] for y in range ( n + 1 ) ]\n    cnt = [ [ 0 for x in range ( m + 1 ) ] for y in range ( n + 1 ) ]\n    for i in range ( 1 , n + 1 ) :\n        for j in range ( 1 , m + 1 ) :\n            lcs [ i ] [ j ] = max ( lcs [ i - 1 ] [ j ] , lcs [ i ] [ j - 1 ] )\n            if ( s1 [ i - 1 ] == s2 [ j - 1 ] ) :\n                cnt [ i ] [ j ] = cnt [ i - 1 ] [ j - 1 ] + 1 ;\n            if ( cnt [ i ] [ j ] >= k ) :\n                for a in range ( k , cnt [ i ] [ j ] + 1 ) :\n                    lcs [ i ] [ j ] = max ( lcs [ i ] [ j ] , lcs [ i - a ] [ j - a ] + a )\n    return lcs [ n ] [ m ]\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY_1": "def printDistinct ( arr , n ) :\n    arr.sort ( ) ;\n    for i in range ( n ) :\n        if ( i < n - 1 and arr [ i ] == arr [ i + 1 ] ) :\n            while ( i < n - 1 and ( arr [ i ] == arr [ i + 1 ] ) ) :\n                i += 1 ;\n        else :\n            print ( arr [ i ] , end = \" \" ) ;\n", "PRIMALITY_TEST_SET_5USING_LUCAS_LEHMER_SERIES": "def isPrime ( p ) :\n    checkNumber = 2 ** p - 1\n    nextval = 4 % checkNumber\n    for i in range ( 1 , p - 1 ) :\n        nextval = ( nextval * nextval - 2 ) % checkNumber\n    if ( nextval == 0 ) : return True\n    else : return False\n", "KTH_NON_REPEATING_CHARACTER": "def kthNonRepeating ( str , k ) :\n    n = len ( str )\n    count = [ 0 ] * MAX_CHAR\n    index = [ 0 ] * MAX_CHAR\n    for i in range ( MAX_CHAR ) :\n        count [ i ] = 0\n        index [ i ] = n\n    for i in range ( n ) :\n        x = str [ i ]\n        count [ ord ( x ) ] += 1\n        if ( count [ ord ( x ) ] == 1 ) :\n            index [ ord ( x ) ] = i\n        if ( count [ ord ( x ) ] == 2 ) :\n            index [ ord ( x ) ] = n\n    index.sort ( )\n    return index [ k - 1 ] if ( index [ k - 1 ] != n ) else - 1\n", "FIRST_UPPERCASE_LETTER_IN_A_STRING_ITERATIVE_AND_RECURSIVE": "def first ( str ) :\n    for i in range ( 0 , len ( str ) ) :\n        if ( str [ i ].istitle ( ) ) :\n            return str [ i ]\n    return 0\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND": "def isSubSequence ( string1 , string2 , m , n ) :\n    if m == 0 : return True\n    if n == 0 : return False\n    if string1 [ m - 1 ] == string2 [ n - 1 ] :\n        return isSubSequence ( string1 , string2 , m - 1 , n - 1 )\n    return isSubSequence ( string1 , string2 , m , n - 1 )\n", "C_PROGRAM_FIND_LARGEST_ELEMENT_ARRAY_1": "def largest ( arr , n ) :\n    return max ( arr )\n", "DIFFERENCE_BETWEEN_HIGHEST_AND_LEAST_FREQUENCIES_IN_AN_ARRAY": "def findDiff ( arr , n ) :\n    arr.sort ( )\n    count = 0 ; max_count = 0 ; min_count = n\n    for i in range ( 0 , ( n - 1 ) ) :\n        if arr [ i ] == arr [ i + 1 ] :\n            count += 1\n            continue\n        else :\n            max_count = max ( max_count , count )\n            min_count = min ( min_count , count )\n            count = 0\n    return max_count - min_count\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER": "def factorial ( n ) :\n    return 1 if ( n == 1 or n == 0 ) else n * factorial ( n - 1 ) ;\n"}