{"MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING": "int maximumChars ( string & str ) {\n  int n = str . length ( );\n  int res = - 1;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( str [ i ] == str [ j ] ) res = max ( res, abs ( j - i - 1 ) );\n  return res;\n}\n", "FIND_MIRROR_IMAGE_POINT_2_D_PLANE": "pair < double, double > mirrorImage ( double a, double b, double c, double x1, double y1 ) {\n  double temp = - 2 * ( a * x1 + b * y1 + c ) / ( a * a + b * b );\n  double x = temp * a + x1;\n  double y = temp * b + y1;\n  return make_pair ( x, y );\n}\n", "EFFICIENTLY_COMPUTE_SUMS_OF_DIAGONALS_OF_A_MATRIX": "void printDiagonalSums ( int mat [ ] [ MAX ], int n ) {\n  int principal = 0, secondary = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( i == j ) principal += mat [ i ] [ j ];\n      if ( ( i + j ) == ( n - 1 ) ) secondary += mat [ i ] [ j ];\n    }\n  }\n  cout << \"Principal Diagonal:\" << principal << endl;\n  cout << \"Secondary Diagonal:\" << secondary << endl;\n}\n", "COUNTS_PATHS_POINT_REACH_ORIGIN": "int countPaths ( int n, int m ) {\n  if ( n == 0 || m == 0 ) return 1;\n  return ( countPaths ( n - 1, m ) + countPaths ( n, m - 1 ) );\n}\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE_1": "bool find3Numbers ( int A [ ], int arr_size, int sum ) {\n  int l, r;\n  sort ( A, A + arr_size );\n  for ( int i = 0;\n  i < arr_size - 2;\n  i ++ ) {\n    l = i + 1;\n    r = arr_size - 1;\n    while ( l < r ) {\n      if ( A [ i ] + A [ l ] + A [ r ] == sum ) {\n        printf ( \"Triplet is %d, %d, %d\", A [ i ], A [ l ], A [ r ] );\n        return true;\n      }\n      else if ( A [ i ] + A [ l ] + A [ r ] < sum ) l ++;\n      else r --;\n    }\n  }\n  return false;\n}\n", "CHECK_GIVEN_MATRIX_IS_MAGIC_SQUARE_OR_NOT": "bool isMagicSquare ( int mat [ ] [ N ] ) {\n  int sum = 0, sum2 = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) sum = sum + mat [ i ] [ i ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) sum2 = sum2 + mat [ i ] [ N - 1 - i ];\n  if ( sum != sum2 ) return false;\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    int rowSum = 0;\n    for ( int j = 0;\n    j < N;\n    j ++ ) rowSum += mat [ i ] [ j ];\n    if ( rowSum != sum ) return false;\n  }\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    int colSum = 0;\n    for ( int j = 0;\n    j < N;\n    j ++ ) colSum += mat [ j ] [ i ];\n    if ( sum != colSum ) return false;\n  }\n  return true;\n}\n", "SEQUENCES_GIVEN_LENGTH_EVERY_ELEMENT_EQUAL_TWICE_PREVIOUS_1": "int getTotalNumberOfSequences ( int m, int n ) {\n  int T [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i < m + 1;\n  i ++ ) {\n    for ( int j = 0;\n    j < n + 1;\n    j ++ ) {\n      if ( i == 0 || j == 0 ) T [ i ] [ j ] = 0;\n      else if ( i < j ) T [ i ] [ j ] = 0;\n      else if ( j == 1 ) T [ i ] [ j ] = i;\n      else T [ i ] [ j ] = T [ i - 1 ] [ j ] + T [ i / 2 ] [ j - 1 ];\n    }\n  }\n  return T [ m ] [ n ];\n}\n", "FIND_DIFFERENCE_BETWEEN_SUMS_OF_TWO_DIAGONALS_1": "int difference ( int arr [ ] [ MAX ], int n ) {\n  int d1 = 0, d2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    d1 += arr [ i ] [ i ];\n    d2 += arr [ i ] [ n - i - 1 ];\n  }\n  return abs ( d1 - d2 );\n}\n", "MINIMUM_NUMBER_SUBSETS_DISTINCT_ELEMENTS": "int subset ( int ar [ ], int n ) {\n  int res = 0;\n  sort ( ar, ar + n );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int count = 1;\n    for (;\n    i < n - 1;\n    i ++ ) {\n      if ( ar [ i ] == ar [ i + 1 ] ) count ++;\n      else break;\n    }\n    res = max ( res, count );\n  }\n  return res;\n}\n", "DECIMAL_BINARY_CONVERSION_WITHOUT_USING_ARITHMETIC_OPERATORS": "string decToBin ( int n ) {\n  if ( n == 0 ) return \"0\";\n  string bin = \"\";\n  while ( n > 0 ) {\n    bin = ( ( n & 1 ) == 0 ? '0' : '1' ) + bin;\n    n >>= 1;\n  }\n  return bin;\n}\n", "FIND_NTH_TERM_DRAGON_CURVE_SEQUENCE": "string Dragon_Curve_Sequence ( int n ) {\n  string s = \"1\";\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    string temp = \"1\";\n    char prev = '1', zero = '0', one = '1';\n    for ( int j = 0;\n    j < s . length ( );\n    j ++ ) {\n      temp += s [ j ];\n      if ( prev == '0' ) {\n        temp += one;\n        prev = one;\n      }\n      else {\n        temp += zero;\n        prev = zero;\n      }\n    }\n    s = temp;\n  }\n  return s;\n}\n", "STACK_SET_3_REVERSE_STRING_USING_STACK": "void reverse ( char str [ ] ) {\n  int n = strlen ( str ), i;\n  for ( i = 0;\n  i < n / 2;\n  i ++ ) swap ( & str [ i ], & str [ n - i - 1 ] );\n}\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER_1": "void bitonicGenerator ( int arr [ ], int n ) {\n  int i = 1;\n  int j = n - 1;\n  if ( j % 2 != 0 ) j --;\n  while ( i < j ) {\n    swap ( arr [ i ], arr [ j ] );\n    i += 2;\n    j -= 2;\n  }\n  sort ( arr, arr + ( n + 1 ) / 2 );\n  sort ( arr + ( n + 1 ) / 2, arr + n, greater < int > ( ) );\n}\n", "GIVEN_TWO_NUMBERS_B_FIND_X_X_B": "void modularEquation ( int a, int b ) {\n  if ( a < b ) {\n    cout << \"No solution possible \" << endl;\n    return;\n  }\n  if ( a == b ) {\n    cout << \"Infinite Solution possible \" << endl;\n    return;\n  }\n  int count = 0;\n  int n = a - b;\n  int y = sqrt ( a - b );\n  for ( int i = 1;\n  i <= y;\n  ++ i ) {\n    if ( n % i == 0 ) {\n      if ( n / i > b ) count ++;\n      if ( i > b ) count ++;\n    }\n  }\n  if ( y * y == n && y > b ) count --;\n  cout << count << endl;\n}\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME": "bool canFormPalindrome ( string str ) {\n  int count [ NO_OF_CHARS ] = {\n    0 };\n    for ( int i = 0;\n    str [ i ];\n    i ++ ) count [ str [ i ] ] ++;\n    int odd = 0;\n    for ( int i = 0;\n    i < NO_OF_CHARS;\n    i ++ ) {\n      if ( count [ i ] & 1 ) odd ++;\n      if ( odd > 1 ) return false;\n    }\n    return true;\n  }\n  ", "MAXIMUM_TRIPLET_SUM_ARRAY_1": "int maxTripletSum ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  return arr [ n - 1 ] + arr [ n - 2 ] + arr [ n - 3 ];\n}\n", "FIND_MEDIAN_ROW_WISE_SORTED_MATRIX": "int binaryMedian ( int m [ ] [ MAX ], int r, int c ) {\n  int min = INT_MAX, max = INT_MIN;\n  for ( int i = 0;\n  i < r;\n  i ++ ) {\n    if ( m [ i ] [ 0 ] < min ) min = m [ i ] [ 0 ];\n    if ( m [ i ] [ c - 1 ] > max ) max = m [ i ] [ c - 1 ];\n  }\n  int desired = ( r * c + 1 ) / 2;\n  while ( min < max ) {\n    int mid = min + ( max - min ) / 2;\n    int place = 0;\n    for ( int i = 0;\n    i < r;\n    ++ i ) place += upper_bound ( m [ i ], m [ i ] + c, mid ) - m [ i ];\n    if ( place < desired ) min = mid + 1;\n    else max = mid;\n  }\n  return min;\n}\n", "HEIGHT_N_ARY_TREE_PARENT_ARRAY_GIVEN": "int findHeight ( int * parent, int n ) {\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int p = i, current = 1;\n    while ( parent [ p ] != - 1 ) {\n      current ++;\n      p = parent [ p ];\n    }\n    res = max ( res, current );\n  }\n  return res;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_20": "bool divisibleBy20 ( string num ) {\n  int lastTwoDigits = stoi ( num . substr ( num . length ( ) - 2, num . length ( ) - 1 ) );\n  return ( ( lastTwoDigits % 5 == 0 ) && ( lastTwoDigits % 4 == 0 ) );\n}\n", "MAXIMUM_VALUE_CHOICE_EITHER_DIVIDING_CONSIDERING": "int maxDP ( int n ) {\n  int res [ n + 1 ];\n  res [ 0 ] = 0;\n  res [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) res [ i ] = max ( i, ( res [ i / 2 ] + res [ i / 3 ] + res [ i / 4 ] + res [ i / 5 ] ) );\n  return res [ n ];\n}\n", "QUERIES_ON_ARRAY_WITH_DISAPPEARING_AND_REAPPEARING_ELEMENTS": "void PerformQueries ( vector < int > & a, vector < pair < long long, int > > & vec ) {\n  vector < int > ans;\n  int n = ( int ) a . size ( ) - 1;\n  int q = ( int ) vec . size ( );\n  for ( int i = 0;\n  i < q;\n  ++ i ) {\n    long long t = vec [ i ] . first;\n    int m = vec [ i ] . second;\n    if ( m > n ) {\n      ans . push_back ( - 1 );\n      continue;\n    }\n    int turn = t / n;\n    int rem = t % n;\n    if ( rem == 0 and turn % 2 == 1 ) {\n      ans . push_back ( - 1 );\n      continue;\n    }\n    if ( rem == 0 and turn % 2 == 0 ) {\n      ans . push_back ( a [ m ] );\n      continue;\n    }\n    if ( turn % 2 == 0 ) {\n      int cursize = n - rem;\n      if ( cursize < m ) {\n        ans . push_back ( - 1 );\n        continue;\n      }\n      ans . push_back ( a [ m + rem ] );\n    }\n    else {\n      int cursize = rem;\n      if ( cursize < m ) {\n        ans . push_back ( - 1 );\n        continue;\n      }\n      ans . push_back ( a [ m ] );\n    }\n  }\n  for ( int i : ans ) cout << i << \"\\n\";\n}\n", "FIND_THE_MINIMUM_DISTANCE_BETWEEN_TWO_NUMBERS_1": "int minDist ( int arr [ ], int n, int x, int y ) {\n  int i = 0;\n  int min_dist = INT_MAX;\n  int prev;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == x || arr [ i ] == y ) {\n      prev = i;\n      break;\n    }\n  }\n  for (;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == x || arr [ i ] == y ) {\n      if ( arr [ prev ] != arr [ i ] && ( i - prev ) < min_dist ) {\n        min_dist = i - prev;\n        prev = i;\n      }\n      else prev = i;\n    }\n  }\n  return min_dist;\n}\n", "UNION_AND_INTERSECTION_OF_TWO_SORTED_ARRAYS_2": "int printUnion ( int arr1 [ ], int arr2 [ ], int m, int n ) {\n  int i = 0, j = 0;\n  while ( i < m && j < n ) {\n    if ( arr1 [ i ] < arr2 [ j ] ) cout << arr1 [ i ++ ] << \" \";\n    else if ( arr2 [ j ] < arr1 [ i ] ) cout << arr2 [ j ++ ] << \" \";\n    else {\n      cout << arr2 [ j ++ ] << \" \";\n      i ++;\n    }\n  }\n  while ( i < m ) cout << arr1 [ i ++ ] << \" \";\n  while ( j < n ) cout << arr2 [ j ++ ] << \" \";\n}\n", "WORD_WRAP_PROBLEM_SPACE_OPTIMIZED_SOLUTION": "void solveWordWrap ( int arr [ ], int n, int k ) {\n  int i, j;\n  int currlen;\n  int cost;\n  int dp [ n ];\n  int ans [ n ];\n  dp [ n - 1 ] = 0;\n  ans [ n - 1 ] = n - 1;\n  for ( i = n - 2;\n  i >= 0;\n  i -- ) {\n    currlen = - 1;\n    dp [ i ] = INT_MAX;\n    for ( j = i;\n    j < n;\n    j ++ ) {\n      currlen += ( arr [ j ] + 1 );\n      if ( currlen > k ) break;\n      if ( j == n - 1 ) cost = 0;\n      else cost = ( k - currlen ) * ( k - currlen ) + dp [ j + 1 ];\n      if ( cost < dp [ i ] ) {\n        dp [ i ] = cost;\n        ans [ i ] = j;\n      }\n    }\n  }\n  i = 0;\n  while ( i < n ) {\n    cout << i + 1 << \" \" << ans [ i ] + 1 << \" \";\n    i = ans [ i ] + 1;\n  }\n}\n", "COUNT_DISTINCT_SUBSEQUENCES": "int countSub ( string str ) {\n  vector < int > last ( MAX_CHAR, - 1 );\n  int n = str . length ( );\n  int dp [ n + 1 ];\n  dp [ 0 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    dp [ i ] = 2 * dp [ i - 1 ];\n    if ( last [ str [ i - 1 ] ] != - 1 ) dp [ i ] = dp [ i ] - dp [ last [ str [ i - 1 ] ] ];\n    last [ str [ i - 1 ] ] = ( i - 1 );\n  }\n  return dp [ n ];\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_3": "int findLength ( string str, int n ) {\n  int ans = 0;\n  for ( int i = 0;\n  i <= n - 2;\n  i ++ ) {\n    int l = i, r = i + 1;\n    int lsum = 0, rsum = 0;\n    while ( r < n && l >= 0 ) {\n      lsum += str [ l ] - '0';\n      rsum += str [ r ] - '0';\n      if ( lsum == rsum ) ans = max ( ans, r - l + 1 );\n      l --;\n      r ++;\n    }\n  }\n  return ans;\n}\n", "MAXIMUM_PATH_SUM_MATRIX": "int findMaxPath ( int mat [ ] [ M ] ) {\n  for ( int i = 1;\n  i < N;\n  i ++ ) {\n    for ( int j = 0;\n    j < M;\n    j ++ ) {\n      if ( j > 0 && j < M - 1 ) mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ], max ( mat [ i - 1 ] [ j - 1 ], mat [ i - 1 ] [ j + 1 ] ) );\n      else if ( j > 0 ) mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ], mat [ i - 1 ] [ j - 1 ] );\n      else if ( j < M - 1 ) mat [ i ] [ j ] += max ( mat [ i - 1 ] [ j ], mat [ i - 1 ] [ j + 1 ] );\n    }\n  }\n  int res = 0;\n  for ( int j = 0;\n  j < M;\n  j ++ ) res = max ( mat [ N - 1 ] [ j ], res );\n  return res;\n}\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING": "char maxRepeating ( string str ) {\n  int len = str . length ( );\n  int count = 0;\n  char res = str [ 0 ];\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    int cur_count = 1;\n    for ( int j = i + 1;\n    j < len;\n    j ++ ) {\n      if ( str [ i ] != str [ j ] ) break;\n      cur_count ++;\n    }\n    if ( cur_count > count ) {\n      count = cur_count;\n      res = str [ i ];\n    }\n  }\n  return res;\n}\n", "MAXIMUM_LENGTH_SUBSEQUENCE_DIFFERENCE_ADJACENT_ELEMENTS_EITHER_0_1": "int maxLenSub ( int arr [ ], int n ) {\n  int mls [ n ], max = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mls [ i ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < i;\n  j ++ ) if ( abs ( arr [ i ] - arr [ j ] ) <= 1 && mls [ i ] < mls [ j ] + 1 ) mls [ i ] = mls [ j ] + 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( max < mls [ i ] ) max = mls [ i ];\n  return max;\n}\n", "BREAKING_NUMBER_FIRST_PART_INTEGRAL_DIVISION_SECOND_POWER_10": "int calculate ( string N ) {\n  int len = N . length ( );\n  int l = ( len ) / 2;\n  int count = 0;\n  for ( int i = 1;\n  i <= l;\n  i ++ ) {\n    string s = N . substr ( 0, i );\n    int l1 = s . length ( );\n    string t = N . substr ( i, l1 );\n    if ( s [ 0 ] == '0' || t [ 0 ] == '0' ) continue;\n    if ( s . compare ( t ) == 0 ) count ++;\n  }\n  return count;\n}\n", "PROGRAM_BINARY_DECIMAL_CONVERSION": "int binaryToDecimal ( int n ) {\n  int num = n;\n  int dec_value = 0;\n  int base = 1;\n  int temp = num;\n  while ( temp ) {\n    int last_digit = temp % 10;\n    temp = temp / 10;\n    dec_value += last_digit * base;\n    base = base * 2;\n  }\n  return dec_value;\n}\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT": "public : int getSum ( int n ) {\n  int sum = 0;\n  while ( n != 0 ) {\n    sum = sum + n % 10;\n    n = n / 10;\n  }\n  return sum;\n}\n", "FIND_N_TH_ELEMENT_FROM_STERNS_DIATOMIC_SERIES": "int findSDSFunc ( int n ) {\n  int DP [ n + 1 ];\n  DP [ 0 ] = 0;\n  DP [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    if ( i % 2 == 0 ) DP [ i ] = DP [ i / 2 ];\n    else DP [ i ] = DP [ ( i - 1 ) / 2 ] + DP [ ( i + 1 ) / 2 ];\n  }\n  return DP [ n ];\n}\n", "NUMBER_SINK_NODES_GRAPH": "int countSink ( int n, int m, int edgeFrom [ ], int edgeTo [ ] ) {\n  int mark [ n ];\n  memset ( mark, 0, sizeof mark );\n  for ( int i = 0;\n  i < m;\n  i ++ ) mark [ edgeFrom [ i ] ] = 1;\n  int count = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) if ( ! mark [ i ] ) count ++;\n  return count;\n}\n", "BREAK_NUMBER_THREE_PARTS": "ll count_of_ways ( ll n ) {\n  ll count = 0;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) for ( int j = 0;\n  j <= n;\n  j ++ ) for ( int k = 0;\n  k <= n;\n  k ++ ) if ( i + j + k == n ) count ++;\n  return count;\n}\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY": "void printDistinct ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < i;\n    j ++ ) if ( arr [ i ] == arr [ j ] ) break;\n    if ( i == j ) cout << arr [ i ] << \" \";\n  }\n}\n", "MAXIMUM_NUMBER_SEGMENTS_LENGTHS_B_C": "int maximumSegments ( int n, int a, int b, int c ) {\n  int dp [ n + 1 ];\n  memset ( dp, - 1, sizeof ( dp ) );\n  dp [ 0 ] = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( dp [ i ] != - 1 ) {\n      if ( i + a <= n ) dp [ i + a ] = max ( dp [ i ] + 1, dp [ i + a ] );\n      if ( i + b <= n ) dp [ i + b ] = max ( dp [ i ] + 1, dp [ i + b ] );\n      if ( i + c <= n ) dp [ i + c ] = max ( dp [ i ] + 1, dp [ i + c ] );\n    }\n  }\n  return dp [ n ];\n}\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M": "bool isPossible ( int n, int index, int sum, int M, int arr [ ], int dp [ ] [ MAX ] ) {\n  if ( index == n ) {\n    if ( ( sum % M ) == 0 ) return true;\n    return false;\n  }\n  if ( dp [ index ] [ sum ] != - 1 ) return dp [ index ] [ sum ];\n  bool placeAdd = isPossible ( n, index + 1, sum + arr [ index ], M, arr, dp );\n  bool placeMinus = isPossible ( n, index + 1, sum - arr [ index ], M, arr, dp );\n  bool res = ( placeAdd || placeMinus );\n  dp [ index ] [ sum ] = res;\n  return res;\n}\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY": "int findGreatest ( int arr [ ], int n ) {\n  int result = - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < n - 1;\n  j ++ ) for ( int k = j + 1;\n  k < n;\n  k ++ ) if ( arr [ j ] * arr [ k ] == arr [ i ] ) result = max ( result, arr [ i ] );\n  return result;\n}\n", "MAXIMUM_SUBARRAY_SUM_ARRAY_CREATED_REPEATED_CONCATENATION": "int maxSubArraySumRepeated ( int a [ ], int n, int k ) {\n  int max_so_far = INT_MIN, max_ending_here = 0;\n  for ( int i = 0;\n  i < n * k;\n  i ++ ) {\n    max_ending_here = max_ending_here + a [ i % n ];\n    if ( max_so_far < max_ending_here ) max_so_far = max_ending_here;\n    if ( max_ending_here < 0 ) max_ending_here = 0;\n  }\n  return max_so_far;\n}\n", "LEONARDO_NUMBER_1": "int leonardo ( int n ) {\n  int dp [ n + 1 ];\n  dp [ 0 ] = dp [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) dp [ i ] = dp [ i - 1 ] + dp [ i - 2 ] + 1;\n  return dp [ n ];\n}\n", "SUM_OF_ALL_SUBSTRINGS_OF_A_STRING_REPRESENTING_A_NUMBER": "int sumOfSubstrings ( string num ) {\n  int n = num . length ( );\n  int sumofdigit [ n ];\n  sumofdigit [ 0 ] = toDigit ( num [ 0 ] );\n  int res = sumofdigit [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int numi = toDigit ( num [ i ] );\n    sumofdigit [ i ] = ( i + 1 ) * numi + 10 * sumofdigit [ i - 1 ];\n    res += sumofdigit [ i ];\n  }\n  return res;\n}\n", "PRUFER_CODE_TREE_CREATION": "void printTreeEdges ( int prufer [ ], int m ) {\n  int vertices = m + 2;\n  int vertex_set [ vertices ];\n  for ( int i = 0;\n  i < vertices;\n  i ++ ) vertex_set [ i ] = 0;\n  for ( int i = 0;\n  i < vertices - 2;\n  i ++ ) vertex_set [ prufer [ i ] - 1 ] += 1;\n  cout << \"\\nThe edge set E(G) is :\\n\";\n  int j = 0;\n  for ( int i = 0;\n  i < vertices - 2;\n  i ++ ) {\n    for ( j = 0;\n    j < vertices;\n    j ++ ) {\n      if ( vertex_set [ j ] == 0 ) {\n        vertex_set [ j ] = - 1;\n        cout << \"(\" << ( j + 1 ) << \", \" << prufer [ i ] << \")  \";\n        vertex_set [ prufer [ i ] - 1 ] --;\n        break;\n      }\n    }\n  }\n  j = 0;\n  for ( int i = 0;\n  i < vertices;\n  i ++ ) {\n    if ( vertex_set [ i ] == 0 && j == 0 ) {\n      cout << \"(\" << ( i + 1 ) << \", \";\n      j ++;\n    }\n    else if ( vertex_set [ i ] == 0 && j == 1 ) cout << ( i + 1 ) << \")\\n\";\n  }\n}\n", "PROGRAM_FIND_SMALLEST_DIFFERENCE_ANGLES_TWO_PARTS_GIVEN_CIRCLE": "int findMinimumAngle ( int arr [ ], int n ) {\n  int l = 0, sum = 0, ans = 360;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ];\n    while ( sum >= 180 ) {\n      ans = min ( ans, 2 * abs ( 180 - sum ) );\n      sum -= arr [ l ];\n      l ++;\n    }\n    ans = min ( ans, 2 * abs ( 180 - sum ) );\n  }\n  return ans;\n}\n", "FIND_MAXIMUM_AVERAGE_SUBARRAY_OF_K_LENGTH": "int findMaxAverage ( int arr [ ], int n, int k ) {\n  if ( k > n ) return - 1;\n  int * csum = new int [ n ];\n  csum [ 0 ] = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) csum [ i ] = csum [ i - 1 ] + arr [ i ];\n  int max_sum = csum [ k - 1 ], max_end = k - 1;\n  for ( int i = k;\n  i < n;\n  i ++ ) {\n    int curr_sum = csum [ i ] - csum [ i - k ];\n    if ( curr_sum > max_sum ) {\n      max_sum = curr_sum;\n      max_end = i;\n    }\n  }\n  delete [ ] csum;\n  return max_end - k + 1;\n}\n", "SQUARE_PYRAMIDAL_NUMBER_SUM_SQUARES": "int findS ( int s ) {\n  int sum = 0;\n  for ( int n = 1;\n  sum < s;\n  n ++ ) {\n    sum += n * n;\n    if ( sum == s ) return n;\n  }\n  return - 1;\n}\n", "PROGRAM_TO_CALCULATE_AREA_OF_AN_CIRCLE_INSCRIBED_IN_A_SQUARE": "float areaOfInscribedCircle ( float a ) {\n  return ( PI / 4 ) * a * a;\n}\n", "MINIMUM_NUMBER_CHARACTERS_REMOVED_MAKE_BINARY_STRING_ALTERNATE": "void countToMake0lternate ( const string & s ) {\n  int result = 0;\n  for ( int i = 0;\n  i < ( s . length ( ) - 1 );\n  i ++ ) if ( s [ i ] == s [ i + 1 ] ) result ++;\n  return result;\n}\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND": "void findMissing ( int a [ ], int b [ ], int n, int m ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < m;\n    j ++ ) if ( a [ i ] == b [ j ] ) break;\n    if ( j == m ) cout << a [ i ] << \" \";\n  }\n}\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM": "void rearrange ( int arr [ ], int n ) {\n  int temp [ n ];\n  int small = 0, large = n - 1;\n  int flag = true;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( flag ) temp [ i ] = arr [ large -- ];\n    else temp [ i ] = arr [ small ++ ];\n    flag = ! flag;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = temp [ i ];\n}\n", "DYNAMIC_PROGRAMMING_SET_15_LONGEST_BITONIC_SUBSEQUENCE": "int lbs ( int arr [ ], int n ) {\n  int i, j;\n  int * lis = new int [ n ];\n  for ( i = 0;\n  i < n;\n  i ++ ) lis [ i ] = 1;\n  for ( i = 1;\n  i < n;\n  i ++ ) for ( j = 0;\n  j < i;\n  j ++ ) if ( arr [ i ] > arr [ j ] && lis [ i ] < lis [ j ] + 1 ) lis [ i ] = lis [ j ] + 1;\n  int * lds = new int [ n ];\n  for ( i = 0;\n  i < n;\n  i ++ ) lds [ i ] = 1;\n  for ( i = n - 2;\n  i >= 0;\n  i -- ) for ( j = n - 1;\n  j > i;\n  j -- ) if ( arr [ i ] > arr [ j ] && lds [ i ] < lds [ j ] + 1 ) lds [ i ] = lds [ j ] + 1;\n  int max = lis [ 0 ] + lds [ 0 ] - 1;\n  for ( i = 1;\n  i < n;\n  i ++ ) if ( lis [ i ] + lds [ i ] - 1 > max ) max = lis [ i ] + lds [ i ] - 1;\n  return max;\n}\n", "COUNT_PAIRS_WHOSE_PRODUCTS_EXIST_IN_ARRAY": "int countPairs ( int arr [ ], int n ) {\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int product = arr [ i ] * arr [ j ];\n      for ( int k = 0;\n      k < n;\n      k ++ ) {\n        if ( arr [ k ] == product ) {\n          result ++;\n          break;\n        }\n      }\n    }\n  }\n  return result;\n}\n", "COUNT_SINGLE_NODE_ISOLATED_SUB_GRAPHS_DISCONNECTED_GRAPH": "int compute ( vector < int > graph [ ], int N ) {\n  int count = 0;\n  for ( int i = 1;\n  i <= N;\n  i ++ ) if ( graph [ i ] . size ( ) == 0 ) count ++;\n  return count;\n}\n", "HARDY_RAMANUJAN_THEOREM": "int exactPrimeFactorCount ( int n ) {\n  int count = 0;\n  if ( n % 2 == 0 ) {\n    count ++;\n    while ( n % 2 == 0 ) n = n / 2;\n  }\n  for ( int i = 3;\n  i <= sqrt ( n );\n  i = i + 2 ) {\n    if ( n % i == 0 ) {\n      count ++;\n      while ( n % i == 0 ) n = n / i;\n    }\n  }\n  if ( n > 2 ) count ++;\n  return count;\n}\n", "SHORTEST_COMMON_SUPERSEQUENCE_1": "int superSeq ( char * X, char * Y, int m, int n ) {\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( ! i ) dp [ i ] [ j ] = j;\n      else if ( ! j ) dp [ i ] [ j ] = i;\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) 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    }\n  }\n  return dp [ m ] [ n ];\n}\n", "POWER_SET": "public : void printPowerSet ( char * set, int set_size ) {\n  unsigned int pow_set_size = pow ( 2, set_size );\n  int counter, j;\n  for ( counter = 0;\n  counter < pow_set_size;\n  counter ++ ) {\n    for ( j = 0;\n    j < set_size;\n    j ++ ) {\n      if ( counter & ( 1 << j ) ) cout << set [ j ];\n    }\n    cout << endl;\n  }\n}\n", "CHECK_ARRAY_MAJORITY_ELEMENT": "bool isMajority ( int a [ ], int n ) {\n  unordered_map < int, int > mp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mp [ a [ i ] ] ++;\n  for ( auto x : mp ) if ( x . second >= n / 2 ) return true;\n  return false;\n}\n", "PRINT_GIVEN_MATRIX_COUNTER_CLOCK_WISE_SPIRAL_FORM": "void counterClockspiralPrint ( int m, int n, int arr [ R ] [ C ] ) {\n  int i, k = 0, l = 0;\n  int cnt = 0;\n  int total = m * n;\n  while ( k < m && l < n ) {\n    if ( cnt == total ) break;\n    for ( i = k;\n    i < m;\n    ++ i ) {\n      cout << arr [ i ] [ l ] << \" \";\n      cnt ++;\n    }\n    l ++;\n    if ( cnt == total ) break;\n    for ( i = l;\n    i < n;\n    ++ i ) {\n      cout << arr [ m - 1 ] [ i ] << \" \";\n      cnt ++;\n    }\n    m --;\n    if ( cnt == total ) break;\n    if ( k < m ) {\n      for ( i = m - 1;\n      i >= k;\n      -- i ) {\n        cout << arr [ i ] [ n - 1 ] << \" \";\n        cnt ++;\n      }\n      n --;\n    }\n    if ( cnt == total ) break;\n    if ( l < n ) {\n      for ( i = n - 1;\n      i >= l;\n      -- i ) {\n        cout << arr [ k ] [ i ] << \" \";\n        cnt ++;\n      }\n      k ++;\n    }\n  }\n}\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD": "bool isPrime ( int n ) {\n  if ( n <= 1 ) return false;\n  for ( int i = 2;\n  i < n;\n  i ++ ) if ( n % i == 0 ) return false;\n  return true;\n}\n", "FIND_CHARACTER_FIRST_STRING_PRESENT_MINIMUM_INDEX_SECOND_STRING": "void printMinIndexChar ( string str, string patt ) {\n  int minIndex = INT_MAX;\n  int m = str . size ( );\n  int n = patt . size ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( patt [ i ] == str [ j ] && j < minIndex ) {\n        minIndex = j;\n        break;\n      }\n    }\n  }\n  if ( minIndex != INT_MAX ) cout << \"Minimum Index Character = \" << str [ minIndex ];\n  else cout << \"No character present\";\n}\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX_1": "void transpose ( int A [ ] [ N ], int B [ ] [ M ] ) {\n  int i, j;\n  for ( i = 0;\n  i < N;\n  i ++ ) for ( j = 0;\n  j < M;\n  j ++ ) B [ i ] [ j ] = A [ j ] [ i ];\n}\n", "COUNT_NATURAL_NUMBERS_WHOSE_PERMUTATION_GREATER_NUMBER": "int countNumber ( int n ) {\n  int result = 0;\n  for ( int i = 1;\n  i <= 9;\n  i ++ ) {\n    stack < int > s;\n    if ( i <= n ) {\n      s . push ( i );\n      result ++;\n    }\n    while ( ! s . empty ( ) ) {\n      int tp = s . top ( );\n      s . pop ( );\n      for ( int j = tp % 10;\n      j <= 9;\n      j ++ ) {\n        int x = tp * 10 + j;\n        if ( x <= n ) {\n          s . push ( x );\n          result ++;\n        }\n      }\n    }\n  }\n  return result;\n}\n", "FIND_FIRST_NATURAL_NUMBER_WHOSE_FACTORIAL_DIVISIBLE_X": "int firstFactorialDivisibleNumber ( int x ) {\n  int i = 1;\n  int fact = 1;\n  for ( i = 1;\n  i < x;\n  i ++ ) {\n    fact = fact * i;\n    if ( fact % x == 0 ) break;\n  }\n  return i;\n}\n", "PRINT_EQUAL_SUM_SETS_ARRAY_PARTITION_PROBLEM_SET_2": "void printEqualSumSets ( int arr [ ], int n ) {\n  int i, currSum;\n  int sum = accumulate ( arr, arr + n, 0 );\n  if ( sum & 1 ) {\n    cout << \"-1\";\n    return;\n  }\n  int k = sum >> 1;\n  bool dp [ n + 1 ] [ k + 1 ];\n  for ( i = 1;\n  i <= k;\n  i ++ ) dp [ 0 ] [ i ] = false;\n  for ( i = 0;\n  i <= n;\n  i ++ ) dp [ i ] [ 0 ] = true;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    for ( currSum = 1;\n    currSum <= k;\n    currSum ++ ) {\n      dp [ i ] [ currSum ] = dp [ i - 1 ] [ currSum ];\n      if ( arr [ i - 1 ] <= currSum ) dp [ i ] [ currSum ] = dp [ i ] [ currSum ] | dp [ i - 1 ] [ currSum - arr [ i - 1 ] ];\n    }\n  }\n  vector < int > set1, set2;\n  if ( ! dp [ n ] [ k ] ) {\n    cout << \"-1\\n\";\n    return;\n  }\n  i = n;\n  currSum = k;\n  while ( i > 0 && currSum >= 0 ) {\n    if ( dp [ i - 1 ] [ currSum ] ) {\n      i --;\n      set2 . push_back ( arr [ i ] );\n    }\n    else if ( dp [ i - 1 ] [ currSum - arr [ i - 1 ] ] ) {\n      i --;\n      currSum -= arr [ i ];\n      set1 . push_back ( arr [ i ] );\n    }\n  }\n  cout << \"Set 1 elements: \";\n  for ( i = 0;\n  i < set1 . size ( );\n  i ++ ) cout << set1 [ i ] << \" \";\n  cout << \"\\nSet 2 elements: \";\n  for ( i = 0;\n  i < set2 . size ( );\n  i ++ ) cout << set2 [ i ] << \" \";\n}\n", "COUNTING_PAIRS_PERSON_CAN_FORM_PAIR_ONE_1": "int numberOfWays ( int x ) {\n  int dp [ x + 1 ];\n  dp [ 0 ] = dp [ 1 ] = 1;\n  for ( int i = 2;\n  i <= x;\n  i ++ ) dp [ i ] = dp [ i - 1 ] + ( i - 1 ) * dp [ i - 2 ];\n  return dp [ x ];\n}\n", "COUNT_NEGATIVE_NUMBERS_IN_A_COLUMN_WISE_ROW_WISE_SORTED_MATRIX": "int countNegative ( int M [ ] [ 4 ], int n, int m ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( M [ i ] [ j ] < 0 ) count += 1;\n      else break;\n    }\n  }\n  return count;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER": "unsigned int countSetBits ( unsigned int n ) {\n  unsigned int count = 0;\n  while ( n ) {\n    count += n & 1;\n    n >>= 1;\n  }\n  return count;\n}\n", "MODULUS_TWO_FLOAT_DOUBLE_NUMBERS": "double findMod ( double a, double b ) {\n  double mod;\n  if ( a < 0 ) mod = - a;\n  else mod = a;\n  if ( b < 0 ) b = - b;\n  while ( mod >= b ) mod = mod - b;\n  if ( a < 0 ) return - mod;\n  return mod;\n}\n", "FIND_A_SPECIFIC_PAIR_IN_MATRIX_1": "int findMaxValue ( int mat [ ] [ N ] ) {\n  int maxValue = INT_MIN;\n  int maxArr [ N ] [ N ];\n  maxArr [ N - 1 ] [ N - 1 ] = mat [ N - 1 ] [ N - 1 ];\n  int maxv = mat [ N - 1 ] [ N - 1 ];\n  for ( int j = N - 2;\n  j >= 0;\n  j -- ) {\n    if ( mat [ N - 1 ] [ j ] > maxv ) maxv = mat [ N - 1 ] [ j ];\n    maxArr [ N - 1 ] [ j ] = maxv;\n  }\n  maxv = mat [ N - 1 ] [ N - 1 ];\n  for ( int i = N - 2;\n  i >= 0;\n  i -- ) {\n    if ( mat [ i ] [ N - 1 ] > maxv ) maxv = mat [ i ] [ N - 1 ];\n    maxArr [ i ] [ N - 1 ] = maxv;\n  }\n  for ( int i = N - 2;\n  i >= 0;\n  i -- ) {\n    for ( int j = N - 2;\n    j >= 0;\n    j -- ) {\n      if ( maxArr [ i + 1 ] [ j + 1 ] - mat [ i ] [ j ] > maxValue ) 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    }\n  }\n  return maxValue;\n}\n", "MINIMUM_SUM_TWO_NUMBERS_FORMED_DIGITS_ARRAY": "int solve ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int a = 0, b = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i & 1 ) a = a * 10 + arr [ i ];\n    else b = b * 10 + arr [ i ];\n  }\n  return a + b;\n}\n", "COUNT_DISTINCT_NON_NEGATIVE_PAIRS_X_Y_SATISFY_INEQUALITY_XX_YY_N_2_1": "int countSolutions ( int n ) {\n  int x = 0, yCount, res = 0;\n  for ( yCount = 0;\n  yCount * yCount < n;\n  yCount ++ );\n  while ( yCount != 0 ) {\n    res += yCount;\n    x ++;\n    while ( yCount != 0 && ( x * x + ( yCount - 1 ) * ( yCount - 1 ) >= n ) ) yCount --;\n  }\n  return res;\n}\n", "FIND_INDEX_GIVEN_FIBONACCI_NUMBER_CONSTANT_TIME": "int findIndex ( int n ) {\n  if ( n <= 1 ) return n;\n  int a = 0, b = 1, c = 1;\n  int res = 1;\n  while ( c < n ) {\n    c = a + b;\n    res ++;\n    a = b;\n    b = c;\n  }\n  return res;\n}\n", "PROGRAM_OCTAL_DECIMAL_CONVERSION": "int octalToDecimal ( int n ) {\n  int num = n;\n  int dec_value = 0;\n  int base = 1;\n  int temp = num;\n  while ( temp ) {\n    int last_digit = temp % 10;\n    temp = temp / 10;\n    dec_value += last_digit * base;\n    base = base * 8;\n  }\n  return dec_value;\n}\n", "FIND_PERMUTED_ROWS_GIVEN_ROW_MATRIX": "void permutatedRows ( int mat [ ] [ MAX ], int m, int n, int r ) {\n  unordered_set < int > s;\n  for ( int j = 0;\n  j < n;\n  j ++ ) s . insert ( mat [ r ] [ j ] );\n  for ( int i = 0;\n  i < m;\n  i ++ ) {\n    if ( i == r ) continue;\n    int j;\n    for ( j = 0;\n    j < n;\n    j ++ ) if ( s . find ( mat [ i ] [ j ] ) == s . end ( ) ) break;\n    if ( j != n ) continue;\n    cout << i << \", \";\n  }\n}\n", "PRINT_A_CLOSEST_STRING_THAT_DOES_NOT_CONTAIN_ADJACENT_DUPLICATES": "string noAdjacentDup ( string s ) {\n  int n = s . length ( );\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( s [ i ] == s [ i - 1 ] ) {\n      s [ i ] = 'a';\n      while ( s [ i ] == s [ i - 1 ] || ( i + 1 < n && s [ i ] == s [ i + 1 ] ) ) s [ i ] ++;\n      i ++;\n    }\n  }\n  return s;\n}\n", "SUM_MANHATTAN_DISTANCES_PAIRS_POINTS": "int distancesum ( int x [ ], int y [ ], int n ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) sum += ( abs ( x [ i ] - x [ j ] ) + abs ( y [ i ] - y [ j ] ) );\n  return sum;\n}\n", "PROGRAM_FIND_STRING_START_END_GEEKS": "bool isCornerPresent ( string str, string corner ) {\n  int n = str . length ( );\n  int cl = corner . length ( );\n  if ( n < cl ) return false;\n  return ( str . substr ( 0, cl ) . compare ( corner ) == 0 && str . substr ( n - cl, cl ) . compare ( corner ) == 0 );\n}\n", "LONGEST_SUBARRAY_COUNT_1S_ONE_COUNT_0S": "int lenOfLongSubarr ( int arr [ ], int n ) {\n  unordered_map < int, int > um;\n  int sum = 0, maxLen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ] == 0 ? - 1 : 1;\n    if ( sum == 1 ) maxLen = i + 1;\n    else if ( um . find ( sum ) == um . end ( ) ) um [ sum ] = i;\n    if ( um . find ( sum - 1 ) != um . end ( ) ) {\n      if ( maxLen < ( i - um [ sum - 1 ] ) ) maxLen = i - um [ sum - 1 ];\n    }\n  }\n  return maxLen;\n}\n", "DIVIDE_CONQUER_SET_6_SEARCH_ROW_WISE_COLUMN_WISE_SORTED_2D_ARRAY": "void search ( int mat [ ROW ] [ COL ], int fromRow, int toRow, int fromCol, int toCol, int key ) {\n  int i = fromRow + ( toRow - fromRow ) / 2;\n  int j = fromCol + ( toCol - fromCol ) / 2;\n  if ( mat [ i ] [ j ] == key ) cout << \"Found \" << key << \" at \" << i << \" \" << j << endl;\n  else {\n    if ( i != toRow || j != fromCol ) search ( mat, fromRow, i, j, toCol, key );\n    if ( fromRow == toRow && fromCol + 1 == toCol ) if ( mat [ fromRow ] [ toCol ] == key ) cout << \"Found \" << key << \" at \" << fromRow << \" \" << toCol << endl;\n    if ( mat [ i ] [ j ] < key ) {\n      if ( i + 1 <= toRow ) search ( mat, i + 1, toRow, fromCol, toCol, key );\n    }\n    else {\n      if ( j - 1 >= fromCol ) search ( mat, fromRow, toRow, fromCol, j - 1, key );\n    }\n  }\n}\n", "SHORTEST_COMMON_SUPERSEQUENCE": "int superSeq ( char * X, char * Y, int m, int n ) {\n  if ( ! m ) return n;\n  if ( ! n ) return m;\n  if ( X [ m - 1 ] == Y [ n - 1 ] ) 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}\n", "URLIFY_GIVEN_STRING_REPLACE_SPACES": "int replaceSpaces ( char str [ ] ) {\n  int space_count = 0, i;\n  for ( i = 0;\n  str [ i ];\n  i ++ ) if ( str [ i ] == ' ' ) space_count ++;\n  while ( str [ i - 1 ] == ' ' ) {\n    space_count --;\n    i --;\n  }\n  int new_length = i + space_count * 2 + 1;\n  if ( new_length > MAX ) return - 1;\n  int index = new_length - 1;\n  str [ index -- ] = '\\0';\n  for ( int j = i - 1;\n  j >= 0;\n  j -- ) {\n    if ( str [ j ] == ' ' ) {\n      str [ index ] = '0';\n      str [ index - 1 ] = '2';\n      str [ index - 2 ] = '%';\n      index = index - 3;\n    }\n    else {\n      str [ index ] = str [ j ];\n      index --;\n    }\n  }\n  return new_length;\n}\n", "MAXIMUM_PATH_SUM_STARTING_CELL_0_TH_ROW_ENDING_CELL_N_1_TH_ROW": "int MaximumPath ( int Mat [ ] [ N ] ) {\n  int result = 0;\n  int dp [ N ] [ N + 2 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i < N;\n  i ++ ) dp [ 0 ] [ i + 1 ] = Mat [ 0 ] [ i ];\n  for ( int i = 1;\n  i < N;\n  i ++ ) for ( int j = 1;\n  j <= N;\n  j ++ ) dp [ i ] [ j ] = max ( dp [ i - 1 ] [ j - 1 ], max ( dp [ i - 1 ] [ j ], dp [ i - 1 ] [ j + 1 ] ) ) + Mat [ i ] [ j - 1 ];\n  for ( int i = 0;\n  i <= N;\n  i ++ ) result = max ( result, dp [ N - 1 ] [ i ] );\n  return result;\n}\n", "COMPUTE_THE_INTEGER_ABSOLUTE_VALUE_ABS_WITHOUT_BRANCHING": "unsigned int getAbs ( int n ) {\n  int const mask = n >> ( sizeof ( int ) * CHARBIT - 1 );\n  return ( ( n + mask ) ^ mask );\n}\n", "COUNT_PALINDROMIC_SUBSEQUENCE_GIVEN_STRING_1": "int countPS ( int i, int j ) {\n  if ( i >= n || j < 0 ) return 0;\n  if ( dp [ i ] [ j ] != - 1 ) return dp [ i ] [ j ];\n  if ( abs ( i - j ) == 1 ) {\n    if ( str [ i ] == str [ j ] ) return dp [ i ] [ j ] = 3;\n    else return dp [ i ] [ j ] = 2;\n  }\n  if ( i == j ) return dp [ 1 ] [ j ] = 1;\n  else if ( str [ i ] == str [ j ] ) return dp [ i ] [ j ] = countPS ( i + 1, j ) + countPS ( i, j - 1 ) + 1;\n  else return dp [ i ] [ j ] = countPS ( i + 1, j ) + countPS ( i, j - 1 ) - countPS ( i + 1, j - 1 );\n}\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY_2": "int maxSubArraySum ( int a [ ], int size ) {\n  int max_so_far = a [ 0 ];\n  int curr_max = a [ 0 ];\n  for ( int i = 1;\n  i < size;\n  i ++ ) {\n    curr_max = max ( a [ i ], curr_max + a [ i ] );\n    max_so_far = max ( max_so_far, curr_max );\n  }\n  return max_so_far;\n}\n", "COUNT_MINIMUM_STEPS_GET_GIVEN_DESIRED_ARRAY": "int countMinOperations ( unsigned int target [ ], int n ) {\n  int result = 0;\n  while ( 1 ) {\n    int zero_count = 0;\n    int i;\n    for ( i = 0;\n    i < n;\n    i ++ ) {\n      if ( target [ i ] & 1 ) break;\n      else if ( target [ i ] == 0 ) zero_count ++;\n    }\n    if ( zero_count == n ) return result;\n    if ( i == n ) {\n      for ( int j = 0;\n      j < n;\n      j ++ ) target [ j ] = target [ j ] / 2;\n      result ++;\n    }\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      if ( target [ j ] & 1 ) {\n        target [ j ] --;\n        result ++;\n      }\n    }\n  }\n}\n", "PRINT_FIBONACCI_SEQUENCE_USING_2_VARIABLES_1": "void fib ( int n ) {\n  int a = 0, b = 1;\n  if ( n >= 0 ) cout << a << \" \";\n  if ( n >= 1 ) cout << b << \" \";\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    cout << a + b << \" \";\n    b = a + b;\n    a = b - a;\n  }\n}\n", "PROGRAM_CHECK_INPUT_INTEGER_STRING": "bool isNumber ( string s ) {\n  for ( int i = 0;\n  i < s . length ( );\n  i ++ ) if ( isdigit ( s [ i ] ) == false ) return false;\n  return true;\n}\n", "MINIMUM_HEIGHT_TRIANGLE_GIVEN_BASE_AREA": "int minHeight ( int base, int area ) {\n  return ceil ( ( float ) ( 2 * area ) / base );\n}\n", "FIND_POSITION_GIVEN_NUMBER_AMONG_NUMBERS_MADE_4_7": "int findpos ( string n ) {\n  int i = 0, pos = 0;\n  while ( n [ i ] != '\\0' ) {\n    switch ( n [ i ] ) {\n      case '4' : pos = pos * 2 + 1;\n      break;\n      case '7' : pos = pos * 2 + 2;\n      break;\n    }\n    i ++;\n  }\n  return pos;\n}\n", "MINIMUM_OPERATIONS_REQUIRED_SET_ELEMENTS_BINARY_MATRIX": "int minOperation ( bool arr [ N ] [ M ] ) {\n  int ans = 0;\n  for ( int i = N - 1;\n  i >= 0;\n  i -- ) {\n    for ( int j = M - 1;\n    j >= 0;\n    j -- ) {\n      if ( arr [ i ] [ j ] == 0 ) {\n        ans ++;\n        for ( int k = 0;\n        k <= i;\n        k ++ ) {\n          for ( int h = 0;\n          h <= j;\n          h ++ ) {\n            if ( arr [ k ] [ h ] == 1 ) arr [ k ] [ h ] = 0;\n            else arr [ k ] [ h ] = 1;\n          }\n        }\n      }\n    }\n  }\n  return ans;\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_2": "int findLength ( string str, int n ) {\n  int sum [ n + 1 ];\n  sum [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) sum [ i ] = ( sum [ i - 1 ] + str [ i - 1 ] - '0' );\n  int ans = 0;\n  for ( int len = 2;\n  len <= n;\n  len += 2 ) {\n    for ( int i = 0;\n    i <= n - len;\n    i ++ ) {\n      int j = i + len - 1;\n      if ( sum [ i + len / 2 ] - sum [ i ] == sum [ i + len ] - sum [ i + len / 2 ] ) ans = max ( ans, len );\n    }\n  }\n  return ans;\n}\n", "MULTIPLY_LARGE_NUMBERS_REPRESENTED_AS_STRINGS": "string multiply ( string num1, string num2 ) {\n  int len1 = num1 . size ( );\n  int len2 = num2 . size ( );\n  if ( len1 == 0 || len2 == 0 ) return \"0\";\n  vector < int > result ( len1 + len2, 0 );\n  int i_n1 = 0;\n  int i_n2 = 0;\n  for ( int i = len1 - 1;\n  i >= 0;\n  i -- ) {\n    int carry = 0;\n    int n1 = num1 [ i ] - '0';\n    i_n2 = 0;\n    for ( int j = len2 - 1;\n    j >= 0;\n    j -- ) {\n      int n2 = num2 [ j ] - '0';\n      int sum = n1 * n2 + result [ i_n1 + i_n2 ] + carry;\n      carry = sum / 10;\n      result [ i_n1 + i_n2 ] = sum % 10;\n      i_n2 ++;\n    }\n    if ( carry > 0 ) result [ i_n1 + i_n2 ] += carry;\n    i_n1 ++;\n  }\n  int i = result . size ( ) - 1;\n  while ( i >= 0 && result [ i ] == 0 ) i --;\n  if ( i == - 1 ) return \"0\";\n  string s = \"\";\n  while ( i >= 0 ) s += std :: to_string ( result [ i -- ] );\n  return s;\n}\n", "PARTITION_NUMBER_TWO_DIVISBLE_PARTS": "void findDivision ( string & str, int a, int b ) {\n  int len = str . length ( );\n  vector < int > lr ( len + 1, 0 );\n  lr [ 0 ] = ( str [ 0 ] - '0' ) % a;\n  for ( int i = 1;\n  i < len;\n  i ++ ) lr [ i ] = ( ( lr [ i - 1 ] * 10 ) % a + ( str [ i ] - '0' ) ) % a;\n  vector < int > rl ( len + 1, 0 );\n  rl [ len - 1 ] = ( str [ len - 1 ] - '0' ) % b;\n  int power10 = 10;\n  for ( int i = len - 2;\n  i >= 0;\n  i -- ) {\n    rl [ i ] = ( rl [ i + 1 ] + ( str [ i ] - '0' ) * power10 ) % b;\n    power10 = ( power10 * 10 ) % b;\n  }\n  for ( int i = 0;\n  i < len - 1;\n  i ++ ) {\n    if ( lr [ i ] != 0 ) continue;\n    if ( rl [ i + 1 ] == 0 ) {\n      cout << \"YES\\n\";\n      for ( int k = 0;\n      k <= i;\n      k ++ ) cout << str [ k ];\n      cout << \", \";\n      for ( int k = i + 1;\n      k < len;\n      k ++ ) cout << str [ k ];\n      return;\n    }\n  }\n  cout << \"NO\\n\";\n}\n", "PROGRAM_BEST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "void bestFit ( int blockSize [ ], int m, int processSize [ ], int n ) {\n  int allocation [ n ];\n  memset ( allocation, - 1, sizeof ( allocation ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int bestIdx = - 1;\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( blockSize [ j ] >= processSize [ i ] ) {\n        if ( bestIdx == - 1 ) bestIdx = j;\n        else if ( blockSize [ bestIdx ] > blockSize [ j ] ) bestIdx = j;\n      }\n    }\n    if ( bestIdx != - 1 ) {\n      allocation [ i ] = bestIdx;\n      blockSize [ bestIdx ] -= processSize [ i ];\n    }\n  }\n  cout << \"\\nProcess No.\\tProcess Size\\tBlock no.\\n\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cout << \"   \" << i + 1 << \"\\t\\t\" << processSize [ i ] << \"\\t\\t\";\n    if ( allocation [ i ] != - 1 ) cout << allocation [ i ] + 1;\n    else cout << \"Not Allocated\";\n    cout << endl;\n  }\n}\n", "FINDING_THE_MAXIMUM_SQUARE_SUB_MATRIX_WITH_ALL_EQUAL_ELEMENTS": "int largestKSubmatrix ( int a [ ] [ Col ] ) {\n  int dp [ Row ] [ Col ];\n  memset ( dp, sizeof ( dp ), 0 );\n  int result = 0;\n  for ( int i = 0;\n  i < Row;\n  i ++ ) {\n    for ( int j = 0;\n    j < Col;\n    j ++ ) {\n      if ( i == 0 || j == 0 ) dp [ i ] [ j ] = 1;\n      else {\n        if ( a [ i ] [ j ] == a [ i - 1 ] [ j ] && a [ i ] [ j ] == a [ i ] [ j - 1 ] && a [ i ] [ j ] == a [ i - 1 ] [ j - 1 ] ) dp [ i ] [ j ] = min ( min ( dp [ i - 1 ] [ j ], dp [ i ] [ j - 1 ] ), dp [ i - 1 ] [ j - 1 ] ) + 1;\n        else dp [ i ] [ j ] = 1;\n      }\n      result = max ( result, dp [ i ] [ j ] );\n    }\n  }\n  return result;\n}\n", "FRIENDS_PAIRING_PROBLEM_1": "int countFriendsPairings ( int n ) {\n  if ( dp [ n ] != - 1 ) return dp [ n ];\n  if ( n > 2 ) return dp [ n ] = countFriendsPairings ( n - 1 ) + ( n - 1 ) * countFriendsPairings ( n - 2 );\n  else return dp [ n ] = n;\n}\n", "FIRST_ELEMENT_OCCURRING_K_TIMES_ARRAY": "int firstElement ( int arr [ ], int n, int k ) {\n  unordered_map < int, int > count_map;\n  for ( int i = 0;\n  i < n;\n  i ++ ) count_map [ arr [ i ] ] ++;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( count_map [ arr [ i ] ] == k ) return arr [ i ];\n  return - 1;\n}\n", "SUM_SERIES_0_6_0_06_0_006_0_0006_N_TERMS": "float sumOfSeries ( int n ) {\n  return ( 0.666 ) * ( 1 - 1 / pow ( 10, n ) );\n}\n", "COUNT_WORDS_IN_A_GIVEN_STRING": "unsigned countWords ( char * str ) {\n  int state = OUT;\n  unsigned wc = 0;\n  while ( * str ) {\n    if ( * str == ' ' || * str == '\\n' || * str == '\\t' ) state = OUT;\n    else if ( state == OUT ) {\n      state = IN;\n      ++ wc;\n    }\n    ++ str;\n  }\n  return wc;\n}\n", "PARTITION_INTO_TWO_SUBARRAYS_OF_LENGTHS_K_AND_N_K_SUCH_THAT_THE_DIFFERENCE_OF_SUMS_IS_MAXIMUM": "int maxDifference ( int arr [ ], int N, int k ) {\n  int M, S = 0, S1 = 0, max_difference = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) S += arr [ i ];\n  sort ( arr, arr + N, greater < int > ( ) );\n  M = max ( k, N - k );\n  for ( int i = 0;\n  i < M;\n  i ++ ) S1 += arr [ i ];\n  max_difference = S1 - ( S - S1 );\n  return max_difference;\n}\n", "HOW_WILL_YOU_PRINT_NUMBERS_FROM_1_TO_200_WITHOUT_USING_LOOP": "public : void printNos ( unsigned int n ) {\n  if ( n > 0 ) {\n    printNos ( n - 1 );\n    cout << n << \" \";\n  }\n  return;\n}\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM_1": "int pairsInSortedRotated ( int arr [ ], int n, int x ) {\n  int i;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) if ( arr [ i ] > arr [ i + 1 ] ) break;\n  int l = ( i + 1 ) % n;\n  int r = i;\n  int cnt = 0;\n  while ( l != r ) {\n    if ( arr [ l ] + arr [ r ] == x ) {\n      cnt ++;\n      if ( l == ( r - 1 + n ) % n ) {\n        return cnt;\n      }\n      l = ( l + 1 ) % n;\n      r = ( r - 1 + n ) % n;\n    }\n    else if ( arr [ l ] + arr [ r ] < x ) l = ( l + 1 ) % n;\n    else r = ( n + r - 1 ) % n;\n  }\n  return cnt;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE": "int getSingle ( int arr [ ], int n ) {\n  int ones = 0, twos = 0;\n  int common_bit_mask;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\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  }\n  return ones;\n}\n", "CASSINIS_IDENTITY": "int cassini ( int n ) {\n  return ( n & 1 ) ? - 1 : 1;\n}\n", "DISTRIBUTING_ALL_BALLS_WITHOUT_REPETITION": "bool distributingBalls ( int k, int n, string str ) {\n  int a [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      a [ str [ i ] - 'a' ] ++;\n    }\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) if ( a [ i ] > k ) return false;\n    return true;\n  }\n  ", "DISTRIBUTING_ITEMS_PERSON_CANNOT_TAKE_TWO_ITEMS_TYPE": "bool checkCount ( int arr [ ], int n, int k ) {\n  int count;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    count = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( arr [ j ] == arr [ i ] ) count ++;\n      if ( count > 2 * k ) return false;\n    }\n  }\n  return true;\n}\n", "MAXIMIZE_ARRJ_ARRI_ARRL_ARRK_SUCH_THAT_I_J_K_L": "- 100000000 int findMaxValue ( int arr [ ], int n ) {\n  if ( n < 4 ) {\n    printf ( \"The array should have atlest 4 elements\\n\" );\n    return MIN;\n  }\n  int table1 [ n + 1 ], table2 [ n ], table3 [ n - 1 ], table4 [ n - 2 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) table1 [ i ] = table2 [ i ] = table3 [ i ] = table4 [ i ] = MIN;\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) table1 [ i ] = max ( table1 [ i + 1 ], arr [ i ] );\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) table2 [ i ] = max ( table2 [ i + 1 ], table1 [ i + 1 ] - arr [ i ] );\n  for ( int i = n - 3;\n  i >= 0;\n  i -- ) table3 [ i ] = max ( table3 [ i + 1 ], table2 [ i + 1 ] + arr [ i ] );\n  for ( int i = n - 4;\n  i >= 0;\n  i -- ) table4 [ i ] = max ( table4 [ i + 1 ], table3 [ i + 1 ] - arr [ i ] );\n  return table4 [ 0 ];\n}\n", "COUNT_NEGATIVE_NUMBERS_IN_A_COLUMN_WISE_ROW_WISE_SORTED_MATRIX_1": "int countNegative ( int M [ ] [ 4 ], int n, int m ) {\n  int count = 0;\n  int i = 0;\n  int j = m - 1;\n  while ( j >= 0 && i < n ) {\n    if ( M [ i ] [ j ] < 0 ) {\n      count += j + 1;\n      i += 1;\n    }\n    else j -= 1;\n  }\n  return count;\n}\n", "SORT_AN_ARRAY_OF_0S_1S_AND_2S": "void sort012 ( int a [ ], int arr_size ) {\n  int lo = 0;\n  int hi = arr_size - 1;\n  int mid = 0;\n  while ( mid <= hi ) {\n    switch ( a [ mid ] ) {\n      case 0 : swap ( a [ lo ++ ], a [ mid ++ ] );\n      break;\n      case 1 : mid ++;\n      break;\n      case 2 : swap ( a [ mid ], a [ hi -- ] );\n      break;\n    }\n  }\n}\n", "NTH_EVEN_FIBONACCI_NUMBER": "long int evenFib ( int n ) {\n  if ( n < 1 ) return n;\n  if ( n == 1 ) return 2;\n  return ( ( 4 * evenFib ( n - 1 ) ) + evenFib ( n - 2 ) );\n}\n", "NEXT_GREATER_ELEMENT": "void printNGE ( int arr [ ], int n ) {\n  int next, i, j;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    next = - 1;\n    for ( j = i + 1;\n    j < n;\n    j ++ ) {\n      if ( arr [ i ] < arr [ j ] ) {\n        next = arr [ j ];\n        break;\n      }\n    }\n    cout << arr [ i ] << \" -- \" << next << endl;\n  }\n}\n", "CHECK_WHETHER_GIVEN_CIRCLE_RESIDE_BOUNDARY_MAINTAINED_OUTER_CIRCLE_INNER_CIRCLE": "void fitOrNotFit ( int R, int r, int x, int y, int rad ) {\n  double val = sqrt ( pow ( x, 2 ) + pow ( y, 2 ) );\n  if ( val + rad <= R && val - rad >= R - r ) cout << \"Fits\\n\";\n  else cout << \"Doesn't Fit\\n\";\n}\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS_1": "int gcdExtended ( int a, int b, int * x, int * y ) {\n  if ( a == 0 ) {\n    * x = 0;\n    * y = 1;\n    return b;\n  }\n  int x1, y1;\n  int gcd = gcdExtended ( b % a, a, & x1, & y1 );\n  * x = y1 - ( b / a ) * x1;\n  * y = x1;\n  return gcd;\n}\n", "FIND_SMALLEST_RANGE_CONTAINING_ELEMENTS_FROM_K_LISTS": "void findSmallestRange ( int arr [ ] [ N ], int n, int k ) {\n  int i, minval, maxval, minrange, minel, maxel, flag, minind;\n  for ( i = 0;\n  i <= k;\n  i ++ ) ptr [ i ] = 0;\n  minrange = INT_MAX;\n  while ( 1 ) {\n    minind = - 1;\n    minval = INT_MAX;\n    maxval = INT_MIN;\n    flag = 0;\n    for ( i = 0;\n    i < k;\n    i ++ ) {\n      if ( ptr [ i ] == n ) {\n        flag = 1;\n        break;\n      }\n      if ( ptr [ i ] < n && arr [ i ] [ ptr [ i ] ] < minval ) {\n        minind = i;\n        minval = arr [ i ] [ ptr [ i ] ];\n      }\n      if ( ptr [ i ] < n && arr [ i ] [ ptr [ i ] ] > maxval ) {\n        maxval = arr [ i ] [ ptr [ i ] ];\n      }\n    }\n    if ( flag ) break;\n    ptr [ minind ] ++;\n    if ( ( maxval - minval ) < minrange ) {\n      minel = minval;\n      maxel = maxval;\n      minrange = maxel - minel;\n    }\n  }\n  printf ( \"The smallest range is [%d , %d]\\n\", minel, maxel );\n}\n", "FIND_THE_MINIMUM_COST_TO_REACH_A_DESTINATION_WHERE_EVERY_STATION_IS_CONNECTED_IN_ONE_DIRECTION": "INT_MAX int minCost ( int cost [ ] [ N ] ) {\n  int dist [ N ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) dist [ i ] = INF;\n  dist [ 0 ] = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = i + 1;\n  j < N;\n  j ++ ) if ( dist [ j ] > dist [ i ] + cost [ i ] [ j ] ) dist [ j ] = dist [ i ] + cost [ i ] [ j ];\n  return dist [ N - 1 ];\n}\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS_1": "int middleOfThree ( int a, int b, int c ) {\n  if ( a > b ) {\n    if ( b > c ) return b;\n    else if ( a > c ) return c;\n    else return a;\n  }\n  else {\n    if ( a > c ) return a;\n    else if ( b > c ) return c;\n    else return b;\n  }\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_11_NOT": "int check ( string str ) {\n  int n = str . length ( );\n  int oddDigSum = 0, evenDigSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i % 2 == 0 ) oddDigSum += ( str [ i ] - '0' );\n    else evenDigSum += ( str [ i ] - '0' );\n  }\n  return ( ( oddDigSum - evenDigSum ) % 11 == 0 );\n}\n", "COMPUTE_MODULUS_DIVISION_BY_A_POWER_OF_2_NUMBER": "unsigned int getModulo ( unsigned int n, unsigned int d ) {\n  return ( n & ( d - 1 ) );\n}\n", "COUNT_BINARY_STRINGS_K_TIMES_APPEARING_ADJACENT_TWO_SET_BITS": "int countStrings ( int n, int k ) {\n  int dp [ n + 1 ] [ k + 1 ] [ 2 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 1 ] [ 0 ] [ 0 ] = 1;\n  dp [ 1 ] [ 0 ] [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j < i;\n    j ++ ) {\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 >= 0 ) dp [ i ] [ j ] [ 1 ] += dp [ i - 1 ] [ j - 1 ] [ 1 ];\n    }\n  }\n  return dp [ n ] [ k ] [ 0 ] + dp [ n ] [ k ] [ 1 ];\n}\n", "FINDING_K_MODULUS_ARRAY_ELEMENT": "void printEqualModNumbers ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int d = arr [ n - 1 ] - arr [ 0 ];\n  vector < int > v;\n  for ( int i = 1;\n  i * i <= d;\n  i ++ ) {\n    if ( d % i == 0 ) {\n      v . push_back ( i );\n      if ( i != d / i ) v . push_back ( d / i );\n    }\n  }\n  for ( int i = 0;\n  i < v . size ( );\n  i ++ ) {\n    int temp = arr [ 0 ] % v [ i ];\n    int j;\n    for ( j = 1;\n    j < n;\n    j ++ ) if ( arr [ j ] % v [ i ] != temp ) break;\n    if ( j == n ) cout << v [ i ] << \" \";\n  }\n}\n", "CIRCULAR_MATRIX_CONSTRUCT_A_MATRIX_WITH_NUMBERS_1_TO_MN_IN_SPIRAL_WAY": "void spiralFill ( int m, int n, int a [ ] [ MAX ] ) {\n  int val = 1;\n  int k = 0, l = 0;\n  while ( k < m && l < n ) {\n    for ( int i = l;\n    i < n;\n    ++ i ) a [ k ] [ i ] = val ++;\n    k ++;\n    for ( int i = k;\n    i < m;\n    ++ i ) a [ i ] [ n - 1 ] = val ++;\n    n --;\n    if ( k < m ) {\n      for ( int i = n - 1;\n      i >= l;\n      -- i ) a [ m - 1 ] [ i ] = val ++;\n      m --;\n    }\n    if ( l < n ) {\n      for ( int i = m - 1;\n      i >= k;\n      -- i ) a [ i ] [ l ] = val ++;\n      l ++;\n    }\n  }\n}\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_2": "void printRepeating ( int arr [ ], int size ) {\n  int Xor = arr [ 0 ];\n  int set_bit_no;\n  int i;\n  int n = size - 2;\n  int x = 0, y = 0;\n  for ( i = 1;\n  i < size;\n  i ++ ) Xor ^= arr [ i ];\n  for ( i = 1;\n  i <= n;\n  i ++ ) Xor ^= i;\n  set_bit_no = Xor & ~ ( Xor - 1 );\n  for ( i = 0;\n  i < size;\n  i ++ ) {\n    if ( arr [ i ] & set_bit_no ) x = x ^ arr [ i ];\n    else y = y ^ arr [ i ];\n  }\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    if ( i & set_bit_no ) x = x ^ i;\n    else y = y ^ i;\n  }\n  cout << \"The two repeating elements are \" << y << \" \" << x;\n}\n", "COUNT_POSSIBLE_WAYS_TO_CONSTRUCT_BUILDINGS": "int countWays ( int N ) {\n  if ( N == 1 ) return 4;\n  int countB = 1, countS = 1, prev_countB, prev_countS;\n  for ( int i = 2;\n  i <= N;\n  i ++ ) {\n    prev_countB = countB;\n    prev_countS = countS;\n    countS = prev_countB + prev_countS;\n    countB = prev_countS;\n  }\n  int result = countS + countB;\n  return ( result * result );\n}\n", "ONE_LINE_FUNCTION_FOR_FACTORIAL_OF_A_NUMBER": "int factorial ( int n ) {\n  return ( n == 1 || n == 0 ) ? 1 : n * factorial ( n - 1 );\n}\n", "CHECK_GIVEN_MATRIX_SPARSE_NOT": "bool isSparse ( int array [ ] [ MAX ], int m, int n ) {\n  int counter = 0;\n  for ( int i = 0;\n  i < m;\n  ++ i ) for ( int j = 0;\n  j < n;\n  ++ j ) if ( array [ i ] [ j ] == 0 ) ++ counter;\n  return ( counter > ( ( m * n ) / 2 ) );\n}\n", "DYNAMIC_PROGRAMMING_SET_10_0_1_KNAPSACK_PROBLEM": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  if ( n == 0 || W == 0 ) return 0;\n  if ( wt [ n - 1 ] > W ) return knapSack ( W, wt, val, n - 1 );\n  else return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ], wt, val, n - 1 ), knapSack ( W, wt, val, n - 1 ) );\n}\n", "FIND_SUBARRAY_LEAST_AVERAGE": "void findMinAvgSubarray ( int arr [ ], int n, int k ) {\n  if ( n < k ) return;\n  int res_index = 0;\n  int curr_sum = 0;\n  for ( int i = 0;\n  i < k;\n  i ++ ) curr_sum += arr [ i ];\n  int min_sum = curr_sum;\n  for ( int i = k;\n  i < n;\n  i ++ ) {\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    }\n  }\n  cout << \"Subarray between [\" << res_index << \", \" << res_index + k - 1 << \"] has minimum average\";\n}\n", "QUERIES_FOR_CHARACTERS_IN_A_REPEATED_STRING": "void query ( char s [ ], int i, int j ) {\n  int n = strlen ( s );\n  i %= n;\n  j %= n;\n  ( s [ i ] == s [ j ] ) ? ( cout << \"Yes\" << endl ) : ( cout << \"No\" << endl );\n}\n", "A_PRODUCT_ARRAY_PUZZLE_1": "void productArray ( int arr [ ], int n ) {\n  if ( n == 1 ) {\n    cout << 0;\n    return;\n  }\n  int i, temp = 1;\n  int * prod = new int [ ( sizeof ( int ) * n ) ];\n  memset ( prod, 1, n );\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    prod [ i ] = temp;\n    temp *= arr [ i ];\n  }\n  temp = 1;\n  for ( i = n - 1;\n  i >= 0;\n  i -- ) {\n    prod [ i ] *= temp;\n    temp *= arr [ i ];\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) cout << prod [ i ] << \" \";\n  return;\n}\n", "FIND_PAIRS_GIVEN_SUM_ELEMENTS_PAIR_DIFFERENT_ROWS": "void pairSum ( int mat [ ] [ MAX ], int n, int sum ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) sort ( mat [ i ], mat [ i ] + n );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int left = 0, right = n - 1;\n      while ( left < n && right >= 0 ) {\n        if ( ( mat [ i ] [ left ] + mat [ j ] [ right ] ) == sum ) {\n          cout << \"(\" << mat [ i ] [ left ] << \", \" << mat [ j ] [ right ] << \"), \";\n          left ++;\n          right --;\n        }\n        else {\n          if ( ( mat [ i ] [ left ] + mat [ j ] [ right ] ) < sum ) left ++;\n          else right --;\n        }\n      }\n    }\n  }\n}\n", "CHECK_STRING_CAN_OBTAINED_ROTATING_ANOTHER_STRING_2_PLACES": "bool isRotated ( string str1, string str2 ) {\n  if ( str1 . length ( ) != str2 . length ( ) ) return false;\n  string clock_rot = \"\";\n  string anticlock_rot = \"\";\n  int len = str2 . length ( );\n  anticlock_rot = anticlock_rot + str2 . substr ( len - 2, 2 ) + str2 . substr ( 0, len - 2 );\n  clock_rot = clock_rot + str2 . substr ( 2 ) + str2 . substr ( 0, 2 );\n  return ( str1 . compare ( clock_rot ) == 0 || str1 . compare ( anticlock_rot ) == 0 );\n}\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN": "int findNth ( int n ) {\n  int count = 0;\n  for ( int curr = 1;\n  ;\n  curr ++ ) {\n    int sum = 0;\n    for ( int x = curr;\n    x > 0;\n    x = x / 10 ) sum = sum + x % 10;\n    if ( sum == 10 ) count ++;\n    if ( count == n ) return curr;\n  }\n  return - 1;\n}\n", "PROGRAM_FIND_SLOPE_LINE": "float slope ( float x1, float y1, float x2, float y2 ) {\n  return ( y2 - y1 ) / ( x2 - x1 );\n}\n", "GCD_ELEMENTS_GIVEN_RANGE": "int rangeGCD ( int n, int m ) {\n  return ( n == m ) ? n : 1;\n}\n", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY_1": "void alternateSubarray ( bool arr [ ], int n ) {\n  int count = 1;\n  int prev = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  ++ i ) {\n    if ( ( arr [ i ] ^ prev ) == 0 ) {\n      while ( count ) cout << count -- << \" \";\n    }\n    ++ count;\n    prev = arr [ i ];\n  }\n  while ( count ) cout << count -- << \" \";\n}\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y": "int unitDigitXRaisedY ( int x, int y ) {\n  int res = 1;\n  for ( int i = 0;\n  i < y;\n  i ++ ) res = ( res * x ) % 10;\n  return res;\n}\n", "MULTIPLY_LARGE_INTEGERS_UNDER_LARGE_MODULO": "long long moduloMultiplication ( long long a, long long b, long long mod ) {\n  long long res = 0;\n  a %= mod;\n  while ( b ) {\n    if ( b & 1 ) res = ( res + a ) % mod;\n    a = ( 2 * a ) % mod;\n    b >>= 1;\n  }\n  return res;\n}\n", "FIND_SMALLEST_NUMBER_WITH_GIVEN_NUMBER_OF_DIGITS_AND_DIGIT_SUM": "void findSmallest ( int m, int s ) {\n  if ( s == 0 ) {\n    ( m == 1 ) ? cout << \"Smallest number is \" << 0 : cout << \"Not possible\";\n    return;\n  }\n  if ( s > 9 * m ) {\n    cout << \"Not possible\";\n    return;\n  }\n  int res [ m ];\n  s -= 1;\n  for ( int i = m - 1;\n  i > 0;\n  i -- ) {\n    if ( s > 9 ) {\n      res [ i ] = 9;\n      s -= 9;\n    }\n    else {\n      res [ i ] = s;\n      s = 0;\n    }\n  }\n  res [ 0 ] = s + 1;\n  cout << \"Smallest number is \";\n  for ( int i = 0;\n  i < m;\n  i ++ ) cout << res [ i ];\n}\n", "C_PROGRAM_FIND_LARGEST_ELEMENT_ARRAY": "int largest ( int arr [ ], int n ) {\n  int i;\n  int max = arr [ 0 ];\n  for ( i = 1;\n  i < n;\n  i ++ ) if ( arr [ i ] > max ) max = arr [ i ];\n  return max;\n}\n", "COUNT_NUMBERS_CAN_CONSTRUCTED_USING_TWO_NUMBERS": "int countNums ( int n, int x, int y ) {\n  vector < bool > arr ( n + 1, false );\n  if ( x <= n ) arr [ x ] = true;\n  if ( y <= n ) arr [ y ] = true;\n  int result = 0;\n  for ( int i = min ( x, y );\n  i <= n;\n  i ++ ) {\n    if ( arr [ i ] ) {\n      if ( i + x <= n ) arr [ i + x ] = true;\n      if ( i + y <= n ) arr [ i + y ] = true;\n      result ++;\n    }\n  }\n  return result;\n}\n", "BUBBLE_SORT_1": "void bubbleSort ( int arr [ ], int n ) {\n  int i, j;\n  bool swapped;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) {\n    swapped = false;\n    for ( j = 0;\n    j < n - i - 1;\n    j ++ ) {\n      if ( arr [ j ] > arr [ j + 1 ] ) {\n        swap ( & arr [ j ], & arr [ j + 1 ] );\n        swapped = true;\n      }\n    }\n    if ( swapped == false ) break;\n  }\n}\n", "MAXIMUM_SUM_2_X_N_GRID_NO_TWO_ELEMENTS_ADJACENT": "int maxSum ( int grid [ 2 ] [ MAX ], int n ) {\n  int incl = max ( grid [ 0 ] [ 0 ], grid [ 1 ] [ 0 ] );\n  int excl = 0, excl_new;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    excl_new = max ( excl, incl );\n    incl = excl + max ( grid [ 0 ] [ i ], grid [ 1 ] [ i ] );\n    excl = excl_new;\n  }\n  return max ( excl, incl );\n}\n", "GCD_FACTORIALS_TWO_NUMBERS": "int gcdOfFactorial ( int m, int n ) {\n  return factorial ( min ( m, n ) );\n}\n", "AREA_OF_A_SECTOR": "void SectorArea ( double radius, double angle ) {\n  if ( angle >= 360 ) cout << \"Angle not possible\";\n  else {\n    double sector = ( ( 22 * radius * radius ) / 7 ) * ( angle / 360 );\n    cout << sector;\n  }\n}\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS_1": "int countSeq ( int n ) {\n  int nCr = 1, res = 1;\n  for ( int r = 1;\n  r <= n;\n  r ++ ) {\n    nCr = ( nCr * ( n + 1 - r ) ) / r;\n    res += nCr * nCr;\n  }\n  return res;\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_1": "int findLength ( char * str ) {\n  int n = strlen ( str );\n  int maxlen = 0;\n  int sum [ n ] [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum [ i ] [ i ] = str [ i ] - '0';\n  for ( int len = 2;\n  len <= n;\n  len ++ ) {\n    for ( int i = 0;\n    i < n - len + 1;\n    i ++ ) {\n      int j = i + len - 1;\n      int k = len / 2;\n      sum [ i ] [ j ] = sum [ i ] [ j - k ] + sum [ j - k + 1 ] [ j ];\n      if ( len % 2 == 0 && sum [ i ] [ j - k ] == sum [ ( j - k + 1 ) ] [ j ] && len > maxlen ) maxlen = len;\n    }\n  }\n  return maxlen;\n}\n", "SWAP_ALL_ODD_AND_EVEN_BITS": "unsigned int swapBits ( unsigned int x ) {\n  unsigned int even_bits = x & 0xAAAAAAAA;\n  unsigned int odd_bits = x & 0x55555555;\n  even_bits >>= 1;\n  odd_bits <<= 1;\n  return ( even_bits | odd_bits );\n}\n", "SORT_ARRAY_WAVE_FORM_2": "void sortInWave ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 1;\n  i += 2 ) swap ( & arr [ i ], & arr [ i + 1 ] );\n}\n", "FIND_HARMONIC_MEAN_USING_ARITHMETIC_MEAN_GEOMETRIC_MEAN": "double compute ( int a, int b ) {\n  double AM, GM, HM;\n  AM = ( a + b ) / 2;\n  GM = sqrt ( a * b );\n  HM = ( GM * GM ) / AM;\n  return HM;\n}\n", "COUNT_BALANCED_BINARY_TREES_HEIGHT_H": "long long int countBT ( int h ) {\n  long long int dp [ h + 1 ];\n  dp [ 0 ] = dp [ 1 ] = 1;\n  for ( int i = 2;\n  i <= h;\n  i ++ ) {\n    dp [ i ] = ( dp [ i - 1 ] * ( ( 2 * dp [ i - 2 ] ) % mod + dp [ i - 1 ] ) % mod ) % mod;\n  }\n  return dp [ h ];\n}\n", "MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME_WITH_PERMUTATIONS_ALLOWED": "int minInsertion ( string str ) {\n  int n = str . length ( );\n  int res = 0;\n  int count [ 26 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) count [ str [ i ] - 'a' ] ++;\n    for ( int i = 0;\n    i < 26;\n    i ++ ) if ( count [ i ] % 2 == 1 ) res ++;\n    return ( res == 0 ) ? 0 : res - 1;\n  }\n  ", "SHUFFLE_A_GIVEN_ARRAY": "void randomize ( int arr [ ], int n ) {\n  srand ( time ( NULL ) );\n  for ( int i = n - 1;\n  i > 0;\n  i -- ) {\n    int j = rand ( ) % ( i + 1 );\n    swap ( & arr [ i ], & arr [ j ] );\n  }\n}\n", "UGLY_NUMBERS": "unsigned getNthUglyNo ( unsigned n ) {\n  unsigned ugly [ n ];\n  unsigned i2 = 0, i3 = 0, i5 = 0;\n  unsigned next_multiple_of_2 = 2;\n  unsigned next_multiple_of_3 = 3;\n  unsigned next_multiple_of_5 = 5;\n  unsigned next_ugly_no = 1;\n  ugly [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    next_ugly_no = min ( next_multiple_of_2, min ( next_multiple_of_3, next_multiple_of_5 ) );\n    ugly [ i ] = next_ugly_no;\n    if ( next_ugly_no == next_multiple_of_2 ) {\n      i2 = i2 + 1;\n      next_multiple_of_2 = ugly [ i2 ] * 2;\n    }\n    if ( next_ugly_no == next_multiple_of_3 ) {\n      i3 = i3 + 1;\n      next_multiple_of_3 = ugly [ i3 ] * 3;\n    }\n    if ( next_ugly_no == next_multiple_of_5 ) {\n      i5 = i5 + 1;\n      next_multiple_of_5 = ugly [ i5 ] * 5;\n    }\n  }\n  return next_ugly_no;\n}\n", "MINIMUM_COST_CUT_BOARD_SQUARES": "int minimumCostOfBreaking ( int X [ ], int Y [ ], int m, int n ) {\n  int res = 0;\n  sort ( X, X + m, greater < int > ( ) );\n  sort ( Y, Y + n, greater < int > ( ) );\n  int hzntl = 1, vert = 1;\n  int i = 0, j = 0;\n  while ( i < m && j < n ) {\n    if ( X [ i ] > Y [ j ] ) {\n      res += X [ i ] * vert;\n      hzntl ++;\n      i ++;\n    }\n    else {\n      res += Y [ j ] * hzntl;\n      vert ++;\n      j ++;\n    }\n  }\n  int total = 0;\n  while ( i < m ) total += X [ i ++ ];\n  res += total * vert;\n  total = 0;\n  while ( j < n ) total += Y [ j ++ ];\n  res += total * hzntl;\n  return res;\n}\n", "DYNAMIC_PROGRAMMING_SET_10_0_1_KNAPSACK_PROBLEM_1": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  int i, w;\n  int K [ n + 1 ] [ W + 1 ];\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( w = 0;\n    w <= W;\n    w ++ ) {\n      if ( i == 0 || w == 0 ) K [ i ] [ w ] = 0;\n      else if ( wt [ i - 1 ] <= w ) K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ], K [ i - 1 ] [ w ] );\n      else K [ i ] [ w ] = K [ i - 1 ] [ w ];\n    }\n  }\n  return K [ n ] [ W ];\n}\n", "STACK_PERMUTATIONS_CHECK_IF_AN_ARRAY_IS_STACK_PERMUTATION_OF_OTHER": "bool checkStackPermutation ( int ip [ ], int op [ ], int n ) {\n  queue < int > input;\n  for ( int i = 0;\n  i < n;\n  i ++ ) input . push ( ip [ i ] );\n  queue < int > output;\n  for ( int i = 0;\n  i < n;\n  i ++ ) output . push ( op [ i ] );\n  stack < int > tempStack;\n  while ( ! input . empty ( ) ) {\n    int ele = input . front ( );\n    input . pop ( );\n    if ( ele == output . front ( ) ) {\n      output . pop ( );\n      while ( ! tempStack . empty ( ) ) {\n        if ( tempStack . top ( ) == output . front ( ) ) {\n          tempStack . pop ( );\n          output . pop ( );\n        }\n        else break;\n      }\n    }\n    else tempStack . push ( ele );\n  }\n  return ( input . empty ( ) && tempStack . empty ( ) );\n}\n", "PROBABILITY_THREE_RANDOMLY_CHOSEN_NUMBERS_AP": "double procal ( int n ) {\n  return ( 3.0 * n ) / ( 4.0 * ( n * n ) - 1 );\n}\n", "REMOVE_BRACKETS_ALGEBRAIC_STRING_CONTAINING_OPERATORS": "char * simplify ( string str ) {\n  int len = str . length ( );\n  char * res = new char ( len );\n  int index = 0, i = 0;\n  stack < int > s;\n  s . push ( 0 );\n  while ( i < len ) {\n    if ( str [ i ] == '+' ) {\n      if ( s . top ( ) == 1 ) res [ index ++ ] = '-';\n      if ( s . top ( ) == 0 ) res [ index ++ ] = '+';\n    }\n    else if ( str [ i ] == '-' ) {\n      if ( s . top ( ) == 1 ) res [ index ++ ] = '+';\n      else if ( s . top ( ) == 0 ) res [ index ++ ] = '-';\n    }\n    else if ( str [ i ] == '(' && i > 0 ) {\n      if ( str [ i - 1 ] == '-' ) {\n        int x = ( s . top ( ) == 1 ) ? 0 : 1;\n        s . push ( x );\n      }\n      else if ( str [ i - 1 ] == '+' ) s . push ( s . top ( ) );\n    }\n    else if ( str [ i ] == ')' ) s . pop ( );\n    else res [ index ++ ] = str [ i ];\n    i ++;\n  }\n  return res;\n}\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS": "int countSquares ( int a, int b ) {\n  int cnt = 0;\n  for ( int i = a;\n  i <= b;\n  i ++ ) for ( int j = 1;\n  j * j <= i;\n  j ++ ) if ( j * j == i ) cnt ++;\n  return cnt;\n}\n", "K_NUMBERS_DIFFERENCE_MAXIMUM_MINIMUM_K_NUMBER_MINIMIZED": "int minDiff ( int arr [ ], int n, int k ) {\n  int result = INT_MAX;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i <= n - k;\n  i ++ ) result = min ( result, arr [ i + k - 1 ] - arr [ i ] );\n  return result;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_13_NOT": "bool checkDivisibility ( string num ) {\n  int length = num . size ( );\n  if ( length == 1 && num [ 0 ] == '0' ) return true;\n  if ( length % 3 == 1 ) {\n    num += \"00\";\n    length += 2;\n  }\n  else if ( length % 3 == 2 ) {\n    num += \"0\";\n    length += 1;\n  }\n  int sum = 0, p = 1;\n  for ( int i = length - 1;\n  i >= 0;\n  i -- ) {\n    int group = 0;\n    group += num [ i -- ] - '0';\n    group += ( num [ i -- ] - '0' ) * 10;\n    group += ( num [ i ] - '0' ) * 100;\n    sum = sum + group * p;\n    p *= ( - 1 );\n  }\n  sum = abs ( sum );\n  return ( sum % 13 == 0 );\n}\n", "GIVEN_N_X_N_SQUARE_MATRIX_FIND_SUM_SUB_SQUARES_SIZE_K_X_K": "void printSumSimple ( int mat [ ] [ n ], int k ) {\n  if ( k > n ) return;\n  for ( int i = 0;\n  i < n - k + 1;\n  i ++ ) {\n    for ( int j = 0;\n    j < n - k + 1;\n    j ++ ) {\n      int sum = 0;\n      for ( int p = i;\n      p < k + i;\n      p ++ ) for ( int q = j;\n      q < k + j;\n      q ++ ) sum += mat [ p ] [ q ];\n      cout << sum << \"  \";\n    }\n    cout << endl;\n  }\n}\n", "FIND_THE_POINT_WHERE_MAXIMUM_INTERVALS_OVERLAP_1": "void maxOverlap ( vector < int > & start, vector < int > & end ) {\n  int n = start . size ( );\n  int maxa = * max_element ( start . begin ( ), start . end ( ) );\n  int maxb = * max_element ( end . begin ( ), end . end ( ) );\n  int maxc = max ( maxa, maxb );\n  int x [ maxc + 2 ];\n  memset ( x, 0, sizeof x );\n  int cur = 0, idx;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    ++ x [ start [ i ] ];\n    -- x [ end [ i ] + 1 ];\n  }\n  int maxy = INT_MIN;\n  for ( int i = 0;\n  i <= maxc;\n  i ++ ) {\n    cur += x [ i ];\n    if ( maxy < cur ) {\n      maxy = cur;\n      idx = i;\n    }\n  }\n  cout << \"Maximum value is \" << maxy << \" at position \" << idx << endl;\n}\n", "MAXIMUM_SUBSEQUENCE_SUM_SUCH_THAT_NO_THREE_ARE_CONSECUTIVE_1": "int maxSumWO3Consec ( int n ) {\n  if ( sum [ n ] != - 1 ) return sum [ n ];\n  if ( n == 0 ) return sum [ n ] = 0;\n  if ( n == 1 ) return sum [ n ] = arr [ 0 ];\n  if ( n == 2 ) return sum [ n ] = arr [ 1 ] + arr [ 0 ];\n  return sum [ n ] = max ( max ( maxSumWO3Consec ( n - 1 ), maxSumWO3Consec ( n - 2 ) + arr [ n - 1 ] ), arr [ n - 2 ] + arr [ n - 1 ] + maxSumWO3Consec ( n - 3 ) );\n}\n", "C_PROGRAM_ADDITION_TWO_MATRICES": "void add ( int A [ ] [ N ], int B [ ] [ N ], int C [ ] [ N ] ) {\n  int i, j;\n  for ( i = 0;\n  i < N;\n  i ++ ) for ( j = 0;\n  j < N;\n  j ++ ) C [ i ] [ j ] = A [ i ] [ j ] + B [ i ] [ j ];\n}\n", "FIND_MAXIMUM_AVERAGE_SUBARRAY_OF_K_LENGTH_1": "int findMaxAverage ( int arr [ ], int n, int k ) {\n  if ( k > n ) return - 1;\n  int sum = arr [ 0 ];\n  for ( int i = 1;\n  i < k;\n  i ++ ) sum += arr [ i ];\n  int max_sum = sum, max_end = k - 1;\n  for ( int i = k;\n  i < n;\n  i ++ ) {\n    int sum = sum + arr [ i ] - arr [ i - k ];\n    if ( sum > max_sum ) {\n      max_sum = sum;\n      max_end = i;\n    }\n  }\n  return max_end - k + 1;\n}\n", "FIND_CENTER_CIRCLE_USING_ENDPOINTS_DIAMETER": "void center ( int x1, int x2, int y1, int y2 ) {\n  cout << ( float ) ( x1 + x2 ) / 2 << \", \" << ( float ) ( y1 + y2 ) / 2;\n}\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS": "long long int countNonDecreasing ( int n ) {\n  long long int dp [ 10 ] [ n + 1 ];\n  memset ( dp, 0, sizeof dp );\n  for ( int i = 0;\n  i < 10;\n  i ++ ) dp [ i ] [ 1 ] = 1;\n  for ( int digit = 0;\n  digit <= 9;\n  digit ++ ) {\n    for ( int len = 2;\n    len <= n;\n    len ++ ) {\n      for ( int x = 0;\n      x <= digit;\n      x ++ ) dp [ digit ] [ len ] += dp [ x ] [ len - 1 ];\n    }\n  }\n  long long int count = 0;\n  for ( int i = 0;\n  i < 10;\n  i ++ ) count += dp [ i ] [ n ];\n  return count;\n}\n", "PRINT_REVERSE_STRING_REMOVING_VOWELS": "void replaceOriginal ( string s, int n ) {\n  string r ( n, ' ' );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    r [ i ] = s [ n - 1 - i ];\n    if ( s [ i ] != 'a' && s [ i ] != 'e' && s [ i ] != 'i' && s [ i ] != 'o' && s [ i ] != 'u' ) {\n      cout << r [ i ];\n    }\n  }\n  cout << endl;\n}\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND_1": "void findMissing ( int a [ ], int b [ ], int n, int m ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < m;\n  i ++ ) s . insert ( b [ i ] );\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( s . find ( a [ i ] ) == s . end ( ) ) cout << a [ i ] << \" \";\n}\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS": "int countStr ( int n, int bCount, int cCount ) {\n  if ( bCount < 0 || cCount < 0 ) return 0;\n  if ( n == 0 ) return 1;\n  if ( bCount == 0 && cCount == 0 ) return 1;\n  int 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}\n", "GOLD_MINE_PROBLEM": "int getMaxGold ( int gold [ ] [ MAX ], int m, int n ) {\n  int goldTable [ m ] [ n ];\n  memset ( goldTable, 0, sizeof ( goldTable ) );\n  for ( int col = n - 1;\n  col >= 0;\n  col -- ) {\n    for ( int row = 0;\n    row < m;\n    row ++ ) {\n      int right = ( col == n - 1 ) ? 0 : goldTable [ row ] [ col + 1 ];\n      int right_up = ( row == 0 || col == n - 1 ) ? 0 : goldTable [ row - 1 ] [ col + 1 ];\n      int right_down = ( row == m - 1 || col == n - 1 ) ? 0 : goldTable [ row + 1 ] [ col + 1 ];\n      goldTable [ row ] [ col ] = gold [ row ] [ col ] + max ( right, max ( right_up, right_down ) );\n    }\n  }\n  int res = goldTable [ 0 ] [ 0 ];\n  for ( int i = 1;\n  i < m;\n  i ++ ) res = max ( res, goldTable [ i ] [ 0 ] );\n  return res;\n}\n", "COUNT_WAYS_BUILD_STREET_GIVEN_CONSTRAINTS": "long countWays ( int n ) {\n  long dp [ 2 ] [ n + 1 ];\n  dp [ 0 ] [ 1 ] = 1;\n  dp [ 1 ] [ 1 ] = 2;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\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  }\n  return dp [ 0 ] [ n ] + dp [ 1 ] [ n ];\n}\n", "RETURN_A_PAIR_WITH_MAXIMUM_PRODUCT_IN_ARRAY_OF_INTEGERS_1": "void maxProduct ( int arr [ ], int n ) {\n  if ( n < 2 ) {\n    cout << \"No pairs exists\\n\";\n    return;\n  }\n  if ( n == 2 ) {\n    cout << arr [ 0 ] << \" \" << arr [ 1 ] << endl;\n    return;\n  }\n  int posa = INT_MIN, posb = INT_MIN;\n  int nega = INT_MIN, negb = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] > posa ) {\n      posb = posa;\n      posa = arr [ i ];\n    }\n    else if ( arr [ i ] > posb ) posb = arr [ i ];\n    if ( arr [ i ] < 0 && abs ( arr [ i ] ) > abs ( nega ) ) {\n      negb = nega;\n      nega = arr [ i ];\n    }\n    else if ( arr [ i ] < 0 && abs ( arr [ i ] ) > abs ( negb ) ) negb = arr [ i ];\n  }\n  if ( nega * negb > posa * posb ) cout << \"Max product pair is {\" << nega << \", \" << negb << \"}\";\n  else cout << \"Max product pair is {\" << posa << \", \" << posb << \"}\";\n}\n", "POSITION_OF_RIGHTMOST_SET_BIT": "public : unsigned int getFirstSetBitPos ( int n ) {\n  return log2 ( n & - n ) + 1;\n}\n", "LONGEST_SUBSEQUENCE_WHERE_EVERY_CHARACTER_APPEARS_AT_LEAST_K_TIMES": "void longestSubseqWithK ( string str, int k ) {\n  int n = str . size ( );\n  int freq [ MAX_CHARS ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) freq [ str [ i ] - 'a' ] ++;\n    for ( int i = 0;\n    i < n;\n    i ++ ) if ( freq [ str [ i ] - 'a' ] >= k ) cout << str [ i ];\n  }\n  ", "POSSIBLE_TO_MAKE_A_DIVISIBLE_BY_3_NUMBER_USING_ALL_DIGITS_IN_AN_ARRAY": "bool isPossibleToMakeDivisible ( int arr [ ], int n ) {\n  int remainder = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) remainder = ( remainder + arr [ i ] ) % 3;\n  return ( remainder == 0 );\n}\n", "AREA_SQUARE_CIRCUMSCRIBED_CIRCLE": "int find_Area ( int r ) {\n  return ( 2 * r * r );\n}\n", "FIND_MAXIMUM_DOT_PRODUCT_TWO_ARRAYS_INSERTION_0S": "long long int MaxDotProduct ( int A [ ], int B [ ], int m, int n ) {\n  long long int dp [ n + 1 ] [ m + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = i;\n  j <= m;\n  j ++ ) 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}\n", "FIND_DISTINCT_SUBSET_SUBSEQUENCE_SUMS_ARRAY": "void printDistSum ( int arr [ ], int n ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += arr [ i ];\n  bool dp [ n + 1 ] [ sum + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i <= n;\n  i ++ ) dp [ i ] [ 0 ] = true;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    dp [ i ] [ arr [ i - 1 ] ] = true;\n    for ( int j = 1;\n    j <= sum;\n    j ++ ) {\n      if ( dp [ i - 1 ] [ j ] == true ) {\n        dp [ i ] [ j ] = true;\n        dp [ i ] [ j + arr [ i - 1 ] ] = true;\n      }\n    }\n  }\n  for ( int j = 0;\n  j <= sum;\n  j ++ ) if ( dp [ n ] [ j ] == true ) cout << j << \" \";\n}\n", "SPLIT_NUMERIC_ALPHABETIC_AND_SPECIAL_SYMBOLS_FROM_A_STRING": "void splitString ( string str ) {\n  string alpha, num, special;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    if ( isdigit ( str [ i ] ) ) num . push_back ( str [ i ] );\n    else if ( ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) || ( str [ i ] >= 'a' && str [ i ] <= 'z' ) ) alpha . push_back ( str [ i ] );\n    else special . push_back ( str [ i ] );\n  }\n  cout << alpha << endl;\n  cout << num << endl;\n  cout << special << endl;\n}\n", "MAXIMUM_SUM_ALTERNATING_SUBSEQUENCE_SUM": "int maxAlternateSum ( int arr [ ], int n ) {\n  if ( n == 1 ) return arr [ 0 ];\n  int dec [ n ];\n  memset ( dec, 0, sizeof ( dec ) );\n  int inc [ n ];\n  memset ( inc, 0, sizeof ( inc ) );\n  dec [ 0 ] = inc [ 0 ] = arr [ 0 ];\n  int flag = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < i;\n    j ++ ) {\n      if ( arr [ j ] > arr [ i ] ) {\n        dec [ i ] = max ( dec [ i ], inc [ j ] + arr [ i ] );\n        flag = 1;\n      }\n      else if ( arr [ j ] < arr [ i ] && flag == 1 ) inc [ i ] = max ( inc [ i ], dec [ j ] + arr [ i ] );\n    }\n  }\n  int result = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( result < inc [ i ] ) result = inc [ i ];\n    if ( result < dec [ i ] ) result = dec [ i ];\n  }\n  return result;\n}\n", "FIND_PAIR_MAXIMUM_GCD_ARRAY": "int findMaxGCD ( int arr [ ], int n ) {\n  int high = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) high = max ( high, arr [ i ] );\n  int divisors [ high + 1 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      for ( int j = 1;\n      j <= sqrt ( arr [ i ] );\n      j ++ ) {\n        if ( arr [ i ] % j == 0 ) {\n          divisors [ j ] ++;\n          if ( j != arr [ i ] / j ) divisors [ arr [ i ] / j ] ++;\n        }\n      }\n    }\n    for ( int i = high;\n    i >= 1;\n    i -- ) if ( divisors [ i ] > 1 ) return i;\n  }\n  ", "FIND_MINIMUM_NUMBER_OF_COINS_THAT_MAKE_A_CHANGE_1": "int minCoins ( int coins [ ], int m, int V ) {\n  int table [ V + 1 ];\n  table [ 0 ] = 0;\n  for ( int i = 1;\n  i <= V;\n  i ++ ) table [ i ] = INT_MAX;\n  for ( int i = 1;\n  i <= V;\n  i ++ ) {\n    for ( int j = 0;\n    j < m;\n    j ++ ) if ( coins [ j ] <= i ) {\n      int sub_res = table [ i - coins [ j ] ];\n      if ( sub_res != INT_MAX && sub_res + 1 < table [ i ] ) table [ i ] = sub_res + 1;\n    }\n  }\n  return table [ V ];\n}\n", "SUM_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING": "int sumAtKthLevel ( string tree, int k ) {\n  int level = - 1;\n  int sum = 0;\n  int n = tree . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( tree [ i ] == '(' ) level ++;\n    else if ( tree [ i ] == ')' ) level --;\n    else {\n      if ( level == k ) sum += ( tree [ i ] - '0' );\n    }\n  }\n  return sum;\n}\n", "DYNAMIC_PROGRAMMING_SET_4_LONGEST_COMMON_SUBSEQUENCE": "int lcs ( char * X, char * Y, int m, int n ) {\n  if ( m == 0 || n == 0 ) return 0;\n  if ( X [ m - 1 ] == Y [ n - 1 ] ) return 1 + lcs ( X, Y, m - 1, n - 1 );\n  else return max ( lcs ( X, Y, m, n - 1 ), lcs ( X, Y, m - 1, n ) );\n}\n", "CHECK_GIVEN_SENTENCE_GIVEN_SET_SIMPLE_GRAMMER_RULES": "bool checkSentence ( char str [ ] ) {\n  int len = strlen ( str );\n  if ( str [ 0 ] < 'A' || str [ 0 ] > 'Z' ) return false;\n  if ( str [ len - 1 ] != '.' ) return false;\n  int prev_state = 0, curr_state = 0;\n  int index = 1;\n  while ( str [ index ] ) {\n    if ( str [ index ] >= 'A' && str [ index ] <= 'Z' ) curr_state = 0;\n    else if ( str [ index ] == ' ' ) curr_state = 1;\n    else if ( str [ index ] >= 'a' && str [ index ] <= 'z' ) curr_state = 2;\n    else if ( str [ index ] == '.' ) curr_state = 3;\n    if ( prev_state == curr_state && curr_state != 2 ) return false;\n    if ( prev_state == 2 && curr_state == 0 ) return false;\n    if ( curr_state == 3 && prev_state != 1 ) return ( str [ index + 1 ] == '\\0' );\n    index ++;\n    prev_state = curr_state;\n  }\n  return false;\n}\n", "CHECK_DIVISIBILITY_LARGE_NUMBER_999": "bool isDivisible999 ( string num ) {\n  int n = num . length ( );\n  if ( n == 0 && num [ 0 ] == '0' ) return true;\n  if ( n % 3 == 1 ) num = \"00\" + num;\n  if ( n % 3 == 2 ) num = \"0\" + num;\n  int gSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int group = 0;\n    group += ( num [ i ++ ] - '0' ) * 100;\n    group += ( num [ i ++ ] - '0' ) * 10;\n    group += num [ i ] - '0';\n    gSum += group;\n  }\n  if ( gSum > 1000 ) {\n    num = to_string ( gSum );\n    n = num . length ( );\n    gSum = isDivisible999 ( num );\n  }\n  return ( gSum == 999 );\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_9_NOT": "int check ( string str ) {\n  int n = str . length ( );\n  int digitSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) digitSum += ( str [ i ] - '0' );\n  return ( digitSum % 9 == 0 );\n}\n", "NUMBER_OF_BINARY_TREES_FOR_GIVEN_PREORDER_SEQUENCE_LENGTH": "int countTrees ( int n ) {\n  int BT [ n + 1 ];\n  memset ( BT, 0, sizeof ( BT ) );\n  BT [ 0 ] = BT [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  ++ i ) for ( int j = 0;\n  j < i;\n  j ++ ) BT [ i ] += BT [ j ] * BT [ i - j - 1 ];\n  return BT [ n ];\n}\n", "PROGRAM_SWAP_UPPER_DIAGONAL_ELEMENTS_LOWER_DIAGONAL_ELEMENTS_MATRIX": "void swapUpperToLower ( int arr [ n ] [ n ] ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int temp = arr [ i ] [ j ];\n      arr [ i ] [ j ] = arr [ j ] [ i ];\n      arr [ j ] [ i ] = temp;\n    }\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) cout << arr [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER_1": "int findSum ( int N, int K ) {\n  int ans = 0;\n  int y = N / K;\n  int x = N % K;\n  ans = ( K * ( K - 1 ) / 2 ) * y + ( x * ( x + 1 ) ) / 2;\n  return ans;\n}\n", "WAYS_REMOVE_ONE_ELEMENT_BINARY_STRING_XOR_BECOMES_ZERO": "int xorZero ( string str ) {\n  int one_count = 0, zero_count = 0;\n  int n = str . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( str [ i ] == '1' ) one_count ++;\n  else zero_count ++;\n  if ( one_count % 2 == 0 ) return zero_count;\n  return one_count;\n}\n", "DYNAMIC_PROGRAMMING_SET_7_COIN_CHANGE": "int count ( int S [ ], int m, int n ) {\n  if ( n == 0 ) return 1;\n  if ( n < 0 ) return 0;\n  if ( m <= 0 && n >= 1 ) return 0;\n  return count ( S, m - 1, n ) + count ( S, m, n - S [ m - 1 ] );\n}\n", "MINIMUM_SUM_SUBSEQUENCE_LEAST_ONE_EVERY_FOUR_CONSECUTIVE_ELEMENTS_PICKED": "int minSum ( int arr [ ], int n ) {\n  int dp [ n ];\n  if ( n == 1 ) return arr [ 0 ];\n  if ( n == 2 ) return min ( arr [ 0 ], arr [ 1 ] );\n  if ( n == 3 ) return min ( arr [ 0 ], min ( arr [ 1 ], arr [ 2 ] ) );\n  if ( n == 4 ) 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 ( int i = 4;\n  i < n;\n  i ++ ) 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}\n", "MAXIMUM_PATH_SUM_TRIANGLE": "int maxPathSum ( int tri [ ] [ N ], int m, int n ) {\n  for ( int i = m - 1;\n  i >= 0;\n  i -- ) {\n    for ( int j = 0;\n    j <= i;\n    j ++ ) {\n      if ( tri [ i + 1 ] [ j ] > tri [ i + 1 ] [ j + 1 ] ) tri [ i ] [ j ] += tri [ i + 1 ] [ j ];\n      else tri [ i ] [ j ] += tri [ i + 1 ] [ j + 1 ];\n    }\n  }\n  return tri [ 0 ] [ 0 ];\n}\n", "FIND_THREE_ELEMENT_FROM_DIFFERENT_THREE_ARRAYS_SUCH_THAT_THAT_A_B_C_K": "bool findTriplet ( int a1 [ ], int a2 [ ], int a3 [ ], int n1, int n2, int n3, int sum ) {\n  for ( int i = 0;\n  i < n1;\n  i ++ ) for ( int j = 0;\n  j < n2;\n  j ++ ) for ( int k = 0;\n  k < n3;\n  k ++ ) if ( a1 [ i ] + a2 [ j ] + a3 [ k ] == sum ) return true;\n  return false;\n}\n", "TAIL_RECURSION_FIBONACCI": "int fib ( int n, int a = 0, int b = 1 ) {\n  if ( n == 0 ) return a;\n  if ( n == 1 ) return b;\n  return fib ( n - 1, b, a + b );\n}\n", "PROGRAM_TO_CHECK_IF_A_GIVEN_NUMBER_IS_LUCKY_ALL_DIGITS_ARE_DIFFERENT": "bool isLucky ( int n ) {\n  bool arr [ 10 ];\n  for ( int i = 0;\n  i < 10;\n  i ++ ) arr [ i ] = false;\n  while ( n > 0 ) {\n    int digit = n % 10;\n    if ( arr [ digit ] ) return false;\n    arr [ digit ] = true;\n    n = n / 10;\n  }\n  return true;\n}\n", "GIVEN_N_X_N_SQUARE_MATRIX_FIND_SUM_SUB_SQUARES_SIZE_K_X_K_1": "void printSumTricky ( int mat [ ] [ n ], int k ) {\n  if ( k > n ) return;\n  int stripSum [ n ] [ n ];\n  for ( int j = 0;\n  j < n;\n  j ++ ) {\n    int sum = 0;\n    for ( int i = 0;\n    i < k;\n    i ++ ) sum += mat [ i ] [ j ];\n    stripSum [ 0 ] [ j ] = sum;\n    for ( int i = 1;\n    i < n - k + 1;\n    i ++ ) {\n      sum += ( mat [ i + k - 1 ] [ j ] - mat [ i - 1 ] [ j ] );\n      stripSum [ i ] [ j ] = sum;\n    }\n  }\n  for ( int i = 0;\n  i < n - k + 1;\n  i ++ ) {\n    int sum = 0;\n    for ( int j = 0;\n    j < k;\n    j ++ ) sum += stripSum [ i ] [ j ];\n    cout << sum << \"  \";\n    for ( int j = 1;\n    j < n - k + 1;\n    j ++ ) {\n      sum += ( stripSum [ i ] [ j + k - 1 ] - stripSum [ i ] [ j - 1 ] );\n      cout << sum << \"  \";\n    }\n    cout << endl;\n  }\n}\n", "SCHEDULE_ELEVATOR_TO_REDUCE_THE_TOTAL_TIME_TAKEN": "int minTime ( int n, int k, int a [ ] ) {\n  sort ( a, a + n, greater < int > ( ) );\n  int minTime = 0;\n  for ( int i = 0;\n  i < n;\n  i += k ) minTime += ( 2 * a [ i ] );\n  return minTime;\n}\n", "ODD_EVEN_SORT_BRICK_SORT": "void oddEvenSort ( int arr [ ], int n ) {\n  bool isSorted = false;\n  while ( ! isSorted ) {\n    isSorted = true;\n    for ( int i = 1;\n    i <= n - 2;\n    i = i + 2 ) {\n      if ( arr [ i ] > arr [ i + 1 ] ) {\n        swap ( arr [ i ], arr [ i + 1 ] );\n        isSorted = false;\n      }\n    }\n    for ( int i = 0;\n    i <= n - 2;\n    i = i + 2 ) {\n      if ( arr [ i ] > arr [ i + 1 ] ) {\n        swap ( arr [ i ], arr [ i + 1 ] );\n        isSorted = false;\n      }\n    }\n  }\n  return;\n}\n", "RETURN_MAXIMUM_OCCURRING_CHARACTER_IN_THE_INPUT_STRING": "char getMaxOccuringChar ( char * str ) {\n  int count [ ASCII_SIZE ] = {\n    0 };\n    int len = strlen ( str );\n    int max = 0;\n    char result;\n    for ( int i = 0;\n    i < len;\n    i ++ ) {\n      count [ str [ i ] ] ++;\n      if ( max < count [ str [ i ] ] ) {\n        max = count [ str [ i ] ];\n        result = str [ i ];\n      }\n    }\n    return result;\n  }\n  ", "COUNT_NUMBER_PAIRS_N_B_N_GCD_B_B": "int CountPairs ( int n ) {\n  int k = n;\n  int imin = 1;\n  int ans = 0;\n  while ( imin <= n ) {\n    int imax = n / k;\n    ans += k * ( imax - imin + 1 );\n    imin = imax + 1;\n    k = n / imin;\n  }\n  return ans;\n}\n", "K_TH_DISTINCT_OR_NON_REPEATING_ELEMENT_IN_AN_ARRAY_1": "int printKDistinct ( int arr [ ], int n, int k ) {\n  unordered_map < int, int > h;\n  for ( int i = 0;\n  i < n;\n  i ++ ) h [ arr [ i ] ] ++;\n  if ( h . size ( ) < k ) return - 1;\n  int dist_count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( h [ arr [ i ] ] == 1 ) dist_count ++;\n    if ( dist_count == k ) return arr [ i ];\n  }\n  return - 1;\n}\n", "GENERATE_BINARY_PERMUTATIONS_1S_0S_EVERY_POINT_PERMUTATIONS": "void generate ( int ones, int zeroes, string str, int len ) {\n  if ( len == str . length ( ) ) {\n    cout << str << \"  \";\n    return;\n  }\n  generate ( ones + 1, zeroes, str + \"1\", len );\n  if ( ones > zeroes ) generate ( ones, zeroes + 1, str + \"0\", len );\n}\n", "SEARCH_INSERT_AND_DELETE_IN_AN_UNSORTED_ARRAY": "int findElement ( int arr [ ], int n, int key ) {\n  int i;\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] == key ) return i;\n  return - 1;\n}\n", "LCS_LONGEST_COMMON_SUBSEQUENCE_THREE_STRINGS": "int lcsOf3 ( string X, string Y, string Z, int m, int n, int o ) {\n  int L [ m + 1 ] [ n + 1 ] [ o + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      for ( int k = 0;\n      k <= o;\n      k ++ ) {\n        if ( i == 0 || j == 0 || k == 0 ) L [ i ] [ j ] [ k ] = 0;\n        else if ( X [ i - 1 ] == Y [ j - 1 ] && X [ i - 1 ] == Z [ k - 1 ] ) L [ i ] [ j ] [ k ] = L [ i - 1 ] [ j - 1 ] [ k - 1 ] + 1;\n        else L [ i ] [ j ] [ k ] = max ( max ( L [ i - 1 ] [ j ] [ k ], L [ i ] [ j - 1 ] [ k ] ), L [ i ] [ j ] [ k - 1 ] );\n      }\n    }\n  }\n  return L [ m ] [ n ] [ o ];\n}\n", "MAXIMUM_SUM_SUBARRAY_REMOVING_ONE_ELEMENT": "int maxSumSubarrayRemovingOneEle ( int arr [ ], int n ) {\n  int fw [ n ], bw [ n ];\n  int cur_max = arr [ 0 ], max_so_far = arr [ 0 ];\n  fw [ 0 ] = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\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  }\n  cur_max = max_so_far = bw [ n - 1 ] = arr [ n - 1 ];\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\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  }\n  int fans = max_so_far;\n  for ( int i = 1;\n  i < n - 1;\n  i ++ ) fans = max ( fans, fw [ i - 1 ] + bw [ i + 1 ] );\n  return fans;\n}\n", "COUNT_NUMBER_WAYS_TILE_FLOOR_SIZE_N_X_M_USING_1_X_M_SIZE_TILES": "int countWays ( int n, int m ) {\n  int count [ n + 1 ];\n  count [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    if ( i > m ) count [ i ] = count [ i - 1 ] + count [ i - m ];\n    else if ( i < m ) count [ i ] = 1;\n    else count [ i ] = 2;\n  }\n  return count [ n ];\n}\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS": "int middleOfThree ( int a, int b, int c ) {\n  if ( ( a < b && b < c ) || ( c < b && b < a ) ) return b;\n  else if ( ( b < a && a < c ) || ( c < a && a < b ) ) return a;\n  else return c;\n}\n", "LONGEST_COMMON_INCREASING_SUBSEQUENCE_LCS_LIS": "int LCIS ( int arr1 [ ], int n, int arr2 [ ], int m ) {\n  int table [ m ];\n  for ( int j = 0;\n  j < m;\n  j ++ ) table [ j ] = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int current = 0;\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( arr1 [ i ] == arr2 [ j ] ) if ( current + 1 > table [ j ] ) table [ j ] = current + 1;\n      if ( arr1 [ i ] > arr2 [ j ] ) if ( table [ j ] > current ) current = table [ j ];\n    }\n  }\n  int result = 0;\n  for ( int i = 0;\n  i < m;\n  i ++ ) if ( table [ i ] > result ) result = table [ i ];\n  return result;\n}\n", "MAXIMUM_SUBSEQUENCE_SUM_SUCH_THAT_NO_THREE_ARE_CONSECUTIVE": "int maxSumWO3Consec ( int arr [ ], int n ) {\n  int sum [ n ];\n  if ( n >= 1 ) sum [ 0 ] = arr [ 0 ];\n  if ( n >= 2 ) sum [ 1 ] = arr [ 0 ] + arr [ 1 ];\n  if ( n > 2 ) sum [ 2 ] = max ( sum [ 1 ], max ( arr [ 1 ] + arr [ 2 ], arr [ 0 ] + arr [ 2 ] ) );\n  for ( int i = 3;\n  i < n;\n  i ++ ) 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}\n", "EULERIAN_NUMBER_1": "int eulerian ( int n, int m ) {\n  int dp [ n + 1 ] [ m + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= m;\n    j ++ ) {\n      if ( i > j ) {\n        if ( j == 0 ) dp [ i ] [ j ] = 1;\n        else dp [ i ] [ j ] = ( ( i - j ) * dp [ i - 1 ] [ j - 1 ] ) + ( ( j + 1 ) * dp [ i - 1 ] [ j ] );\n      }\n    }\n  }\n  return dp [ n ] [ m ];\n}\n", "DOUBLE_FACTORIAL": "unsigned int doublefactorial ( unsigned int n ) {\n  if ( n == 0 || n == 1 ) return 1;\n  return n * doublefactorial ( n - 2 );\n}\n", "REARRANGE_POSITIVE_AND_NEGATIVE_NUMBERS_PUBLISH": "void GFG :: rearrange ( int arr [ ], int n ) {\n  int i = - 1;\n  for ( int j = 0;\n  j < n;\n  j ++ ) {\n    if ( arr [ j ] < 0 ) {\n      i ++;\n      swap ( & arr [ i ], & arr [ j ] );\n    }\n  }\n  int pos = i + 1, neg = 0;\n  while ( pos < n && neg < pos && arr [ neg ] < 0 ) {\n    swap ( & arr [ neg ], & arr [ pos ] );\n    pos ++;\n    neg += 2;\n  }\n}\n", "MAXIMIZE_ARRAY_SUN_AFTER_K_NEGATION_OPERATIONS": "int maximumSum ( int arr [ ], int n, int k ) {\n  for ( int i = 1;\n  i <= k;\n  i ++ ) {\n    int min = INT_MAX;\n    int index = - 1;\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( arr [ j ] < min ) {\n        min = arr [ j ];\n        index = j;\n      }\n    }\n    if ( min == 0 ) break;\n    arr [ index ] = - arr [ index ];\n  }\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += arr [ i ];\n  return sum;\n}\n", "MAXIMUM_SUM_INCREASING_SUBSEQUENCE_FROM_A_PREFIX_AND_A_GIVEN_ELEMENT_AFTER_PREFIX_IS_MUST": "ll pre_compute ( ll a [ ], ll n, ll index, ll k ) {\n  ll dp [ n ] [ n ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      if ( a [ i ] > a [ 0 ] ) dp [ 0 ] [ i ] = a [ i ] + a [ 0 ];\n      else dp [ 0 ] [ i ] = a [ i ];\n    }\n    for ( int i = 1;\n    i < n;\n    i ++ ) {\n      for ( int j = 0;\n      j < n;\n      j ++ ) {\n        if ( a [ j ] > a [ i ] && j > i ) {\n          if ( dp [ i - 1 ] [ i ] + a [ j ] > dp [ i - 1 ] [ j ] ) dp [ i ] [ j ] = dp [ i - 1 ] [ i ] + a [ j ];\n          else dp [ i ] [ j ] = dp [ i - 1 ] [ j ];\n        }\n        else dp [ i ] [ j ] = dp [ i - 1 ] [ j ];\n      }\n    }\n    return dp [ index ] [ k ];\n  }\n  ", "FUNCTION_COPY_STRING_ITERATIVE_RECURSIVE": "void myCopy ( char s1 [ ], char s2 [ ] ) {\n  int i = 0;\n  for ( i = 0;\n  s1 [ i ] != '\\0';\n  i ++ ) s2 [ i ] = s1 [ i ];\n  s2 [ i ] = '\\0';\n}\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND_1": "bool isSubSequence ( char str1 [ ], char str2 [ ], int m, int n ) {\n  int j = 0;\n  for ( int i = 0;\n  i < n && j < m;\n  i ++ ) if ( str1 [ j ] == str2 [ i ] ) j ++;\n  return ( j == m );\n}\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y_1": "int unitnumber ( int x, int y ) {\n  x = x % 10;\n  if ( y != 0 ) y = y % 4 + 4;\n  return ( ( ( int ) ( pow ( x, y ) ) ) % 10 );\n}\n", "PROGRAM_NEXT_FIT_ALGORITHM_MEMORY_MANAGEMENT": "void NextFit ( int blockSize [ ], int m, int processSize [ ], int n ) {\n  int allocation [ n ], j = 0;\n  memset ( allocation, - 1, sizeof ( allocation ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( j < m ) {\n      if ( blockSize [ j ] >= processSize [ i ] ) {\n        allocation [ i ] = j;\n        blockSize [ j ] -= processSize [ i ];\n        break;\n      }\n      j = ( j + 1 ) % m;\n    }\n  }\n  cout << \"\\nProcess No.\\tProcess Size\\tBlock no.\\n\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cout << \" \" << i + 1 << \"\\t\\t\" << processSize [ i ] << \"\\t\\t\";\n    if ( allocation [ i ] != - 1 ) cout << allocation [ i ] + 1;\n    else cout << \"Not Allocated\";\n    cout << endl;\n  }\n}\n", "NOBLE_INTEGERS_IN_AN_ARRAY_COUNT_OF_GREATER_ELEMENTS_IS_EQUAL_TO_VALUE": "int nobleInteger ( int arr [ ], int size ) {\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\n    int count = 0;\n    for ( int j = 0;\n    j < size;\n    j ++ ) if ( arr [ i ] < arr [ j ] ) count ++;\n    if ( count == arr [ i ] ) return arr [ i ];\n  }\n  return - 1;\n}\n", "MINIMUM_FLIP_REQUIRED_MAKE_BINARY_MATRIX_SYMMETRIC": "int minimumflip ( int mat [ ] [ N ], int n ) {\n  int transpose [ n ] [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) transpose [ i ] [ j ] = mat [ j ] [ i ];\n  int flip = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) if ( transpose [ i ] [ j ] != mat [ i ] [ j ] ) flip ++;\n  return flip / 2;\n}\n", "SEGREGATE_EVEN_ODD_NUMBERS_SET_3": "void arrayEvenAndOdd ( int arr [ ], int n ) {\n  int i = - 1, j = 0;\n  int t;\n  while ( j != n ) {\n    if ( arr [ j ] % 2 == 0 ) {\n      i ++;\n      swap ( arr [ i ], arr [ j ] );\n    }\n    j ++;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "DFS_N_ARY_TREE_ACYCLIC_GRAPH_REPRESENTED_ADJACENCY_LIST": "void dfs ( vector < int > list [ ], int node, int arrival ) {\n  cout << node << '\\n';\n  for ( int i = 0;\n  i < list [ node ] . size ( );\n  i ++ ) {\n    if ( list [ node ] [ i ] != arrival ) dfs ( list, list [ node ] [ i ], node );\n  }\n}\n", "HOW_TO_TURN_OFF_A_PARTICULAR_BIT_IN_A_NUMBER": "int turnOffK ( int n, int k ) {\n  if ( k <= 0 ) return n;\n  return ( n & ~ ( 1 << ( k - 1 ) ) );\n}\n", "NUMBER_SUBSTRINGS_DIVISIBLE_8_NOT_3": "int count ( char s [ ], int len ) {\n  int cur = 0, dig = 0;\n  int sum [ MAX ], dp [ MAX ] [ 3 ];\n  memset ( sum, 0, sizeof ( sum ) );\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i <= len;\n  i ++ ) {\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 ] ] ++;\n  }\n  int ans = 0, dprev = 0, value = 0, dprev2 = 0;\n  for ( int i = 1;\n  i <= len;\n  i ++ ) {\n    dig = int ( s [ i - 1 ] ) - 48;\n    if ( dig == 8 ) ans ++;\n    if ( i - 2 >= 0 ) {\n      dprev = int ( s [ i - 2 ] ) - 48;\n      value = dprev * 10 + dig;\n      if ( ( value % 8 == 0 ) && ( value % 3 != 0 ) ) ans ++;\n    }\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 ) continue;\n      ans += ( i - 2 );\n      ans -= ( dp [ i - 3 ] [ sum [ i ] ] );\n    }\n  }\n  return ans;\n}\n", "ADD_1_TO_A_GIVEN_NUMBER_1": "int addOne ( int x ) {\n  return ( - ( ~ x ) );\n}\n", "CHECK_STRING_FOLLOWS_ANBN_PATTERN_NOT": "bool isAnBn ( string str ) {\n  int n = str . length ( );\n  int i;\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( str [ i ] != 'a' ) break;\n  if ( i * 2 != n ) return false;\n  int j;\n  for ( j = i;\n  j < n;\n  j ++ ) if ( str [ j ] != 'b' ) return false;\n  return true;\n}\n", "FIND_FIRST_REPEATING_ELEMENT_ARRAY_INTEGERS": "void printFirstRepeating ( int arr [ ], int n ) {\n  int min = - 1;\n  set < int > myset;\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    if ( myset . find ( arr [ i ] ) != myset . end ( ) ) min = i;\n    else myset . insert ( arr [ i ] );\n  }\n  if ( min != - 1 ) cout << \"The first repeating element is \" << arr [ min ];\n  else cout << \"There are no repeating elements\";\n}\n", "COST_BALANCE_PARANTHESES": "int costToBalance ( string s ) {\n  if ( s . length ( ) == 0 ) cout << 0 << endl;\n  int ans = 0;\n  int o = 0, c = 0;\n  for ( int i = 0;\n  i < s . length ( );\n  i ++ ) {\n    if ( s [ i ] == '(' ) o ++;\n    if ( s [ i ] == ')' ) c ++;\n  }\n  if ( o != c ) return - 1;\n  int a [ s . size ( ) ];\n  if ( s [ 0 ] == '(' ) a [ 0 ] = 1;\n  else a [ 0 ] = - 1;\n  if ( a [ 0 ] < 0 ) ans += abs ( a [ 0 ] );\n  for ( int i = 1;\n  i < s . length ( );\n  i ++ ) {\n    if ( s [ i ] == '(' ) a [ i ] = a [ i - 1 ] + 1;\n    else a [ i ] = a [ i - 1 ] - 1;\n    if ( a [ i ] < 0 ) ans += abs ( a [ i ] );\n  }\n  return ans;\n}\n", "COIN_GAME_WINNER_EVERY_PLAYER_THREE_CHOICES": "bool findWinner ( int x, int y, int n ) {\n  int dp [ n + 1 ];\n  dp [ 0 ] = false;\n  dp [ 1 ] = true;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    if ( i - 1 >= 0 and ! dp [ i - 1 ] ) dp [ i ] = true;\n    else if ( i - x >= 0 and ! dp [ i - x ] ) dp [ i ] = true;\n    else if ( i - y >= 0 and ! dp [ i - y ] ) dp [ i ] = true;\n    else dp [ i ] = false;\n  }\n  return dp [ n ];\n}\n", "SEQUENCES_GIVEN_LENGTH_EVERY_ELEMENT_EQUAL_TWICE_PREVIOUS": "int getTotalNumberOfSequences ( int m, int n ) {\n  if ( m < n ) return 0;\n  if ( n == 0 ) return 1;\n  return getTotalNumberOfSequences ( m - 1, n ) + getTotalNumberOfSequences ( m / 2, n - 1 );\n}\n", "FIND_DUPLICATES_GIVEN_ARRAY_ELEMENTS_NOT_LIMITED_RANGE": "void printDuplicates ( int arr [ ], int n ) {\n  unordered_map < int, int > freq;\n  for ( int i = 0;\n  i < n;\n  i ++ ) freq [ arr [ i ] ] ++;\n  bool dup = false;\n  unordered_map < int, int > :: iterator itr;\n  for ( itr = freq . begin ( );\n  itr != freq . end ( );\n  itr ++ ) {\n    if ( itr -> second > 1 ) {\n      cout << itr -> first << \" \";\n      dup = true;\n    }\n  }\n  if ( dup == false ) cout << \"-1\";\n}\n", "LONGEST_REPEATING_SUBSEQUENCE_1": "int findLongestRepeatingSubSeq ( string X, int m, int n ) {\n  if ( dp [ m ] [ n ] != - 1 ) return dp [ m ] [ n ];\n  if ( m == 0 || n == 0 ) return dp [ m ] [ n ] = 0;\n  if ( X [ m - 1 ] == X [ n - 1 ] && m != n ) return dp [ m ] [ n ] = findLongestRepeatingSubSeq ( X, m - 1, n - 1 ) + 1;\n  return dp [ m ] [ n ] = max ( findLongestRepeatingSubSeq ( X, m, n - 1 ), findLongestRepeatingSubSeq ( X, m - 1, n ) );\n}\n", "COUNT_OF_N_DIGIT_NUMBERS_WHOSE_SUM_OF_DIGITS_EQUALS_TO_GIVEN_SUM": "void findCount ( int n, int sum ) {\n  int start = pow ( 10, n - 1 );\n  int end = pow ( 10, n ) - 1;\n  int count = 0;\n  int i = start;\n  while ( i <= end ) {\n    int cur = 0;\n    int temp = i;\n    while ( temp != 0 ) {\n      cur += temp % 10;\n      temp = temp / 10;\n    }\n    if ( cur == sum ) {\n      count ++;\n      i += 9;\n    }\n    else i ++;\n  }\n  cout << count;\n}\n", "MINIMUM_COST_CONNECT_WEIGHTED_NODES_REPRESENTED_ARRAY": "int minimum_cost ( int a [ ], int n ) {\n  int mn = INT_MAX;\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    mn = min ( a [ i ], mn );\n    sum += a [ i ];\n  }\n  return mn * ( sum - mn );\n}\n", "FIND_ALL_DIVISORS_OF_A_NATURAL_NUMBER_SET_2": "void printDivisors ( int n ) {\n  vector < int > v;\n  for ( int i = 1;\n  i <= sqrt ( n );\n  i ++ ) {\n    if ( n % i == 0 ) {\n      if ( n / i == i ) printf ( \"%d \", i );\n      else {\n        printf ( \"%d \", i );\n        v . push_back ( n / i );\n      }\n    }\n  }\n  for ( int i = v . size ( ) - 1;\n  i >= 0;\n  i -- ) printf ( \"%d \", v [ i ] );\n}\n", "SQUARES_OF_MATRIX_DIAGONAL_ELEMENTS_1": "void diagonalsquare ( int mat [ ] [ MAX ], int row, int column ) {\n  cout << \" \\nDiagonal one : \";\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    cout << mat [ i ] [ i ] * mat [ i ] [ i ] << \" \";\n  }\n  cout << \" \\n\\nDiagonal two : \";\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    cout << mat [ i ] [ row - i - 1 ] * mat [ i ] [ row - i - 1 ] << \" \";\n  }\n}\n", "C_PROGRAM_FIND_AREA_TRIANGLE_1": "double polygonArea ( double X [ ], double Y [ ], int n ) {\n  double area = 0.0;\n  int j = n - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    area += ( X [ j ] + X [ i ] ) * ( Y [ j ] - Y [ i ] );\n    j = i;\n  }\n  return abs ( area / 2.0 );\n}\n", "RANGE_QUERIES_FOR_FREQUENCIES_OF_ARRAY_ELEMENTS": "int findFrequency ( int arr [ ], int n, int left, int right, int element ) {\n  int count = 0;\n  for ( int i = left - 1;\n  i <= right;\n  ++ i ) if ( arr [ i ] == element ) ++ count;\n  return count;\n}\n", "SERIES_LARGEST_GCD_SUM_EQUALS_N": "void print_sequence ( int n, int k ) {\n  int b = n / ( k * ( k + 1 ) / 2 );\n  if ( b == 0 ) {\n    cout << - 1 << endl;\n  }\n  else {\n    int r = 1;\n    for ( int x = 1;\n    x * x <= n;\n    x ++ ) {\n      if ( n % x != 0 ) continue;\n      if ( x <= b && x > r ) r = x;\n      if ( n / x <= b && n / x > r ) r = n / x;\n    }\n    for ( int i = 1;\n    i < k;\n    i ++ ) cout << r * i << \" \";\n    int res = n - ( r * ( k * ( k - 1 ) / 2 ) );\n    cout << res << endl;\n  }\n}\n", "FIND_THREE_ELEMENT_FROM_DIFFERENT_THREE_ARRAYS_SUCH_THAT_THAT_A_B_C_K_1": "bool findTriplet ( int a1 [ ], int a2 [ ], int a3 [ ], int n1, int n2, int n3, int sum ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n1;\n  i ++ ) s . insert ( a1 [ i ] );\n  for ( int i = 0;\n  i < n2;\n  i ++ ) {\n    for ( int j = 0;\n    j < n3;\n    j ++ ) {\n      if ( s . find ( sum - a2 [ i ] - a3 [ j ] ) != s . end ( ) ) return true;\n    }\n  }\n  return false;\n}\n", "FIND_THE_MAXIMUM_ELEMENT_IN_AN_ARRAY_WHICH_IS_FIRST_INCREASING_AND_THEN_DECREASING_1": "int findMaximum ( int arr [ ], int low, int high ) {\n  if ( low == high ) return arr [ low ];\n  if ( ( high == low + 1 ) && arr [ low ] >= arr [ high ] ) return arr [ low ];\n  if ( ( high == low + 1 ) && arr [ low ] < arr [ high ] ) return arr [ high ];\n  int mid = ( low + high ) / 2;\n  if ( arr [ mid ] > arr [ mid + 1 ] && arr [ mid ] > arr [ mid - 1 ] ) return arr [ mid ];\n  if ( arr [ mid ] > arr [ mid + 1 ] && arr [ mid ] < arr [ mid - 1 ] ) return findMaximum ( arr, low, mid - 1 );\n  else return findMaximum ( arr, mid + 1, high );\n}\n", "DYNAMIC_PROGRAMMING_SET_1": "int fib ( int n ) {\n  if ( lookup [ n ] == NIL ) {\n    if ( n <= 1 ) lookup [ n ] = n;\n    else lookup [ n ] = fib ( n - 1 ) + fib ( n - 2 );\n  }\n  return lookup [ n ];\n}\n", "MODULAR_EXPONENTIATION_POWER_IN_MODULAR_ARITHMETIC": "int power ( int x, unsigned int y, int p ) {\n  int res = 1;\n  x = x % p;\n  while ( y > 0 ) {\n    if ( y & 1 ) res = ( res * x ) % p;\n    y = y >> 1;\n    x = ( x * x ) % p;\n  }\n  return res;\n}\n", "WRITE_ONE_LINE_C_FUNCTION_TO_FIND_WHETHER_A_NO_IS_POWER_OF_TWO_1": "int bool isPowerOfTwo ( int x ) {\n  return x && ( ! ( x & ( x - 1 ) ) );\n}\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_PERMUTATIONS_ALLOWED": "void longestString ( string str1, string str2 ) {\n  int count1 [ 26 ] = {\n    0 },\n    count2 [ 26 ] = {\n      0 };\n      for ( int i = 0;\n      i < str1 . length ( );\n      i ++ ) count1 [ str1 [ i ] - 'a' ] ++;\n      for ( int i = 0;\n      i < str2 . length ( );\n      i ++ ) count2 [ str2 [ i ] - 'a' ] ++;\n      string result;\n      for ( int i = 0;\n      i < 26;\n      i ++ ) for ( int j = 1;\n      j <= min ( count1 [ i ], count2 [ i ] );\n      j ++ ) result . push_back ( 'a' + i );\n      cout << result;\n    }\n    ", "DIFFERENCE_MAXIMUM_SUM_MINIMUM_SUM_N_M_ELEMENTSIN_REVIEW": "int find_difference ( int arr [ ], int n, int m ) {\n  int max = 0, min = 0;\n  sort ( arr, arr + n );\n  for ( int i = 0, j = n - 1;\n  i < m;\n  i ++, j -- ) {\n    min += arr [ i ];\n    max += arr [ j ];\n  }\n  return ( max - min );\n}\n", "PRINT_NUMBER_ASCENDING_ORDER_CONTAINS_1_2_3_DIGITS": "string printNumbers ( int numbers [ ], int n ) {\n  vector < int > oneTwoThree;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( findContainsOneTwoThree ( numbers [ i ] ) ) oneTwoThree . push_back ( numbers [ i ] );\n  }\n  sort ( oneTwoThree . begin ( ), oneTwoThree . end ( ) );\n  string result = \"\";\n  for ( auto number : oneTwoThree ) {\n    int value = number;\n    if ( result . length ( ) > 0 ) result += \", \";\n    result += to_string ( value );\n  }\n  return ( result . length ( ) > 0 ) ? result : \"-1\";\n}\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE": "int lis ( int arr [ ], int n ) {\n  int max = 1;\n  _lis ( arr, n, & max );\n  return max;\n}\n", "MINIMUM_REVOLUTIONS_MOVE_CENTER_CIRCLE_TARGET": "int minRevolutions ( double r, int x1, int y1, int x2, int y2 ) {\n  double d = sqrt ( ( x1 - x2 ) * ( x1 - x2 ) + ( y1 - y2 ) * ( y1 - y2 ) );\n  return ceil ( d / ( 2 * r ) );\n}\n", "CHECK_TWO_GIVEN_SETS_DISJOINT": "bool areDisjoint ( int set1 [ ], int set2 [ ], int m, int n ) {\n  for ( int i = 0;\n  i < m;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) if ( set1 [ i ] == set2 [ j ] ) return false;\n  return true;\n}\n", "FIND_MINIMUM_SUM_FACTORS_NUMBER": "int findMinSum ( int num ) {\n  int sum = 0;\n  for ( int i = 2;\n  i * i <= num;\n  i ++ ) {\n    while ( num % i == 0 ) {\n      sum += i;\n      num /= i;\n    }\n  }\n  sum += num;\n  return sum;\n}\n", "FREQUENT_ELEMENT_ARRAY": "int mostFrequent ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int max_count = 1, res = arr [ 0 ], curr_count = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == arr [ i - 1 ] ) curr_count ++;\n    else {\n      if ( curr_count > max_count ) {\n        max_count = curr_count;\n        res = arr [ i - 1 ];\n      }\n      curr_count = 1;\n    }\n  }\n  if ( curr_count > max_count ) {\n    max_count = curr_count;\n    res = arr [ n - 1 ];\n  }\n  return res;\n}\n", "MINIMUM_XOR_VALUE_PAIR_1": "int minXOR ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int minXor = INT_MAX;\n  int val = 0;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    val = arr [ i ] ^ arr [ i + 1 ];\n    minXor = min ( minXor, val );\n  }\n  return minXor;\n}\n", "MINIMUM_SUM_PRODUCT_TWO_ARRAYS": "int minproduct ( int a [ ], int b [ ], int n, int k ) {\n  int diff = 0, res = 0;\n  int temp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int pro = a [ i ] * b [ i ];\n    res = res + pro;\n    if ( pro < 0 && b [ i ] < 0 ) temp = ( a [ i ] + 2 * k ) * b [ i ];\n    else if ( pro < 0 && a [ i ] < 0 ) temp = ( a [ i ] - 2 * k ) * b [ i ];\n    else if ( pro > 0 && a [ i ] < 0 ) temp = ( a [ i ] + 2 * k ) * b [ i ];\n    else if ( pro > 0 && a [ i ] > 0 ) temp = ( a [ i ] - 2 * k ) * b [ i ];\n    int d = abs ( pro - temp );\n    if ( d > diff ) diff = d;\n  }\n  return res - diff;\n}\n", "FAST_MULTIPLICATION_METHOD_WITHOUT_USING_MULTIPLICATION_OPERATOR_RUSSIAN_PEASANTS_ALGORITHM": "unsigned int russianPeasant ( unsigned int a, unsigned int b ) {\n  int res = 0;\n  while ( b > 0 ) {\n    if ( b & 1 ) res = res + a;\n    a = a << 1;\n    b = b >> 1;\n  }\n  return res;\n}\n", "DIVISIBILITY_9_USING_BITWISE_OPERATORS": "bool isDivBy9 ( int n ) {\n  if ( n == 0 || n == 9 ) return true;\n  if ( n < 9 ) return false;\n  return isDivBy9 ( ( int ) ( n >> 3 ) - ( int ) ( n & 7 ) );\n}\n", "CHECK_ARRAY_REPRESENTS_INORDER_BINARY_SEARCH_TREE_NOT": "bool isInorder ( int arr [ ], int n ) {\n  if ( n == 0 || n == 1 ) return true;\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( arr [ i - 1 ] > arr [ i ] ) return false;\n  return true;\n}\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X": "void findPairs ( int arr1 [ ], int arr2 [ ], int n, int m, int x ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) if ( arr1 [ i ] + arr2 [ j ] == x ) cout << arr1 [ i ] << \" \" << arr2 [ j ] << endl;\n}\n", "BINARY_REPRESENTATION_OF_NEXT_NUMBER": "string nextGreater ( string num ) {\n  int l = num . size ( );\n  for ( int i = l - 1;\n  i >= 0;\n  i -- ) {\n    if ( num . at ( i ) == '0' ) {\n      num . at ( i ) = '1';\n      break;\n    }\n    else num . at ( i ) = '0';\n  }\n  if ( i < 0 ) num = \"1\" + num;\n  return num;\n}\n", "LARGEST_SUBARRAY_WITH_EQUAL_NUMBER_OF_0S_AND_1S": "int findSubArray ( int arr [ ], int n ) {\n  int sum = 0;\n  int maxsize = - 1, startindex;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    sum = ( arr [ i ] == 0 ) ? - 1 : 1;\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      ( arr [ j ] == 0 ) ? ( sum += - 1 ) : ( sum += 1 );\n      if ( sum == 0 && maxsize < j - i + 1 ) {\n        maxsize = j - i + 1;\n        startindex = i;\n      }\n    }\n  }\n  if ( maxsize == - 1 ) cout << \"No such subarray\";\n  else cout << startindex << \" to \" << startindex + maxsize - 1;\n  return maxsize;\n}\n", "COUNT_PAIRS_WHOSE_PRODUCTS_EXIST_IN_ARRAY_1": "int countPairs ( int arr [ ], int n ) {\n  int result = 0;\n  set < int > Hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) Hash . insert ( arr [ i ] );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int product = arr [ i ] * arr [ j ];\n      if ( Hash . find ( product ) != Hash . end ( ) ) result ++;\n    }\n  }\n  return result;\n}\n", "DYNAMIC_PROGRAMMING_SET_12_LONGEST_PALINDROMIC_SUBSEQUENCE": "int lps ( char * str ) {\n  int n = strlen ( str );\n  int i, j, cl;\n  int L [ n ] [ n ];\n  for ( i = 0;\n  i < n;\n  i ++ ) L [ i ] [ i ] = 1;\n  for ( cl = 2;\n  cl <= n;\n  cl ++ ) {\n    for ( i = 0;\n    i < n - cl + 1;\n    i ++ ) {\n      j = i + cl - 1;\n      if ( str [ i ] == str [ j ] && cl == 2 ) L [ i ] [ j ] = 2;\n      else if ( str [ i ] == str [ j ] ) L [ i ] [ j ] = L [ i + 1 ] [ j - 1 ] + 2;\n      else L [ i ] [ j ] = max ( L [ i ] [ j - 1 ], L [ i + 1 ] [ j ] );\n    }\n  }\n  return L [ 0 ] [ n - 1 ];\n}\n", "COUNT_INVERSIONS_OF_SIZE_THREE_IN_A_GIVE_ARRAY_1": "int getInvCount ( int arr [ ], int n ) {\n  int invcount = 0;\n  for ( int i = 1;\n  i < n - 1;\n  i ++ ) {\n    int small = 0;\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) if ( arr [ i ] > arr [ j ] ) small ++;\n    int great = 0;\n    for ( int j = i - 1;\n    j >= 0;\n    j -- ) if ( arr [ i ] < arr [ j ] ) great ++;\n    invcount += great * small;\n  }\n  return invcount;\n}\n", "DECIMAL_REPRESENTATION_GIVEN_BINARY_STRING_DIVISIBLE_10_NOT": "bool isDivisibleBy10 ( string bin ) {\n  int n = bin . size ( );\n  if ( bin [ n - 1 ] == '1' ) return false;\n  int sum = 0;\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( bin [ i ] == '1' ) {\n      int posFromRight = n - i - 1;\n      if ( posFromRight % 4 == 1 ) sum = sum + 2;\n      else if ( posFromRight % 4 == 2 ) sum = sum + 4;\n      else if ( posFromRight % 4 == 3 ) sum = sum + 8;\n      else if ( posFromRight % 4 == 0 ) sum = sum + 6;\n    }\n  }\n  if ( sum % 10 == 0 ) return true;\n  return false;\n}\n", "FIND_WHETHER_AN_ARRAY_IS_SUBSET_OF_ANOTHER_ARRAY_SET_1_1": "bool isSubset ( int arr1 [ ], int arr2 [ ], int m, int n ) {\n  int i = 0, j = 0;\n  if ( m < n ) return 0;\n  sort ( arr1, arr1 + m );\n  sort ( arr2, arr2 + n );\n  while ( i < n && j < m ) {\n    if ( arr1 [ j ] < arr2 [ i ] ) j ++;\n    else if ( arr1 [ j ] == arr2 [ i ] ) {\n      j ++;\n      i ++;\n    }\n    else if ( arr1 [ j ] > arr2 [ i ] ) return 0;\n  }\n  return ( i < n ) ? false : true;\n}\n", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM_1": "bool isSubsetSum ( int set [ ], int n, int sum ) {\n  bool subset [ n + 1 ] [ sum + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) subset [ i ] [ 0 ] = true;\n  for ( int i = 1;\n  i <= sum;\n  i ++ ) subset [ 0 ] [ i ] = false;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= sum;\n    j ++ ) {\n      if ( j < set [ i - 1 ] ) subset [ i ] [ j ] = subset [ i - 1 ] [ j ];\n      if ( j >= set [ i - 1 ] ) subset [ i ] [ j ] = subset [ i - 1 ] [ j ] || subset [ i - 1 ] [ j - set [ i - 1 ] ];\n    }\n  }\n  return subset [ n ] [ sum ];\n}\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS_1": "int kthgroupsum ( int k ) {\n  return k * k * k;\n}\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS": "void thirdLargest ( int arr [ ], int arr_size ) {\n  if ( arr_size < 3 ) {\n    printf ( \" Invalid Input \" );\n    return;\n  }\n  int first = arr [ 0 ];\n  for ( int i = 1;\n  i < arr_size;\n  i ++ ) if ( arr [ i ] > first ) first = arr [ i ];\n  int second = INT_MIN;\n  for ( int i = 0;\n  i < arr_size;\n  i ++ ) if ( arr [ i ] > second && arr [ i ] < first ) second = arr [ i ];\n  int third = INT_MIN;\n  for ( int i = 0;\n  i < arr_size;\n  i ++ ) if ( arr [ i ] > third && arr [ i ] < second ) third = arr [ i ];\n  printf ( \"The third Largest element is %d\\n\", third );\n}\n", "FIND_SUM_NODES_GIVEN_PERFECT_BINARY_TREE_1": "int sumNodes ( int l ) {\n  int leafNodeCount = pow ( 2, l - 1 );\n  int sumLastLevel = 0;\n  sumLastLevel = ( leafNodeCount * ( leafNodeCount + 1 ) ) / 2;\n  int sum = sumLastLevel * l;\n  return sum;\n}\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS_2": "int middleOfThree ( int a, int b, int c ) {\n  int x = a - b;\n  int y = b - c;\n  int z = a - c;\n  if ( x * y > 0 ) return b;\n  else if ( x * z > 0 ) return c;\n  else return a;\n}\n", "MAXIMUM_TRIPLET_SUM_ARRAY_2": "int maxTripletSum ( int arr [ ], int n ) {\n  int maxA = INT_MIN, maxB = INT_MIN, maxC = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] > maxA ) {\n      maxC = maxB;\n      maxB = maxA;\n      maxA = arr [ i ];\n    }\n    else if ( arr [ i ] > maxB ) {\n      maxC = maxB;\n      maxB = arr [ i ];\n    }\n    else if ( arr [ i ] > maxC ) maxC = arr [ i ];\n  }\n  return ( maxA + maxB + maxC );\n}\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X_1": "int countPairs ( int arr1 [ ], int arr2 [ ], int m, int n, int x ) {\n  int count = 0;\n  unordered_set < int > us;\n  for ( int i = 0;\n  i < m;\n  i ++ ) us . insert ( arr1 [ i ] );\n  for ( int j = 0;\n  j < n;\n  j ++ ) if ( us . find ( x - arr2 [ j ] ) != us . end ( ) ) count ++;\n  return count;\n}\n", "MINIMUM_STEPS_REACH_END_ARRAY_CONSTRAINTS": "int getMinStepToReachEnd ( int arr [ ], int N ) {\n  bool visit [ N ];\n  int distance [ N ];\n  vector < int > digit [ 10 ];\n  memset ( visit, false, sizeof ( visit ) );\n  for ( int i = 1;\n  i < N;\n  i ++ ) digit [ arr [ i ] ] . push_back ( i );\n  distance [ 0 ] = 0;\n  visit [ 0 ] = true;\n  queue < int > q;\n  q . push ( 0 );\n  while ( ! q . empty ( ) ) {\n    int idx = q . front ( );\n    q . pop ( );\n    if ( idx == N - 1 ) break;\n    int d = arr [ idx ];\n    for ( int i = 0;\n    i < digit [ d ] . size ( );\n    i ++ ) {\n      int nextidx = digit [ d ] [ i ];\n      if ( ! visit [ nextidx ] ) {\n        visit [ nextidx ] = true;\n        q . push ( nextidx );\n        distance [ nextidx ] = distance [ idx ] + 1;\n      }\n    }\n    digit [ d ] . clear ( );\n    if ( idx - 1 >= 0 && ! visit [ idx - 1 ] ) {\n      visit [ idx - 1 ] = true;\n      q . push ( idx - 1 );\n      distance [ idx - 1 ] = distance [ idx ] + 1;\n    }\n    if ( idx + 1 < N && ! visit [ idx + 1 ] ) {\n      visit [ idx + 1 ] = true;\n      q . push ( idx + 1 );\n      distance [ idx + 1 ] = distance [ idx ] + 1;\n    }\n  }\n  return distance [ N - 1 ];\n}\n", "LEXICOGRAPHICALLY_SMALLEST_ARRAY_K_CONSECUTIVE_SWAPS": "void minimizeWithKSwaps ( int arr [ ], int n, int k ) {\n  for ( int i = 0;\n  i < n - 1 && k > 0;\n  ++ i ) {\n    int pos = i;\n    for ( int j = i + 1;\n    j < n;\n    ++ j ) {\n      if ( j - i > k ) break;\n      if ( arr [ j ] < arr [ pos ] ) pos = j;\n    }\n    for ( int j = pos;\n    j > i;\n    -- j ) swap ( arr [ j ], arr [ j - 1 ] );\n    k -= pos - i;\n  }\n}\n", "CONVERT_SENTENCE_EQUIVALENT_MOBILE_NUMERIC_KEYPAD_SEQUENCE": "string printSequence ( string arr [ ], string input ) {\n  string output = \"\";\n  int n = input . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( input [ i ] == ' ' ) output = output + \"0\";\n    else {\n      int position = input [ i ] - 'A';\n      output = output + arr [ position ];\n    }\n  }\n  return output;\n}\n", "PROGRAM_CHECK_ARRAY_SORTED_NOT_ITERATIVE_RECURSIVE": "int arraySortedOrNot ( int arr [ ], int n ) {\n  if ( n == 1 || n == 0 ) return 1;\n  if ( arr [ n - 1 ] < arr [ n - 2 ] ) return 0;\n  return arraySortedOrNot ( arr, n - 1 );\n}\n", "CHECK_TWO_GIVEN_CIRCLES_TOUCH_INTERSECT": "int circle ( int x1, int y1, int x2, int y2, int r1, int r2 ) {\n  int distSq = ( x1 - x2 ) * ( x1 - x2 ) + ( y1 - y2 ) * ( y1 - y2 );\n  int radSumSq = ( r1 + r2 ) * ( r1 + r2 );\n  if ( distSq == radSumSq ) return 1;\n  else if ( distSq > radSumSq ) return - 1;\n  else return 0;\n}\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N_2": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  n --;\n  n |= n >> 1;\n  n |= n >> 2;\n  n |= n >> 4;\n  n |= n >> 8;\n  n |= n >> 16;\n  n ++;\n  return n;\n}\n", "PADOVAN_SEQUENCE": "int pad ( int n ) {\n  int pPrevPrev = 1, pPrev = 1, pCurr = 1, pNext = 1;\n  for ( int i = 3;\n  i <= n;\n  i ++ ) {\n    pNext = pPrevPrev + pPrev;\n    pPrevPrev = pPrev;\n    pPrev = pCurr;\n    pCurr = pNext;\n  }\n  return pNext;\n}\n", "CHECK_GIVEN_STRING_CAN_SPLIT_FOUR_DISTINCT_STRINGS": "bool check ( string s ) {\n  if ( s . size ( ) >= 10 ) return true;\n  for ( int i = 1;\n  i < s . size ( );\n  i ++ ) {\n    for ( int j = i + 1;\n    j < s . size ( );\n    j ++ ) {\n      for ( int k = j + 1;\n      k < s . size ( );\n      k ++ ) {\n        string s1 = s . substr ( 0, i );\n        string s2 = s . substr ( i, j - i );\n        string s3 = s . substr ( j, k - j );\n        string s4 = s . substr ( k, s . size ( ) - k );\n        if ( s1 != s2 && s1 != s3 && s1 != s4 && s2 != s3 && s2 != s4 && s3 != s4 ) return true;\n      }\n    }\n  }\n  return false;\n}\n", "PERMUTE_TWO_ARRAYS_SUM_EVERY_PAIR_GREATER_EQUAL_K": "bool isPossible ( int a [ ], int b [ ], int n, int k ) {\n  sort ( a, a + n );\n  sort ( b, b + n, greater < int > ( ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( a [ i ] + b [ i ] < k ) return false;\n  return true;\n}\n", "ARRAY_ELEMENT_MOVED_K_USING_SINGLE_MOVES": "int winner ( int a [ ], int n, int k ) {\n  if ( k >= n - 1 ) return n;\n  int best = 0, times = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] > best ) {\n      best = a [ i ];\n      if ( i ) times = 1;\n    }\n    else times += 1;\n    if ( times >= k ) return best;\n  }\n  return best;\n}\n", "DIRECTION_LAST_SQUARE_BLOCK": "void direction ( ll R, ll C ) {\n  if ( R != C && R % 2 == 0 && C % 2 != 0 && R < C ) {\n    cout << \"Left\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 == 0 && R > C ) {\n    cout << \"Up\" << endl;\n    return;\n  }\n  if ( R == C && R % 2 != 0 && C % 2 != 0 ) {\n    cout << \"Right\" << endl;\n    return;\n  }\n  if ( R == C && R % 2 == 0 && C % 2 == 0 ) {\n    cout << \"Left\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 != 0 && R < C ) {\n    cout << \"Right\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 != 0 && R > C ) {\n    cout << \"Down\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 == 0 && R < C ) {\n    cout << \"Left\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 == 0 && R > C ) {\n    cout << \"Up\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 != 0 && R > C ) {\n    cout << \"Down\" << endl;\n    return;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 == 0 && R < C ) {\n    cout << \"Right\" << endl;\n    return;\n  }\n}\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N": "int countIntegralSolutions ( int n ) {\n  int result = 0;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) for ( int j = 0;\n  j <= n - i;\n  j ++ ) for ( int k = 0;\n  k <= ( n - i - j );\n  k ++ ) if ( i + j + k == n ) result ++;\n  return result;\n}\n", "SWAP_MAJOR_MINOR_DIAGONALS_SQUARE_MATRIX": "void swapDiagonal ( int matrix [ ] [ N ] ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) swap ( matrix [ i ] [ i ], matrix [ i ] [ N - i - 1 ] );\n}\n", "MINIMUM_OPERATIONS_MAKE_GCD_ARRAY_MULTIPLE_K": "int MinOperation ( int a [ ], int n, int k ) {\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    if ( a [ i ] != 1 && a [ i ] > k ) {\n      result = result + min ( a [ i ] % k, k - a [ i ] % k );\n    }\n    else {\n      result = result + k - a [ i ];\n    }\n  }\n  return result;\n}\n", "MAXIMUM_DECIMAL_VALUE_PATH_IN_A_BINARY_MATRIX": "long long int maxDecimalValue ( int mat [ ] [ N ], int i, int j, int p ) {\n  if ( i >= N || j >= N ) return 0;\n  int result = max ( maxDecimalValue ( mat, i, j + 1, p + 1 ), maxDecimalValue ( mat, i + 1, j, p + 1 ) );\n  if ( mat [ i ] [ j ] == 1 ) return pow ( 2, p ) + result;\n  else return result;\n}\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE_1": "public : float squareRoot ( float n ) {\n  float x = n;\n  float y = 1;\n  float e = 0.000001;\n  while ( x - y > e ) {\n    x = ( x + y ) / 2;\n    y = n / x;\n  }\n  return x;\n}\n", "FIND_MINIMUM_SHIFT_LONGEST_COMMON_PREFIX": "void KMP ( int m, int n, string str2, string str1 ) {\n  int pos = 0, len = 0;\n  int p [ m + 1 ];\n  int k = 0;\n  p [ 1 ] = 0;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    while ( k > 0 && str1 [ k ] != str1 [ i - 1 ] ) k = p [ k ];\n    if ( str1 [ k ] == str1 [ i - 1 ] ) ++ k;\n    p [ i ] = k;\n  }\n  for ( int j = 0, i = 0;\n  i < m;\n  i ++ ) {\n    while ( j > 0 && str1 [ j ] != str2 [ i ] ) j = p [ j ];\n    if ( str1 [ j ] == str2 [ i ] ) j ++;\n    if ( j > len ) {\n      len = j;\n      pos = i - j + 1;\n    }\n  }\n  cout << \"Shift = \" << pos << endl;\n  cout << \"Prefix = \" << str1 . substr ( 0, len );\n}\n", "SORTED_ORDER_PRINTING_OF_AN_ARRAY_THAT_REPRESENTS_A_BST": "void printSorted ( int arr [ ], int start, int end ) {\n  if ( start > end ) return;\n  printSorted ( arr, start * 2 + 1, end );\n  cout << arr [ start ] << \" \";\n  printSorted ( arr, start * 2 + 2, end );\n}\n", "CHECK_WHETHER_GIVEN_DEGREES_VERTICES_REPRESENT_GRAPH_TREE": "bool check ( int degree [ ], int n ) {\n  int deg_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) deg_sum += degree [ i ];\n  return ( 2 * ( n - 1 ) == deg_sum );\n}\n", "MOVE_ZEROES_END_ARRAY": "void pushZerosToEnd ( int arr [ ], int n ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] != 0 ) arr [ count ++ ] = arr [ i ];\n  while ( count < n ) arr [ count ++ ] = 0;\n}\n", "COUNT_ELEMENTS_WHICH_DIVIDE_ALL_NUMBERS_IN_RANGE_L_R": "int answerQuery ( int a [ ], int n, int l, int r ) {\n  int count = 0;\n  l = l - 1;\n  for ( int i = l;\n  i < r;\n  i ++ ) {\n    int element = a [ i ];\n    int divisors = 0;\n    for ( int j = l;\n    j < r;\n    j ++ ) {\n      if ( a [ j ] % a [ i ] == 0 ) divisors ++;\n      else break;\n    }\n    if ( divisors == ( r - l ) ) count ++;\n  }\n  return count;\n}\n", "SUM_LARGEST_PRIME_FACTOR_NUMBER_LESS_EQUAL_N": "int sumOfLargePrimeFactor ( int n ) {\n  int prime [ n + 1 ], sum = 0;\n  memset ( prime, 0, sizeof ( prime ) );\n  int max = n / 2;\n  for ( int p = 2;\n  p <= max;\n  p ++ ) {\n    if ( prime [ p ] == 0 ) {\n      for ( int i = p * 2;\n      i <= n;\n      i += p ) prime [ i ] = p;\n    }\n  }\n  for ( int p = 2;\n  p <= n;\n  p ++ ) {\n    if ( prime [ p ] ) sum += prime [ p ];\n    else sum += p;\n  }\n  return sum;\n}\n", "REARRANGE_A_STRING_IN_SORTED_ORDER_FOLLOWED_BY_THE_INTEGER_SUM": "string arrangeString ( string str ) {\n  int char_count [ MAX_CHAR ] = {\n    0 };\n    int sum = 0;\n    for ( int i = 0;\n    i < str . length ( );\n    i ++ ) {\n      if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) char_count [ str [ i ] - 'A' ] ++;\n      else sum = sum + ( str [ i ] - '0' );\n    }\n    string res = \"\";\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) {\n      char ch = ( char ) ( 'A' + i );\n      while ( char_count [ i ] -- ) res = res + ch;\n    }\n    if ( sum > 0 ) res = res + to_string ( sum );\n    return res;\n  }\n  ", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_1": "int numberOfPaths ( int m, int n ) {\n  int count [ m ] [ n ];\n  for ( int i = 0;\n  i < m;\n  i ++ ) count [ i ] [ 0 ] = 1;\n  for ( int j = 0;\n  j < n;\n  j ++ ) count [ 0 ] [ j ] = 1;\n  for ( int i = 1;\n  i < m;\n  i ++ ) {\n    for ( int j = 1;\n    j < n;\n    j ++ ) count [ i ] [ j ] = count [ i - 1 ] [ j ] + count [ i ] [ j - 1 ];\n  }\n  return count [ m - 1 ] [ n - 1 ];\n}\n", "DYNAMIC_PROGRAMMING_SET_5_EDIT_DISTANCE_1": "int editDistDP ( string str1, string str2, int m, int n ) {\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( i == 0 ) dp [ i ] [ j ] = j;\n      else if ( j == 0 ) dp [ i ] [ j ] = i;\n      else if ( str1 [ i - 1 ] == str2 [ j - 1 ] ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = 1 + min ( dp [ i ] [ j - 1 ], dp [ i - 1 ] [ j ], dp [ i - 1 ] [ j - 1 ] );\n    }\n  }\n  return dp [ m ] [ n ];\n}\n", "FIND_NUMBER_OF_SOLUTIONS_OF_A_LINEAR_EQUATION_OF_N_VARIABLES": "int countSol ( int coeff [ ], int start, int end, int rhs ) {\n  if ( rhs == 0 ) return 1;\n  int result = 0;\n  for ( int i = start;\n  i <= end;\n  i ++ ) if ( coeff [ i ] <= rhs ) result += countSol ( coeff, i, end, rhs - coeff [ i ] );\n  return result;\n}\n", "SUM_ELEMENTS_K1TH_K2TH_SMALLEST_ELEMENTS_1": "void minheapify ( int a [ ], int index ) {\n  int small = index;\n  int l = 2 * index + 1;\n  int r = 2 * index + 2;\n  if ( l < n && a [ l ] < a [ small ] ) small = l;\n  if ( r < n && a [ r ] < a [ small ] ) small = r;\n  if ( small != index ) {\n    swap ( a [ small ], a [ index ] );\n    minheapify ( a, small );\n  }\n}\n", "SEARCHING_FOR_PATTERNS_SET_2_KMP_ALGORITHM": "void computeLPSArray ( char * pat, int M, int * lps ) {\n  int len = 0;\n  lps [ 0 ] = 0;\n  int i = 1;\n  while ( i < M ) {\n    if ( pat [ i ] == pat [ len ] ) {\n      len ++;\n      lps [ i ] = len;\n      i ++;\n    }\n    else {\n      if ( len != 0 ) {\n        len = lps [ len - 1 ];\n      }\n      else {\n        lps [ i ] = 0;\n        i ++;\n      }\n    }\n  }\n}\n", "FIND_MINIMUM_DIFFERENCE_PAIR": "int findMinDiff ( int arr [ ], int n ) {\n  int diff = INT_MAX;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( abs ( arr [ i ] - arr [ j ] ) < diff ) diff = abs ( arr [ i ] - arr [ j ] );\n  return diff;\n}\n", "PRINT_FIRST_K_DIGITS_1N_N_POSITIVE_INTEGER": "void print ( int n, int k ) {\n  int rem = 1;\n  for ( int i = 0;\n  i < k;\n  i ++ ) {\n    cout << ( 10 * rem ) / n;\n    rem = ( 10 * rem ) % n;\n  }\n}\n", "GROUP_MULTIPLE_OCCURRENCE_OF_ARRAY_ELEMENTS_ORDERED_BY_FIRST_OCCURRENCE": "void groupElements ( int arr [ ], int n ) {\n  bool * visited = new bool [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) visited [ i ] = false;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ! visited [ i ] ) {\n      cout << arr [ i ] << \" \";\n      for ( int j = i + 1;\n      j < n;\n      j ++ ) {\n        if ( arr [ i ] == arr [ j ] ) {\n          cout << arr [ i ] << \" \";\n          visited [ j ] = true;\n        }\n      }\n    }\n  }\n  delete [ ] visited;\n}\n", "CHECK_WHETHER_ARITHMETIC_PROGRESSION_CAN_FORMED_GIVEN_ARRAY": "bool checkIsAP ( int arr [ ], int n ) {\n  if ( n == 1 ) return true;\n  sort ( arr, arr + n );\n  int d = arr [ 1 ] - arr [ 0 ];\n  for ( int i = 2;\n  i < n;\n  i ++ ) if ( arr [ i ] - arr [ i - 1 ] != d ) return false;\n  return true;\n}\n", "NTH_MULTIPLE_NUMBER_FIBONACCI_SERIES": "int findPosition ( int k, int n ) {\n  unsigned long long int f1 = 0, f2 = 1, f3;\n  for ( int i = 2;\n  i <= MAX;\n  i ++ ) {\n    f3 = f1 + f2;\n    f1 = f2;\n    f2 = f3;\n    if ( f2 % k == 0 ) return n * i;\n  }\n}\n", "COUNT_PAIRS_DIFFERENCE_EQUAL_K_1": "int countPairsWithDiffK ( int arr [ ], int n, int k ) {\n  int count = 0;\n  sort ( arr, arr + n );\n  int l = 0;\n  int r = 0;\n  while ( r < n ) {\n    if ( arr [ r ] - arr [ l ] == k ) {\n      count ++;\n      l ++;\n      r ++;\n    }\n    else if ( arr [ r ] - arr [ l ] > k ) l ++;\n    else r ++;\n  }\n  return count;\n}\n", "ELEMENTS_TO_BE_ADDED_SO_THAT_ALL_ELEMENTS_OF_A_RANGE_ARE_PRESENT_IN_ARRAY": "int countNum ( int arr [ ], int n ) {\n  int count = 0;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) if ( arr [ i ] != arr [ i + 1 ] && arr [ i ] != arr [ i + 1 ] - 1 ) count += arr [ i + 1 ] - arr [ i ] - 1;\n  return count;\n}\n", "MAKE_LARGEST_PALINDROME_CHANGING_K_DIGITS": "string maximumPalinUsingKChanges ( string str, int k ) {\n  string palin = str;\n  int l = 0;\n  int r = str . length ( ) - 1;\n  while ( l < r ) {\n    if ( str [ l ] != str [ r ] ) {\n      palin [ l ] = palin [ r ] = max ( str [ l ], str [ r ] );\n      k --;\n    }\n    l ++;\n    r --;\n  }\n  if ( k < 0 ) return \"Not possible\";\n  l = 0;\n  r = str . length ( ) - 1;\n  while ( l <= r ) {\n    if ( l == r ) {\n      if ( k > 0 ) palin [ l ] = '9';\n    }\n    if ( palin [ l ] < '9' ) {\n      if ( k >= 2 && palin [ l ] == str [ l ] && palin [ r ] == str [ r ] ) {\n        k -= 2;\n        palin [ l ] = palin [ r ] = '9';\n      }\n      else if ( k >= 1 && ( palin [ l ] != str [ l ] || palin [ r ] != str [ r ] ) ) {\n        k --;\n        palin [ l ] = palin [ r ] = '9';\n      }\n    }\n    l ++;\n    r --;\n  }\n  return palin;\n}\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM": "void subArray ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      for ( int k = i;\n      k <= j;\n      k ++ ) cout << arr [ k ] << \" \";\n      cout << endl;\n    }\n  }\n}\n", "MAXIMUM_SUM_INCREASING_ORDER_ELEMENTS_N_ARRAYS": "int maximumSum ( int a [ ] [ M ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) sort ( a [ i ], a [ i ] + M );\n  int sum = a [ n - 1 ] [ M - 1 ];\n  int prev = a [ n - 1 ] [ M - 1 ];\n  int i, j;\n  for ( i = n - 2;\n  i >= 0;\n  i -- ) {\n    for ( j = M - 1;\n    j >= 0;\n    j -- ) {\n      if ( a [ i ] [ j ] < prev ) {\n        prev = a [ i ] [ j ];\n        sum += prev;\n        break;\n      }\n    }\n    if ( j == - 1 ) return 0;\n  }\n  return sum;\n}\n", "C_PROGRAM_FACTORIAL_NUMBER": "unsigned int factorial ( unsigned int n ) {\n  if ( n == 0 ) return 1;\n  return n * factorial ( n - 1 );\n}\n", "PRINT_SQUARES_FIRST_N_NATURAL_NUMBERS_WITHOUT_USING": "void printSquares ( int n ) {\n  int square = 0, prev_x = 0;\n  for ( int x = 0;\n  x < n;\n  x ++ ) {\n    square = ( square + x + prev_x );\n    cout << square << \" \";\n    prev_x = x;\n  }\n}\n", "ROPES_DATA_STRUCTURE_FAST_STRING_CONCATENATION": "void concatenate ( char a [ ], char b [ ], char c [ ], int n1, int n2 ) {\n  int i;\n  for ( i = 0;\n  i < n1;\n  i ++ ) c [ i ] = a [ i ];\n  for ( int j = 0;\n  j < n2;\n  j ++ ) c [ i ++ ] = b [ j ];\n  c [ i ] = '\\0';\n}\n", "GIVEN_TWO_SORTED_ARRAYS_NUMBER_X_FIND_PAIR_WHOSE_SUM_CLOSEST_X": "void printClosest ( int ar1 [ ], int ar2 [ ], int m, int n, int x ) {\n  int diff = INT_MAX;\n  int res_l, res_r;\n  int l = 0, r = n - 1;\n  while ( l < m && 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    }\n    if ( ar1 [ l ] + ar2 [ r ] > x ) r --;\n    else l ++;\n  }\n  cout << \"The closest pair is [\" << ar1 [ res_l ] << \", \" << ar2 [ res_r ] << \"] \\n\";\n}\n", "CONVERT_STRICTLY_INCREASING_ARRAY_MINIMUM_CHANGES": "int minRemove ( int arr [ ], int n ) {\n  int LIS [ n ], len = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) LIS [ i ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < i;\n    j ++ ) {\n      if ( arr [ i ] > arr [ j ] && ( i - j ) <= ( arr [ i ] - arr [ j ] ) ) {\n        LIS [ i ] = max ( LIS [ i ], LIS [ j ] + 1 );\n      }\n    }\n    len = max ( len, LIS [ i ] );\n  }\n  return n - len;\n}\n", "TAIL_RECURSION": "unsigned int fact ( unsigned int n ) {\n  if ( n == 0 ) return 1;\n  return n * fact ( n - 1 );\n}\n", "RECURSIVE_FUNCTIONS": "void tower ( int n, char sourcePole, char destinationPole, char auxiliaryPole ) {\n  if ( 0 == n ) return;\n  tower ( n - 1, sourcePole, auxiliaryPole, destinationPole );\n  cout << \"Move the disk \" << n << \" from \" << sourcePole << \" to \" << destinationPole << endl;\n  tower ( n - 1, auxiliaryPole, destinationPole, sourcePole );\n}\n", "FIND_X_Y_SATISFYING_AX_N": "void solution ( int a, int b, int n ) {\n  for ( int i = 0;\n  i * a <= n;\n  i ++ ) {\n    if ( ( n - ( i * a ) ) % b == 0 ) {\n      cout << \"x = \" << i << \", y = \" << ( n - ( i * a ) ) / b;\n      return;\n    }\n  }\n  cout << \"No solution\";\n}\n", "EXPONENTIAL_SQUARING_FAST_MODULO_MULTIPLICATION_1": "long exponentiation ( long base, long exp ) {\n  long t = 1L;\n  while ( exp > 0 ) {\n    if ( exp % 2 != 0 ) t = ( t * base ) % N;\n    base = ( base * base ) % N;\n    exp /= 2;\n  }\n  return t % N;\n}\n", "CHECK_OCCURRENCES_CHARACTER_APPEAR_TOGETHER": "bool checkIfAllTogether ( string s, char c ) {\n  bool oneSeen = false;\n  int i = 0, n = s . length ( );\n  while ( i < n ) {\n    if ( s [ i ] == c ) {\n      if ( oneSeen == true ) return false;\n      while ( i < n && s [ i ] == c ) i ++;\n      oneSeen = true;\n    }\n    else i ++;\n  }\n  return true;\n}\n", "MAXIMUM_AREA_RECTANGLE_PICKING_FOUR_SIDES_ARRAY": "int findArea ( int arr [ ], int n ) {\n  sort ( arr, arr + n, greater < int > ( ) );\n  int dimension [ 2 ] = {\n    0, 0 };\n    for ( int i = 0, j = 0;\n    i < n - 1 && j < 2;\n    i ++ ) if ( arr [ i ] == arr [ i + 1 ] ) dimension [ j ++ ] = arr [ i ++ ];\n    return ( dimension [ 0 ] * dimension [ 1 ] );\n  }\n  ", "PYTHON_PROGRAM_FIND_PERIMETER_CIRCUMFERENCE_SQUARE_RECTANGLE": "int Circumference ( int a ) {\n  return 4 * a;\n}\n", "CYCLE_SORT": "void cycleSort ( int arr [ ], int n ) {\n  int writes = 0;\n  for ( int cycle_start = 0;\n  cycle_start <= n - 2;\n  cycle_start ++ ) {\n    int item = arr [ cycle_start ];\n    int pos = cycle_start;\n    for ( int i = cycle_start + 1;\n    i < n;\n    i ++ ) if ( arr [ i ] < item ) pos ++;\n    if ( pos == cycle_start ) continue;\n    while ( item == arr [ pos ] ) pos += 1;\n    if ( pos != cycle_start ) {\n      swap ( item, arr [ pos ] );\n      writes ++;\n    }\n    while ( pos != cycle_start ) {\n      pos = cycle_start;\n      for ( int i = cycle_start + 1;\n      i < n;\n      i ++ ) if ( arr [ i ] < item ) pos += 1;\n      while ( item == arr [ pos ] ) pos += 1;\n      if ( item != arr [ pos ] ) {\n        swap ( item, arr [ pos ] );\n        writes ++;\n      }\n    }\n  }\n}\n", "SELECT_A_RANDOM_NUMBER_FROM_STREAM_WITH_O1_SPACE": "int selectRandom ( int x ) {\n  static int res;\n  static int count = 0;\n  count ++;\n  if ( count == 1 ) res = x;\n  else {\n    int i = rand ( ) % count;\n    if ( i == count - 1 ) res = x;\n  }\n  return res;\n}\n", "HOSOYAS_TRIANGLE": "void printHosoya ( int n ) {\n  int dp [ N ] [ N ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ 0 ] = dp [ 1 ] [ 0 ] = dp [ 1 ] [ 1 ] = 1;\n  for ( int i = 2;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( i > j ) dp [ i ] [ j ] = dp [ i - 1 ] [ j ] + dp [ i - 2 ] [ j ];\n      else dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] + dp [ i - 2 ] [ j - 2 ];\n    }\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= i;\n    j ++ ) cout << dp [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "DISTRIBUTING_M_ITEMS_CIRCLE_SIZE_N_STARTING_K_TH_POSITION": "int lastPosition ( int n, int m, int k ) {\n  if ( m <= n - k + 1 ) return m + k - 1;\n  m = m - ( n - k + 1 );\n  return ( m % n == 0 ) ? n : ( m % n );\n}\n", "PRINTING_LONGEST_INCREASING_CONSECUTIVE_SUBSEQUENCE": "void longestSubsequence ( int a [ ], int n ) {\n  unordered_map < int, int > mp;\n  int dp [ n ];\n  memset ( dp, 0, sizeof ( dp ) );\n  int maximum = INT_MIN;\n  int index = - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( mp . find ( a [ i ] - 1 ) != mp . end ( ) ) {\n      int lastIndex = mp [ a [ i ] - 1 ] - 1;\n      dp [ i ] = 1 + dp [ lastIndex ];\n    }\n    else dp [ i ] = 1;\n    mp [ a [ i ] ] = i + 1;\n    if ( maximum < dp [ i ] ) {\n      maximum = dp [ i ];\n      index = i;\n    }\n  }\n  for ( int curr = a [ index ] - maximum + 1;\n  curr <= a [ index ];\n  curr ++ ) cout << curr << \" \";\n}\n", "NUMBER_OF_TRIANGLES_IN_DIRECTED_AND_UNDIRECTED_GRAPHS": "int countTriangle ( int graph [ V ] [ V ], bool isDirected ) {\n  int count_Triangle = 0;\n  for ( int i = 0;\n  i < V;\n  i ++ ) {\n    for ( int j = 0;\n    j < V;\n    j ++ ) {\n      for ( int k = 0;\n      k < V;\n      k ++ ) {\n        if ( graph [ i ] [ j ] && graph [ j ] [ k ] && graph [ k ] [ i ] ) count_Triangle ++;\n      }\n    }\n  }\n  isDirected ? count_Triangle /= 3 : count_Triangle /= 6;\n  return count_Triangle;\n}\n", "CHECK_GIVEN_ARRAY_CONTAINS_DUPLICATE_ELEMENTS_WITHIN_K_DISTANCE": "bool checkDuplicatesWithinK ( int arr [ ], int n, int k ) {\n  unordered_set < int > myset;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( myset . find ( arr [ i ] ) != myset . end ( ) ) return true;\n    myset . insert ( arr [ i ] );\n    if ( i >= k ) myset . erase ( arr [ i - k ] );\n  }\n  return false;\n}\n", "MINIMUM_INSERTIONS_SORT_ARRAY": "int minInsertionStepToSortArray ( int arr [ ], int N ) {\n  int lis [ N ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) lis [ i ] = 1;\n  for ( int i = 1;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < i;\n  j ++ ) if ( arr [ i ] >= arr [ j ] && lis [ i ] < lis [ j ] + 1 ) lis [ i ] = lis [ j ] + 1;\n  int max = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) if ( max < lis [ i ] ) max = lis [ i ];\n  return ( N - max );\n}\n", "GENERATE_TWO_OUTPUT_STRINGS_DEPENDING_UPON_OCCURRENCE_CHARACTER_INPUT_STRING": "void printDuo ( string & str ) {\n  int countChar [ MAX_CHAR ] = {\n    0 };\n    int n = str . length ( );\n    for ( int i = 0;\n    i < n;\n    i ++ ) countChar [ str [ i ] - 'a' ] ++;\n    string str1 = \"\", str2 = \"\";\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) {\n      if ( countChar [ i ] > 1 ) str2 = str2 + ( char ) ( i + 'a' );\n      else if ( countChar [ i ] == 1 ) str1 = str1 + ( char ) ( i + 'a' );\n    }\n    cout << \"String with characters occurring \" << \"once:\\n\";\n    cout << str1 << \"\\n\";\n    cout << \"String with characters occurring \" << \"multiple times:\\n\";\n    cout << str2 << \"\\n\";\n  }\n  ", "NUMBER_DIGITS_PRODUCT_TWO_NUMBERS_1": "int countDigits ( int a, int b ) {\n  if ( a == 0 || b == 0 ) return 1;\n  return floor ( log10 ( abs ( a ) ) + log10 ( abs ( b ) ) ) + 1;\n}\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS_1": "long long int countNonDecreasing ( int n ) {\n  int N = 10;\n  long long count = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    count *= ( N + i - 1 );\n    count /= i;\n  }\n  return count;\n}\n", "COUNT_STRINGS_ADJACENT_CHARACTERS_DIFFERENCE_ONE": "int countStrs ( int n ) {\n  long int dp [ n + 1 ] [ 27 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i <= 25;\n  i ++ ) dp [ 1 ] [ i ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= 25;\n    j ++ ) if ( j == 0 ) dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ];\n    else dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] );\n  }\n  long int sum = 0;\n  for ( int i = 0;\n  i <= 25;\n  i ++ ) sum = ( sum + dp [ n ] [ i ] );\n  return sum;\n}\n", "PROGRAM_TO_EFFICIENTLY_CALCULATE_EX": "float exponential ( int n, float x ) {\n  float sum = 1.0f;\n  for ( int i = n - 1;\n  i > 0;\n  -- i ) sum = 1 + x * sum / i;\n  return sum;\n}\n", "EFFICIENTLY_COMPUTE_SUMS_OF_DIAGONALS_OF_A_MATRIX_1": "void printDiagonalSums ( int mat [ ] [ MAX ], int n ) {\n  int principal = 0, secondary = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    principal += mat [ i ] [ i ];\n    secondary += mat [ i ] [ n - i - 1 ];\n  }\n  cout << \"Principal Diagonal:\" << principal << endl;\n  cout << \"Secondary Diagonal:\" << secondary << endl;\n}\n", "PRINT_WAYS_BREAK_STRING_BRACKET_FORM": "void findCombinations ( string str, int index, string out ) {\n  if ( index == str . length ( ) ) cout << out << endl;\n  for ( int i = index;\n  i < str . length ( );\n  i ++ ) findCombinations ( str, i + 1, out + \"(\" + str . substr ( index, i + 1 - index ) + \")\" );\n}\n", "LINEAR_SEARCH": "int search ( int arr [ ], int n, int x ) {\n  int i;\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] == x ) return i;\n  return - 1;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_2": "int singleNumber ( int a [ ], int n ) {\n  unordered_set < int > s ( a, a + n );\n  int arr_sum = accumulate ( a, a + n, 0 );\n  int set_sum = accumulate ( s . begin ( ), s . end ( ), 0 );\n  return ( 3 * set_sum - arr_sum ) / 2;\n}\n", "SEARCH_ALMOST_SORTED_ARRAY": "int binarySearch ( int arr [ ], int l, int r, int x ) {\n  if ( r >= l ) {\n    int mid = l + ( r - l ) / 2;\n    if ( arr [ mid ] == x ) return mid;\n    if ( mid > l && arr [ mid - 1 ] == x ) return ( mid - 1 );\n    if ( mid < r && arr [ mid + 1 ] == x ) return ( mid + 1 );\n    if ( arr [ mid ] > x ) return binarySearch ( arr, l, mid - 2, x );\n    return binarySearch ( arr, mid + 2, r, x );\n  }\n  return - 1;\n}\n", "EULERS_TOTIENT_FUNCTION_FOR_ALL_NUMBERS_SMALLER_THAN_OR_EQUAL_TO_N": "void computeTotient ( int n ) {\n  long long phi [ n + 1 ];\n  for ( int i = 1;\n  i <= n;\n  i ++ ) phi [ i ] = i;\n  for ( int p = 2;\n  p <= n;\n  p ++ ) {\n    if ( phi [ p ] == p ) {\n      phi [ p ] = p - 1;\n      for ( int i = 2 * p;\n      i <= n;\n      i += p ) {\n        phi [ i ] = ( phi [ i ] / p ) * ( p - 1 );\n      }\n    }\n  }\n  for ( int i = 1;\n  i <= n;\n  i ++ ) cout << \"Totient of \" << i << \" is \" << phi [ i ] << endl;\n}\n", "FIND_MINIMUM_NUMBER_DIVIDED_MAKE_NUMBER_PERFECT_SQUARE": "int findMinNumber ( int n ) {\n  int count = 0, ans = 1;\n  while ( n % 2 == 0 ) {\n    count ++;\n    n /= 2;\n  }\n  if ( count % 2 ) ans *= 2;\n  for ( int i = 3;\n  i <= sqrt ( n );\n  i += 2 ) {\n    count = 0;\n    while ( n % i == 0 ) {\n      count ++;\n      n /= i;\n    }\n    if ( count % 2 ) ans *= i;\n  }\n  if ( n > 2 ) ans *= n;\n  return ans;\n}\n", "COUNT_NUMBER_WAYS_JUMP_REACH_END": "void countWaysToJump ( int arr [ ], int n ) {\n  int count_jump [ n ];\n  memset ( count_jump, 0, sizeof ( count_jump ) );\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( arr [ i ] >= n - i - 1 ) count_jump [ i ] ++;\n    for ( int j = i + 1;\n    j < n - 1 && j <= arr [ i ] + i;\n    j ++ ) if ( count_jump [ j ] != - 1 ) count_jump [ i ] += count_jump [ j ];\n    if ( count_jump [ i ] == 0 ) count_jump [ i ] = - 1;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << count_jump [ i ] << \" \";\n}\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL_1": "int substringConversions ( string str, int k, int b ) {\n  int i = 0, sum = 0, counter = k - 1;\n  for ( i;\n  i < k;\n  i ++ ) {\n    sum = sum + ( ( str . at ( i ) - '0' ) * pow ( b, counter ) );\n    counter --;\n  }\n  cout << sum << \" \";\n  int prev = sum;\n  sum = 0, counter = 0;\n  for ( i;\n  i < str . size ( );\n  i ++ ) {\n    sum = prev - ( ( str . at ( i - k ) - '0' ) * pow ( b, k - 1 ) );\n    sum = sum * b;\n    sum = sum + ( str . at ( i ) - '0' );\n    cout << sum << \" \";\n    prev = sum;\n    counter ++;\n  }\n}\n", "TWO_ELEMENTS_WHOSE_SUM_IS_CLOSEST_TO_ZERO": "void minAbsSumPair ( int arr [ ], int arr_size ) {\n  int inv_count = 0;\n  int l, r, min_sum, sum, min_l, min_r;\n  if ( arr_size < 2 ) {\n    cout << \"Invalid Input\";\n    return;\n  }\n  min_l = 0;\n  min_r = 1;\n  min_sum = arr [ 0 ] + arr [ 1 ];\n  for ( l = 0;\n  l < arr_size - 1;\n  l ++ ) {\n    for ( r = l + 1;\n    r < arr_size;\n    r ++ ) {\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      }\n    }\n  }\n  cout << \"The two elements whose sum is minimum are \" << arr [ min_l ] << \" and \" << arr [ min_r ];\n}\n", "HOW_TO_PRINT_MAXIMUM_NUMBER_OF_A_USING_GIVEN_FOUR_KEYS": "int findoptimal ( int N ) {\n  if ( N <= 6 ) return N;\n  int screen [ N ];\n  int b;\n  int n;\n  for ( n = 1;\n  n <= 6;\n  n ++ ) screen [ n - 1 ] = n;\n  for ( n = 7;\n  n <= N;\n  n ++ ) {\n    screen [ n - 1 ] = max ( 2 * screen [ n - 4 ], max ( 3 * screen [ n - 5 ], 4 * screen [ n - 6 ] ) );\n  }\n  return screen [ N - 1 ];\n}\n", "PROGRAM_DECIMAL_BINARY_CONVERSION_2": "unsigned long long int int decimalToBinary ( int N ) {\n  ull B_Number = 0;\n  int cnt = 0;\n  while ( N != 0 ) {\n    int rem = N % 2;\n    ull c = pow ( 10, cnt );\n    B_Number += rem * c;\n    N /= 2;\n    cnt ++;\n  }\n  return B_Number;\n}\n", "COUNTS_PATHS_POINT_REACH_ORIGIN_1": "int countPaths ( int n, int m ) {\n  int dp [ n + 1 ] [ m + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) dp [ i ] [ 0 ] = 1;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) dp [ 0 ] [ i ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= m;\n  j ++ ) dp [ i ] [ j ] = dp [ i - 1 ] [ j ] + dp [ i ] [ j - 1 ];\n  return dp [ n ] [ m ];\n}\n", "SUM_ELEMENTS_K1TH_K2TH_SMALLEST_ELEMENTS": "int sumBetweenTwoKth ( int arr [ ], int n, int k1, int k2 ) {\n  sort ( arr, arr + n );\n  return accumulate ( arr + k1, arr + k2 - 1, 0 );\n}\n", "SMALLEST_SUBARRAY_K_DISTINCT_NUMBERS": "void minRange ( int arr [ ], int n, int k ) {\n  int l = 0, r = n;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    unordered_set < int > s;\n    int j;\n    for ( j = i;\n    j < n;\n    j ++ ) {\n      s . insert ( arr [ j ] );\n      if ( s . size ( ) == k ) {\n        if ( ( j - i ) < ( r - l ) ) {\n          r = j;\n          l = i;\n        }\n        break;\n      }\n    }\n    if ( j == n ) break;\n  }\n  if ( l == 0 && r == n ) cout << \"Invalid k\";\n  else cout << l << \" \" << r;\n}\n", "AREA_OF_A_HEXAGON": "double hexagonArea ( double s ) {\n  return ( ( 3 * sqrt ( 3 ) * ( s * s ) ) / 2 );\n}\n", "NEXT_POWER_OF_2_2": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  n --;\n  n |= n >> 1;\n  n |= n >> 2;\n  n |= n >> 4;\n  n |= n >> 8;\n  n |= n >> 16;\n  n ++;\n  return n;\n}\n", "COUNT_SUBSTRINGS_BINARY_STRING_CONTAINING_K_ONES": "int countOfSubstringWithKOnes ( string s, int K ) {\n  int N = s . length ( );\n  int res = 0;\n  int countOfOne = 0;\n  int freq [ N + 1 ] = {\n    0 };\n    freq [ 0 ] = 1;\n    for ( int i = 0;\n    i < N;\n    i ++ ) {\n      countOfOne += ( s [ i ] - '0' );\n      if ( countOfOne >= K ) {\n        res += freq [ countOfOne - K ];\n      }\n      freq [ countOfOne ] ++;\n    }\n    return res;\n  }\n  ", "NUMBER_INDEXES_EQUAL_ELEMENTS_GIVEN_RANGE": "int answer_query ( int a [ ], int n, int l, int r ) {\n  int count = 0;\n  for ( int i = l;\n  i < r;\n  i ++ ) if ( a [ i ] == a [ i + 1 ] ) count += 1;\n  return count;\n}\n", "CHECK_WHETHER_NUMBER_DUCK_NUMBER_NOT": "int check_duck ( char * num ) {\n  int len = strlen ( num );\n  int count_zero = 0;\n  char ch;\n  for ( int i = 1;\n  i < len;\n  i ++ ) {\n    ch = num [ i ];\n    if ( ch == '0' ) count_zero ++;\n  }\n  return count_zero;\n}\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N_1": "int countIntegralSolutions ( int n ) {\n  return ( ( n + 1 ) * ( n + 2 ) ) / 2;\n}\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_K_TIMES_1": "int maxProfit ( int price [ ], int n, int k ) {\n  int profit [ k + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= k;\n  i ++ ) profit [ i ] [ 0 ] = 0;\n  for ( int j = 0;\n  j <= n;\n  j ++ ) profit [ 0 ] [ j ] = 0;\n  for ( int i = 1;\n  i <= k;\n  i ++ ) {\n    int prevDiff = INT_MIN;\n    for ( int j = 1;\n    j < n;\n    j ++ ) {\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    }\n  }\n  return profit [ k ] [ n - 1 ];\n}\n", "COUNT_CHARACTERS_POSITION_ENGLISH_ALPHABETS": "int findCount ( string str ) {\n  int result = 0;\n  for ( int i = 0;\n  i < str . size ( );\n  i ++ ) if ( i == ( str [ i ] - 'a' ) || i == ( str [ i ] - 'A' ) ) result ++;\n  return result;\n}\n", "COUNT_GFG_SUBSEQUENCES_GIVEN_STRING": "void countSubsequence ( char s [ ], int n ) {\n  int cntG = 0, cntF = 0, result = 0, C = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    switch ( s [ i ] ) {\n      case 'G' : cntG ++;\n      result += C;\n      break;\n      case 'F' : cntF ++;\n      C += cntG;\n      break;\n      default : continue;\n    }\n  }\n  cout << result << endl;\n}\n", "FIND_SMALLEST_VALUE_REPRESENTED_SUM_SUBSET_GIVEN_ARRAY": "int findSmallest ( int arr [ ], int n ) {\n  int res = 1;\n  for ( int i = 0;\n  i < n && arr [ i ] <= res;\n  i ++ ) res = res + arr [ i ];\n  return res;\n}\n", "MAXIMUM_POINTS_COLLECTED_BY_TWO_PERSONS_ALLOWED_TO_MEET_ONCE": "int findMaxPoints ( int A [ ] [ M ] ) {\n  int P1S [ M + 1 ] [ N + 1 ], P1E [ M + 1 ] [ N + 1 ];\n  memset ( P1S, 0, sizeof ( P1S ) );\n  memset ( P1E, 0, sizeof ( P1E ) );\n  int P2S [ M + 1 ] [ N + 1 ], P2E [ M + 1 ] [ N + 1 ];\n  memset ( P2S, 0, sizeof ( P2S ) );\n  memset ( P2E, 0, sizeof ( P2E ) );\n  for ( int i = 1;\n  i <= N;\n  i ++ ) for ( int j = 1;\n  j <= M;\n  j ++ ) P1S [ i ] [ j ] = max ( P1S [ i - 1 ] [ j ], P1S [ i ] [ j - 1 ] ) + A [ i - 1 ] [ j - 1 ];\n  for ( int i = N;\n  i >= 1;\n  i -- ) for ( int j = M;\n  j >= 1;\n  j -- ) P1E [ i ] [ j ] = max ( P1E [ i + 1 ] [ j ], P1E [ i ] [ j + 1 ] ) + A [ i - 1 ] [ j - 1 ];\n  for ( int i = N;\n  i >= 1;\n  i -- ) for ( int j = 1;\n  j <= M;\n  j ++ ) P2S [ i ] [ j ] = max ( P2S [ i + 1 ] [ j ], P2S [ i ] [ j - 1 ] ) + A [ i - 1 ] [ j - 1 ];\n  for ( int i = 1;\n  i <= N;\n  i ++ ) for ( int j = M;\n  j >= 1;\n  j -- ) P2E [ i ] [ j ] = max ( P2E [ i - 1 ] [ j ], P2E [ i ] [ j + 1 ] ) + A [ i - 1 ] [ j - 1 ];\n  int ans = 0;\n  for ( int i = 2;\n  i < N;\n  i ++ ) {\n    for ( int j = 2;\n    j < M;\n    j ++ ) {\n      int op1 = P1S [ i ] [ j - 1 ] + P1E [ i ] [ j + 1 ] + P2S [ i + 1 ] [ j ] + P2E [ i - 1 ] [ j ];\n      int op2 = P1S [ i - 1 ] [ j ] + P1E [ i + 1 ] [ j ] + P2S [ i ] [ j - 1 ] + P2E [ i ] [ j + 1 ];\n      ans = max ( ans, max ( op1, op2 ) );\n    }\n  }\n  return ans;\n}\n", "PROGRAM_FIND_CIRCUMFERENCE_CIRCLE": "double circumference ( double r ) {\n  double cir = 2 * PI * r;\n  return cir;\n}\n", "QUICKLY_FIND_MULTIPLE_LEFT_ROTATIONS_OF_AN_ARRAY": "void leftRotate ( int arr [ ], int n, int k ) {\n  for ( int i = k;\n  i < k + n;\n  i ++ ) cout << arr [ i % n ] << \" \";\n}\n", "MINIMUM_SUM_CHOOSING_MINIMUM_PAIRS_ARRAY": "int minSum ( int A [ ], int n ) {\n  int min_val = * min_element ( A, A + n );\n  return ( min_val * ( n - 1 ) );\n}\n", "RECURSIVE_PROGRAM_PRIME_NUMBER": "bool isPrime ( int n, int i = 2 ) {\n  if ( n <= 2 ) return ( n == 2 ) ? true : false;\n  if ( n % i == 0 ) return false;\n  if ( i * i > n ) return true;\n  return isPrime ( n, i + 1 );\n}\n", "SPARSE_SEARCH": "int sparseSearch ( string arr [ ], string x, int n ) {\n  return binarySearch ( arr, 0, n - 1, x );\n}\n", "FIND_NUMBER_TIMES_STRING_OCCURS_GIVEN_STRING": "int count ( string a, string b, int m, int n ) {\n  if ( ( m == 0 && n == 0 ) || n == 0 ) return 1;\n  if ( m == 0 ) return 0;\n  if ( a [ m - 1 ] == b [ n - 1 ] ) return count ( a, b, m - 1, n - 1 ) + count ( a, b, m - 1, n );\n  else return count ( a, b, m - 1, n );\n}\n", "PROGRAM_CHECK_ARRAY_SORTED_NOT_ITERATIVE_RECURSIVE_1": "bool arraySortedOrNot ( int arr [ ], int n ) {\n  if ( n == 0 || n == 1 ) return true;\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( arr [ i - 1 ] > arr [ i ] ) return false;\n  return true;\n}\n", "FIND_INDEX_0_REPLACED_1_GET_LONGEST_CONTINUOUS_SEQUENCE_1S_BINARY_ARRAY": "int maxOnesIndex ( bool arr [ ], int n ) {\n  int max_count = 0;\n  int max_index;\n  int prev_zero = - 1;\n  int prev_prev_zero = - 1;\n  for ( int curr = 0;\n  curr < n;\n  ++ curr ) {\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      }\n      prev_prev_zero = prev_zero;\n      prev_zero = curr;\n    }\n  }\n  if ( n - prev_prev_zero > max_count ) max_index = prev_zero;\n  return max_index;\n}\n", "FIND_MAXIMUM_PRODUCT_OF_A_TRIPLET_IN_ARRAY_1": "int maxProduct ( int arr [ ], int n ) {\n  if ( n < 3 ) return - 1;\n  sort ( arr, arr + n );\n  return max ( arr [ 0 ] * arr [ 1 ] * arr [ n - 1 ], arr [ n - 1 ] * arr [ n - 2 ] * arr [ n - 3 ] );\n}\n", "COORDINATES_RECTANGLE_GIVEN_POINTS_LIE_INSIDE": "void printRect ( int X [ ], int Y [ ], int n ) {\n  int Xmax = * max_element ( X, X + n );\n  int Xmin = * min_element ( X, X + n );\n  int Ymax = * max_element ( Y, Y + n );\n  int Ymin = * min_element ( Y, Y + n );\n  cout << \"{\" << Xmin << \", \" << Ymin << \"}\" << endl;\n  cout << \"{\" << Xmin << \", \" << Ymax << \"}\" << endl;\n  cout << \"{\" << Xmax << \", \" << Ymax << \"}\" << endl;\n  cout << \"{\" << Xmax << \", \" << Ymin << \"}\" << endl;\n}\n", "COUNT_BINARY_DIGIT_NUMBERS_SMALLER_N": "int countOfBinaryNumberLessThanN ( int N ) {\n  queue < int > q;\n  q . push ( 1 );\n  int cnt = 0;\n  int t;\n  while ( ! q . empty ( ) ) {\n    t = q . front ( );\n    q . pop ( );\n    if ( t <= N ) {\n      cnt ++;\n      q . push ( t * 10 );\n      q . push ( t * 10 + 1 );\n    }\n  }\n  return cnt;\n}\n", "CONVERT_DECIMAL_FRACTION_BINARY_NUMBER": "string decimalToBinary ( double num, int k_prec ) {\n  string binary = \"\";\n  int Integral = num;\n  double fractional = num - Integral;\n  while ( Integral ) {\n    int rem = Integral % 2;\n    binary . push_back ( rem + '0' );\n    Integral /= 2;\n  }\n  reverse ( binary . begin ( ), binary . end ( ) );\n  binary . push_back ( '.' );\n  while ( k_prec -- ) {\n    fractional *= 2;\n    int fract_bit = fractional;\n    if ( fract_bit == 1 ) {\n      fractional -= fract_bit;\n      binary . push_back ( 1 + '0' );\n    }\n    else binary . push_back ( 0 + '0' );\n  }\n  return binary;\n}\n", "MAXIMUM_NUMBER_OF_TRAILING_ZEROS_IN_THE_PRODUCT_OF_THE_SUBSETS_OF_SIZE_K": "int maximumZeros ( int * arr, int n, int k ) {\n  int subset [ k + 1 ] [ MAX5 + 5 ];\n  memset ( subset, - 1, sizeof ( subset ) );\n  subset [ 0 ] [ 0 ] = 0;\n  for ( int p = 0;\n  p < n;\n  p ++ ) {\n    int pw2 = 0, pw5 = 0;\n    while ( arr [ p ] % 2 == 0 ) {\n      pw2 ++;\n      arr [ p ] /= 2;\n    }\n    while ( arr [ p ] % 5 == 0 ) {\n      pw5 ++;\n      arr [ p ] /= 5;\n    }\n    for ( int i = k - 1;\n    i >= 0;\n    i -- ) for ( int j = 0;\n    j < MAX5;\n    j ++ ) if ( subset [ i ] [ j ] != - 1 ) subset [ i + 1 ] [ j + pw5 ] = max ( subset [ i + 1 ] [ j + pw5 ], subset [ i ] [ j ] + pw2 );\n  }\n  int ans = 0;\n  for ( int i = 0;\n  i < MAX5;\n  i ++ ) ans = max ( ans, min ( i, subset [ k ] [ i ] ) );\n  return ans;\n}\n", "SEARCH_AN_ELEMENT_IN_A_SORTED_AND_PIVOTED_ARRAY": "int search ( int arr [ ], int l, int h, int key ) {\n  if ( l > h ) return - 1;\n  int mid = ( l + h ) / 2;\n  if ( arr [ mid ] == key ) return mid;\n  if ( arr [ l ] <= arr [ mid ] ) {\n    if ( key >= arr [ l ] && key <= arr [ mid ] ) return search ( arr, l, mid - 1, key );\n    return search ( arr, mid + 1, h, key );\n  }\n  if ( key >= arr [ mid ] && key <= arr [ h ] ) return search ( arr, mid + 1, h, key );\n  return search ( arr, l, mid - 1, key );\n}\n", "PROGRAM_FIND_AREA_CIRCULAR_SEGMENT": "float area_of_segment ( float radius, float angle ) {\n  float area_of_sector = pi * ( radius * radius ) * ( angle / 360 );\n  float area_of_triangle = ( float ) 1 / 2 * ( radius * radius ) * sin ( ( angle * pi ) / 180 );\n  return area_of_sector - area_of_triangle;\n}\n", "K_SMALLEST_ELEMENTS_ORDER_USING_O1_EXTRA_SPACE": "void printSmall ( int arr [ ], int n, int k ) {\n  for ( int i = k;\n  i < n;\n  ++ i ) {\n    int max_var = arr [ k - 1 ];\n    int pos = k - 1;\n    for ( int j = k - 2;\n    j >= 0;\n    j -- ) {\n      if ( arr [ j ] > max_var ) {\n        max_var = arr [ j ];\n        pos = j;\n      }\n    }\n    if ( max_var > arr [ i ] ) {\n      int j = pos;\n      while ( j < k - 1 ) {\n        arr [ j ] = arr [ j + 1 ];\n        j ++;\n      }\n      arr [ k - 1 ] = arr [ i ];\n    }\n  }\n  for ( int i = 0;\n  i < k;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "NTH_NON_FIBONACCI_NUMBER": "int nonFibonacci ( int n ) {\n  int prevPrev = 1, prev = 2, 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 = n + ( curr - prev - 1 );\n  return prev + n;\n}\n", "ANALYSIS_OF_ALGORITHMS_SET_2_ASYMPTOTIC_ANALYSIS": "int search ( int arr [ ], int n, int x ) {\n  int i;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == x ) return i;\n  }\n  return - 1;\n}\n", "ZECKENDORFS_THEOREM_NON_NEIGHBOURING_FIBONACCI_REPRESENTATION": "int nearestSmallerEqFib ( int n ) {\n  if ( n == 0 || n == 1 ) return n;\n  int f1 = 0, f2 = 1, f3 = 1;\n  while ( f3 <= n ) {\n    f1 = f2;\n    f2 = f3;\n    f3 = f1 + f2;\n  }\n  return f2;\n}\n", "PRINT_MAXIMUM_SHORTEST_DISTANCE": "int find_maximum ( int a [ ], int n, int k ) {\n  unordered_map < int, int > b;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int x = a [ i ];\n    int d = min ( 1 + i, n - i );\n    if ( b . find ( x ) == b . end ( ) ) b [ x ] = d;\n    else b [ x ] = min ( d, b [ x ] );\n  }\n  int ans = INT_MAX;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int x = a [ i ];\n    if ( x != k - x && b . find ( k - x ) != b . end ( ) ) ans = min ( max ( b [ x ], b [ k - x ] ), ans );\n  }\n  return ans;\n}\n", "GENERATING_DISTINCT_SUBSEQUENCES_OF_A_GIVEN_STRING_IN_LEXICOGRAPHIC_ORDER": "void generate ( set < string > & st, string s ) {\n  if ( s . size ( ) == 0 ) return;\n  if ( st . find ( s ) == st . end ( ) ) {\n    st . insert ( s );\n    for ( int i = 0;\n    i < s . size ( );\n    i ++ ) {\n      string t = s;\n      t . erase ( i, 1 );\n      generate ( st, t );\n    }\n  }\n  return;\n}\n", "WRITE_YOU_OWN_POWER_WITHOUT_USING_MULTIPLICATION_AND_DIVISION": "int pow ( int a, int b ) {\n  if ( b == 0 ) return 1;\n  int answer = a;\n  int increment = a;\n  int i, j;\n  for ( i = 1;\n  i < b;\n  i ++ ) {\n    for ( j = 1;\n    j < a;\n    j ++ ) {\n      answer += increment;\n    }\n    increment = answer;\n  }\n  return answer;\n}\n", "MAXIMIZE_VOLUME_CUBOID_GIVEN_SUM_SIDES_1": "int maxvolume ( int s ) {\n  int length = s / 3;\n  s -= length;\n  int breadth = s / 2;\n  int height = s - breadth;\n  return length * breadth * height;\n}\n", "HORNERS_METHOD_POLYNOMIAL_EVALUATION": "int horner ( int poly [ ], int n, int x ) {\n  int result = poly [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) result = result * x + poly [ i ];\n  return result;\n}\n", "MINIMUM_TIME_REQUIRED_PRODUCE_M_ITEMS": "int minTime ( int arr [ ], int n, int m ) {\n  int t = 0;\n  while ( 1 ) {\n    int items = 0;\n    for ( int i = 0;\n    i < n;\n    i ++ ) items += ( t / arr [ i ] );\n    if ( items >= m ) return t;\n    t ++;\n  }\n}\n", "FIND_DIFFERENCE_BETWEEN_SUMS_OF_TWO_DIAGONALS": "int difference ( int arr [ ] [ MAX ], int n ) {\n  int d1 = 0, d2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( i == j ) d1 += arr [ i ] [ j ];\n      if ( i == n - j - 1 ) d2 += arr [ i ] [ j ];\n    }\n  }\n  return abs ( d1 - d2 );\n}\n", "SHORTEST_UNCOMMON_SUBSEQUENCE": "int shortestSeq ( char * S, char * T ) {\n  int m = strlen ( S ), n = strlen ( T );\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) dp [ i ] [ 0 ] = 1;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) dp [ 0 ] [ i ] = MAX;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      char ch = S [ i - 1 ];\n      int k;\n      for ( k = j - 1;\n      k >= 0;\n      k -- ) if ( T [ k ] == ch ) break;\n      if ( k == - 1 ) dp [ i ] [ j ] = 1;\n      else dp [ i ] [ j ] = min ( dp [ i - 1 ] [ j ], dp [ i - 1 ] [ k ] + 1 );\n    }\n  }\n  int ans = dp [ m ] [ n ];\n  if ( ans >= MAX ) ans = - 1;\n  return ans;\n}\n", "MIN_FLIPS_OF_CONTINUOUS_CHARACTERS_TO_MAKE_ALL_CHARACTERS_SAME_IN_A_STRING": "int findFlips ( char str [ ], int n ) {\n  char last = ' ';\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( last != str [ i ] ) res ++;\n    last = str [ i ];\n  }\n  return res / 2;\n}\n", "DYNAMIC_PROGRAMMING_SET_28_MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME": "int findMinInsertions ( char str [ ], int l, int h ) {\n  if ( l > h ) return INT_MAX;\n  if ( l == h ) return 0;\n  if ( l == h - 1 ) return ( str [ l ] == str [ h ] ) ? 0 : 1;\n  return ( str [ l ] == str [ h ] ) ? findMinInsertions ( str, l + 1, h - 1 ) : ( min ( findMinInsertions ( str, l, h - 1 ), findMinInsertions ( str, l + 1, h ) ) + 1 );\n}\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS": "int countPairs ( string str ) {\n  int result = 0;\n  int n = str . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( abs ( str [ i ] - str [ j ] ) == abs ( i - j ) ) result ++;\n  return result;\n}\n", "MULTISTAGE_GRAPH_SHORTEST_PATH": "INT_MAX int shortestDist ( int graph [ N ] [ N ] ) {\n  int dist [ N ];\n  dist [ N - 1 ] = 0;\n  for ( int i = N - 2;\n  i >= 0;\n  i -- ) {\n    dist [ i ] = INF;\n    for ( int j = i;\n    j < N;\n    j ++ ) {\n      if ( graph [ i ] [ j ] == INF ) continue;\n      dist [ i ] = min ( dist [ i ], graph [ i ] [ j ] + dist [ j ] );\n    }\n  }\n  return dist [ 0 ];\n}\n", "MAXIMUM_SIZE_SUB_MATRIX_WITH_ALL_1S_IN_A_BINARY_MATRIX": "void printMaxSubSquare ( bool M [ R ] [ C ] ) {\n  int i, j;\n  int S [ R ] [ C ];\n  int max_of_s, max_i, max_j;\n  for ( i = 0;\n  i < R;\n  i ++ ) S [ i ] [ 0 ] = M [ i ] [ 0 ];\n  for ( j = 0;\n  j < C;\n  j ++ ) S [ 0 ] [ j ] = M [ 0 ] [ j ];\n  for ( i = 1;\n  i < R;\n  i ++ ) {\n    for ( j = 1;\n    j < C;\n    j ++ ) {\n      if ( M [ i ] [ j ] == 1 ) S [ i ] [ j ] = min ( S [ i ] [ j - 1 ], min ( S [ i - 1 ] [ j ], S [ i - 1 ] [ j - 1 ] ) ) + 1;\n      else S [ i ] [ j ] = 0;\n    }\n  }\n  max_of_s = S [ 0 ] [ 0 ];\n  max_i = 0;\n  max_j = 0;\n  for ( i = 0;\n  i < R;\n  i ++ ) {\n    for ( j = 0;\n    j < C;\n    j ++ ) {\n      if ( max_of_s < S [ i ] [ j ] ) {\n        max_of_s = S [ i ] [ j ];\n        max_i = i;\n        max_j = j;\n      }\n    }\n  }\n  cout << \"Maximum size sub-matrix is: \\n\";\n  for ( i = max_i;\n  i > max_i - max_of_s;\n  i -- ) {\n    for ( j = max_j;\n    j > max_j - max_of_s;\n    j -- ) {\n      cout << M [ i ] [ j ] << \" \";\n    }\n    cout << \"\\n\";\n  }\n}\n", "GIVEN_SORTED_ARRAY_NUMBER_X_FIND_PAIR_ARRAY_WHOSE_SUM_CLOSEST_X": "void printClosest ( int arr [ ], int n, int x ) {\n  int res_l, res_r;\n  int l = 0, r = n - 1, diff = INT_MAX;\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    }\n    if ( arr [ l ] + arr [ r ] > x ) r --;\n    else l ++;\n  }\n  cout << \" The closest pair is \" << arr [ res_l ] << \" and \" << arr [ res_r ];\n}\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS_1": "bool sortedAfterSwap ( int A [ ], bool B [ ], int n ) {\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( B [ i ] ) {\n      if ( A [ i ] != i + 1 ) swap ( A [ i ], A [ i + 1 ] );\n    }\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( A [ i ] != i + 1 ) return false;\n  }\n  return true;\n}\n", "TILE_STACKING_PROBLEM": "int possibleWays ( int n, int m, int k ) {\n  int dp [ N ] [ N ];\n  int presum [ N ] [ N ];\n  memset ( dp, 0, sizeof dp );\n  memset ( presum, 0, sizeof presum );\n  for ( int i = 1;\n  i < n + 1;\n  i ++ ) {\n    dp [ 0 ] [ i ] = 0;\n    presum [ 0 ] [ i ] = 1;\n  }\n  for ( int i = 0;\n  i < m + 1;\n  i ++ ) presum [ i ] [ 0 ] = dp [ i ] [ 0 ] = 1;\n  for ( int i = 1;\n  i < m + 1;\n  i ++ ) {\n    for ( int j = 1;\n    j < n + 1;\n    j ++ ) {\n      dp [ i ] [ j ] = presum [ i - 1 ] [ j ];\n      if ( j > k ) {\n        dp [ i ] [ j ] -= presum [ i - 1 ] [ j - k - 1 ];\n      }\n    }\n    for ( int j = 1;\n    j < n + 1;\n    j ++ ) presum [ i ] [ j ] = dp [ i ] [ j ] + presum [ i ] [ j - 1 ];\n  }\n  return dp [ m ] [ n ];\n}\n", "NUMBER_OF_PAIRS_IN_AN_ARRAY_HAVING_SUM_EQUAL_TO_PRODUCT": "int sumEqualProduct ( int a [ ], int n ) {\n  int zero = 0, two = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] == 0 ) {\n      zero ++;\n    }\n    if ( a [ i ] == 2 ) {\n      two ++;\n    }\n  }\n  int cnt = ( zero * ( zero - 1 ) ) / 2 + ( two * ( two - 1 ) ) / 2;\n  return cnt;\n}\n", "DYNAMIC_PROGRAMMING_SET_17_PALINDROME_PARTITIONING": "int minPalPartion ( char * str ) {\n  int n = strlen ( str );\n  int C [ n ] [ n ];\n  bool P [ n ] [ n ];\n  int i, j, k, L;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    P [ i ] [ i ] = true;\n    C [ i ] [ i ] = 0;\n  }\n  for ( L = 2;\n  L <= n;\n  L ++ ) {\n    for ( i = 0;\n    i < n - L + 1;\n    i ++ ) {\n      j = i + L - 1;\n      if ( L == 2 ) P [ i ] [ j ] = ( str [ i ] == str [ j ] );\n      else P [ i ] [ j ] = ( str [ i ] == str [ j ] ) && P [ i + 1 ] [ j - 1 ];\n      if ( P [ i ] [ j ] == true ) C [ i ] [ j ] = 0;\n      else {\n        C [ i ] [ j ] = INT_MAX;\n        for ( k = i;\n        k <= j - 1;\n        k ++ ) C [ i ] [ j ] = min ( C [ i ] [ j ], C [ i ] [ k ] + C [ k + 1 ] [ j ] + 1 );\n      }\n    }\n  }\n  return C [ 0 ] [ n - 1 ];\n}\n", "FIND_ONE_MULTIPLE_REPEATING_ELEMENTS_READ_ARRAY": "int findRepeatingNumber ( const int arr [ ], int n ) {\n  int sq = sqrt ( n );\n  int range = ( n / sq ) + 1;\n  int count [ range ] = {\n    0 };\n    for ( int i = 0;\n    i <= n;\n    i ++ ) {\n      count [ ( arr [ i ] - 1 ) / sq ] ++;\n    }\n    int selected_block = range - 1;\n    for ( int i = 0;\n    i < range - 1;\n    i ++ ) {\n      if ( count [ i ] > sq ) {\n        selected_block = i;\n        break;\n      }\n    }\n    unordered_map < int, int > m;\n    for ( int i = 0;\n    i <= n;\n    i ++ ) {\n      if ( ( ( selected_block * sq ) < arr [ i ] ) && ( arr [ i ] <= ( ( selected_block + 1 ) * sq ) ) ) {\n        m [ arr [ i ] ] ++;\n        if ( m [ arr [ i ] ] > 1 ) return arr [ i ];\n      }\n    }\n    return - 1;\n  }\n  ", "MINIMUM_SUM_PATH_TRIANGLE": "int minSumPath ( vector < vector < int > > & A ) {\n  int memo [ A . size ( ) ];\n  int n = A . size ( ) - 1;\n  for ( int i = 0;\n  i < A [ n ] . size ( );\n  i ++ ) memo [ i ] = A [ n ] [ i ];\n  for ( int i = A . size ( ) - 2;\n  i >= 0;\n  i -- ) for ( int j = 0;\n  j < A [ i ] . size ( );\n  j ++ ) memo [ j ] = A [ i ] [ j ] + min ( memo [ j ], memo [ j + 1 ] );\n  return memo [ 0 ];\n}\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT_1": "public : int getSum ( int n ) {\n  int sum;\n  for ( sum = 0;\n  n > 0;\n  sum += n % 10, n /= 10 );\n  return sum;\n}\n", "RECURSION": "void printFun ( int test ) {\n  if ( test < 1 ) return;\n  else {\n    cout << test << \" \";\n    printFun ( test - 1 );\n    cout << test << \" \";\n    return;\n  }\n}\n", "MAXIMUM_TRIPLET_SUM_ARRAY": "int maxTripletSum ( int arr [ ], int n ) {\n  int sum = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) for ( int k = j + 1;\n  k < n;\n  k ++ ) if ( sum < arr [ i ] + arr [ j ] + arr [ k ] ) sum = arr [ i ] + arr [ j ] + arr [ k ];\n  return sum;\n}\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY_1": "int minJumps ( int arr [ ], int n ) {\n  int * jumps = new int [ n ];\n  int i, j;\n  if ( n == 0 || arr [ 0 ] == 0 ) return INT_MAX;\n  jumps [ 0 ] = 0;\n  for ( i = 1;\n  i < n;\n  i ++ ) {\n    jumps [ i ] = INT_MAX;\n    for ( j = 0;\n    j < i;\n    j ++ ) {\n      if ( i <= j + arr [ j ] && jumps [ j ] != INT_MAX ) {\n        jumps [ i ] = min ( jumps [ i ], jumps [ j ] + 1 );\n        break;\n      }\n    }\n  }\n  return jumps [ n - 1 ];\n}\n", "MAXIMIZE_ARRAY_ELEMENTS_UPTO_GIVEN_NUMBER": "int findMaxVal ( int arr [ ], int n, int num, int maxLimit ) {\n  int ind;\n  int val;\n  int dp [ n ] [ maxLimit + 1 ];\n  for ( ind = 0;\n  ind < n;\n  ind ++ ) {\n    for ( val = 0;\n    val <= maxLimit;\n    val ++ ) {\n      if ( ind == 0 ) {\n        if ( num - arr [ ind ] == val || num + arr [ ind ] == val ) {\n          dp [ ind ] [ val ] = 1;\n        }\n        else {\n          dp [ ind ] [ val ] = 0;\n        }\n      }\n      else {\n        if ( val - arr [ ind ] >= 0 && val + arr [ ind ] <= maxLimit ) {\n          dp [ ind ] [ val ] = dp [ ind - 1 ] [ val - arr [ ind ] ] || dp [ ind - 1 ] [ val + arr [ ind ] ];\n        }\n        else if ( val - arr [ ind ] >= 0 ) {\n          dp [ ind ] [ val ] = dp [ ind - 1 ] [ val - arr [ ind ] ];\n        }\n        else if ( val + arr [ ind ] <= maxLimit ) {\n          dp [ ind ] [ val ] = dp [ ind - 1 ] [ val + arr [ ind ] ];\n        }\n        else {\n          dp [ ind ] [ val ] = 0;\n        }\n      }\n    }\n  }\n  for ( val = maxLimit;\n  val >= 0;\n  val -- ) {\n    if ( dp [ n - 1 ] [ val ] ) {\n      return val;\n    }\n  }\n  return - 1;\n}\n", "PROGRAM_FOR_DEADLOCK_FREE_CONDITION_IN_OPERATING_SYSTEM": "int Resources ( int process, int need ) {\n  int minResources = 0;\n  minResources = process * ( need - 1 ) + 1;\n  return minResources;\n}\n", "NUMBER_DIGITS_PRODUCT_TWO_NUMBERS": "int countDigits ( int a, int b ) {\n  int count = 0;\n  int p = abs ( a * b );\n  if ( p == 0 ) return 1;\n  while ( p > 0 ) {\n    count ++;\n    p = p / 10;\n  }\n  return count;\n}\n", "FLOOR_IN_A_SORTED_ARRAY": "int floorSearch ( int arr [ ], int n, int x ) {\n  if ( x >= arr [ n - 1 ] ) return n - 1;\n  if ( x < arr [ 0 ] ) return - 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( arr [ i ] > x ) return ( i - 1 );\n  return - 1;\n}\n", "CHECK_WHETHER_TRIANGLE_VALID_NOT_SIDES_GIVEN": "bool checkValidity ( int a, int b, int c ) {\n  if ( a + b <= c || a + c <= b || b + c <= a ) return false;\n  else return true;\n}\n", "PRINT_N_X_N_SPIRAL_MATRIX_USING_O1_EXTRA_SPACE": "void printSpiral ( int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      int x;\n      x = min ( min ( i, j ), min ( n - 1 - i, n - 1 - j ) );\n      if ( i <= j ) printf ( \"%d\\t \", ( n - 2 * x ) * ( n - 2 * x ) - ( i - x ) - ( j - x ) );\n      else printf ( \"%d\\t \", ( n - 2 * x - 2 ) * ( n - 2 * x - 2 ) + ( i - x ) + ( j - x ) );\n    }\n    printf ( \"\\n\" );\n  }\n}\n", "POSITION_ELEMENT_STABLE_SORT": "int getIndexInSortedArray ( int arr [ ], int n, int idx ) {\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] < arr [ idx ] ) result ++;\n    if ( arr [ i ] == arr [ idx ] && i < idx ) result ++;\n  }\n  return result;\n}\n", "MAXIMUM_SEGMENT_VALUE_PUTTING_K_BREAKPOINTS_NUMBER": "int findMaxSegment ( string & s, int k ) {\n  int seg_len = s . length ( ) - k;\n  int res = 0;\n  for ( int i = 0;\n  i < seg_len;\n  i ++ ) res = res * 10 + ( s [ i ] - '0' );\n  int seg_len_pow = pow ( 10, seg_len - 1 );\n  int curr_val = res;\n  for ( int i = 1;\n  i <= ( s . length ( ) - seg_len );\n  i ++ ) {\n    curr_val = curr_val - ( s [ i - 1 ] - '0' ) * seg_len_pow;\n    curr_val = curr_val * 10 + ( s [ i + seg_len - 1 ] - '0' );\n    res = max ( res, curr_val );\n  }\n  return res;\n}\n", "FINDING_POWER_PRIME_NUMBER_P_N_1": "int PowerOFPINnfactorial ( int n, int p ) {\n  int ans = 0;\n  int temp = p;\n  while ( temp <= n ) {\n    ans += n / temp;\n    temp = temp * p;\n  }\n  return ans;\n}\n", "PROGRAM_PRINT_IDENTITY_MATRIX": "int Identity ( int num ) {\n  int row, col;\n  for ( row = 0;\n  row < num;\n  row ++ ) {\n    for ( col = 0;\n    col < num;\n    col ++ ) {\n      if ( row == col ) cout << 1 << \" \";\n      else cout << 0 << \" \";\n    }\n    cout << endl;\n  }\n  return 0;\n}\n", "SUM_MATRIX_ELEMENT_ELEMENT_INTEGER_DIVISION_ROW_COLUMN": "int findSum ( int n ) {\n  int ans = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= n;\n  j ++ ) ans += ( i / j );\n  return ans;\n}\n", "TILING_WITH_DOMINOES": "int countWays ( int n ) {\n  int A [ n + 1 ], B [ n + 1 ];\n  A [ 0 ] = 1, A [ 1 ] = 0, B [ 0 ] = 0, B [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    A [ i ] = A [ i - 2 ] + 2 * B [ i - 1 ];\n    B [ i ] = A [ i - 1 ] + B [ i - 2 ];\n  }\n  return A [ n ];\n}\n", "COUNT_DERANGEMENTS_PERMUTATION_SUCH_THAT_NO_ELEMENT_APPEARS_IN_ITS_ORIGINAL_POSITION": "int countDer ( int 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}\n", "FREQUENCY_ELEMENT_UNSORTED_ARRAY_1": "void countFreq ( int a [ ], int n ) {\n  unordered_map < int, int > hm;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hm [ a [ i ] ] ++;\n  int cumul = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cumul += hm [ a [ i ] ];\n    if ( hm [ a [ i ] ] ) {\n      cout << a [ i ] << \"->\" << cumul << endl;\n    }\n    hm [ a [ i ] ] = 0;\n  }\n}\n", "MINIMIZE_THE_SUM_OF_DIGITS_OF_A_AND_B_SUCH_THAT_A_B_N": "int minSum ( int n ) {\n  int sum = 0;\n  while ( n > 0 ) {\n    sum += ( n % 10 );\n    n /= 10;\n  }\n  if ( sum == 1 ) return 10;\n  return sum;\n}\n", "DIVIDE_CUBOID_CUBES_SUM_VOLUMES_MAXIMUM": "void maximizecube ( int l, int b, int h ) {\n  int side = __gcd ( l, __gcd ( b, h ) );\n  int num = l / side;\n  num = ( num * b / side );\n  num = ( num * h / side );\n  cout << side << \" \" << num << endl;\n}\n", "CHECK_NUMBER_POWER_K_USING_BASE_CHANGING_METHOD": "bool isPowerOfK ( unsigned int n, unsigned int k ) {\n  bool oneSeen = false;\n  while ( n > 0 ) {\n    int digit = n % k;\n    if ( digit > 1 ) return false;\n    if ( digit == 1 ) {\n      if ( oneSeen ) return false;\n      oneSeen = true;\n    }\n    n /= k;\n  }\n  return true;\n}\n", "POSITION_OF_RIGHTMOST_SET_BIT_1": "int PositionRightmostSetbit ( int n ) {\n  int position = 1;\n  int m = 1;\n  while ( ! ( n & m ) ) {\n    m = m << 1;\n    position ++;\n  }\n  return position;\n}\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY_1": "int insertSorted ( int arr [ ], int n, int key, int capacity ) {\n  if ( n >= capacity ) return n;\n  int i;\n  for ( i = n - 1;\n  ( i >= 0 && arr [ i ] > key );\n  i -- ) arr [ i + 1 ] = arr [ i ];\n  arr [ i + 1 ] = key;\n  return ( n + 1 );\n}\n", "FIND_THE_MAXIMUM_OF_MINIMUMS_FOR_EVERY_WINDOW_SIZE_IN_A_GIVEN_ARRAY_1": "void printMaxOfMin ( int arr [ ], int n ) {\n  stack < int > s;\n  int left [ n + 1 ];\n  int right [ n + 1 ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    left [ i ] = - 1;\n    right [ i ] = n;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( ! s . empty ( ) && arr [ s . top ( ) ] >= arr [ i ] ) s . pop ( );\n    if ( ! s . empty ( ) ) left [ i ] = s . top ( );\n    s . push ( i );\n  }\n  while ( ! s . empty ( ) ) s . pop ( );\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    while ( ! s . empty ( ) && arr [ s . top ( ) ] >= arr [ i ] ) s . pop ( );\n    if ( ! s . empty ( ) ) right [ i ] = s . top ( );\n    s . push ( i );\n  }\n  int ans [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) ans [ i ] = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int len = right [ i ] - left [ i ] - 1;\n    ans [ len ] = max ( ans [ len ], arr [ i ] );\n  }\n  for ( int i = n - 1;\n  i >= 1;\n  i -- ) ans [ i ] = max ( ans [ i ], ans [ i + 1 ] );\n  for ( int i = 1;\n  i <= n;\n  i ++ ) cout << ans [ i ] << \" \";\n}\n", "MAXIMUM_DECIMAL_VALUE_PATH_IN_A_BINARY_MATRIX_1": "long long int MaximumDecimalValue ( int mat [ ] [ N ], int n ) {\n  int dp [ n ] [ n ];\n  memset ( dp, 0, sizeof ( dp ) );\n  if ( mat [ 0 ] [ 0 ] == 1 ) dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( mat [ 0 ] [ i ] == 1 ) dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ] + pow ( 2, i );\n    else dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ];\n  }\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( mat [ i ] [ 0 ] == 1 ) dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ] + pow ( 2, i );\n    else dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ];\n  }\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    for ( int j = 1;\n    j < n;\n    j ++ ) {\n      if ( mat [ i ] [ j ] == 1 ) dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ], dp [ i - 1 ] [ j ] ) + pow ( 2, i + j );\n      else dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ], dp [ i - 1 ] [ j ] );\n    }\n  }\n  return dp [ n - 1 ] [ n - 1 ];\n}\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE": "int printCountRec ( int dist ) {\n  if ( dist < 0 ) return 0;\n  if ( dist == 0 ) return 1;\n  return printCountRec ( dist - 1 ) + printCountRec ( dist - 2 ) + printCountRec ( dist - 3 );\n}\n", "MOVE_VE_ELEMENTS_END_ORDER_EXTRA_SPACE_ALLOWED": "void segregateElements ( int arr [ ], int n ) {\n  int temp [ n ];\n  int j = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] >= 0 ) temp [ j ++ ] = arr [ i ];\n  if ( j == n || j == 0 ) return;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] < 0 ) temp [ j ++ ] = arr [ i ];\n  memcpy ( arr, temp, sizeof ( temp ) );\n}\n", "MINIMUM_PERIMETER_N_BLOCKS": "int minPerimeter ( int n ) {\n  int l = sqrt ( n );\n  int sq = l * l;\n  if ( sq == n ) return l * 4;\n  else {\n    long long int row = n / l;\n    long long int perimeter = 2 * ( l + row );\n    if ( n % l != 0 ) perimeter += 2;\n    return perimeter;\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_36_CUT_A_ROPE_TO_MAXIMIZE_PRODUCT": "int maxProd ( int n ) {\n  if ( n == 0 || n == 1 ) return 0;\n  int max_val = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) max_val = max ( max_val, i * ( n - i ), maxProd ( n - i ) * i );\n  return max_val;\n}\n", "LONGEST_COMMON_SUBSTRING_SPACE_OPTIMIZED_DP_SOLUTION": "int LCSubStr ( string X, string Y ) {\n  int m = X . length ( );\n  int n = Y . length ( );\n  int result = 0;\n  int len [ 2 ] [ n ];\n  int currRow = 0;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( i == 0 || j == 0 ) {\n        len [ currRow ] [ j ] = 0;\n      }\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) {\n        len [ currRow ] [ j ] = len [ 1 - currRow ] [ j - 1 ] + 1;\n        result = max ( result, len [ currRow ] [ j ] );\n      }\n      else {\n        len [ currRow ] [ j ] = 0;\n      }\n    }\n    currRow = 1 - currRow;\n  }\n  return result;\n}\n", "CHECK_GIVEN_STRING_ROTATION_PALINDROME": "bool isPalindrome ( string str ) {\n  int l = 0;\n  int h = str . length ( ) - 1;\n  while ( h > l ) if ( str [ l ++ ] != str [ h -- ] ) return false;\n  return true;\n}\n", "FIND_NUMBER_OF_SOLUTIONS_OF_A_LINEAR_EQUATION_OF_N_VARIABLES_1": "int countSol ( int coeff [ ], int n, int rhs ) {\n  int dp [ rhs + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = coeff [ i ];\n  j <= rhs;\n  j ++ ) dp [ j ] += dp [ j - coeff [ i ] ];\n  return dp [ rhs ];\n}\n", "FIND_THE_LARGEST_PAIR_SUM_IN_AN_UNSORTED_ARRAY": "int findLargestSumPair ( int arr [ ], int n ) {\n  int first, second;\n  if ( arr [ 0 ] > arr [ 1 ] ) {\n    first = arr [ 0 ];\n    second = arr [ 1 ];\n  }\n  else {\n    first = arr [ 1 ];\n    second = arr [ 0 ];\n  }\n  for ( int i = 2;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] > first ) {\n      second = first;\n      first = arr [ i ];\n    }\n    else if ( arr [ i ] > second && arr [ i ] != first ) second = arr [ i ];\n  }\n  return ( first + second );\n}\n", "FIND_BITONIC_POINT_GIVEN_BITONIC_SEQUENCE": "int binarySearch ( int arr [ ], int left, int right ) {\n  if ( left <= right ) {\n    int mid = ( left + right ) / 2;\n    if ( arr [ mid - 1 ] < arr [ mid ] && arr [ mid ] > arr [ mid + 1 ] ) return mid;\n    if ( arr [ mid ] < arr [ mid + 1 ] ) return binarySearch ( arr, mid + 1, right );\n    else return binarySearch ( arr, left, mid - 1 );\n  }\n  return - 1;\n}\n", "PRINT_ALL_DISTINCT_CHARACTERS_OF_A_STRING_IN_ORDER_3_METHODS_1": "void printDistinct ( string str ) {\n  int n = str . length ( );\n  int count [ MAX_CHAR ];\n  int index [ MAX_CHAR ];\n  for ( int i = 0;\n  i < MAX_CHAR;\n  i ++ ) {\n    count [ i ] = 0;\n    index [ i ] = n;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    char x = str [ i ];\n    ++ count [ x ];\n    if ( count [ x ] == 1 && x != ' ' ) index [ x ] = i;\n    if ( count [ x ] == 2 ) index [ x ] = n;\n  }\n  sort ( index, index + MAX_CHAR );\n  for ( int i = 0;\n  i < MAX_CHAR && index [ i ] != n;\n  i ++ ) cout << str [ index [ i ] ];\n}\n", "FIND_TWO_SIDES_RIGHT_ANGLE_TRIANGLE": "void printOtherSides ( int n ) {\n  if ( n & 1 ) {\n    if ( n == 1 ) cout << - 1 << endl;\n    else {\n      int b = ( n * n - 1 ) / 2;\n      int c = ( n * n + 1 ) / 2;\n      cout << \"b = \" << b << \", c = \" << c << endl;\n    }\n  }\n  else {\n    if ( n == 2 ) cout << - 1 << endl;\n    else {\n      int b = n * n / 4 - 1;\n      int c = n * n / 4 + 1;\n      cout << \"b = \" << b << \", c = \" << c << endl;\n    }\n  }\n}\n", "COUNT_NUMBER_OF_STRINGS_MADE_OF_R_G_AND_B_USING_GIVEN_COMBINATION": "int possibleStrings ( int n, int r, int b, int g ) {\n  int fact [ n + 1 ];\n  fact [ 0 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) fact [ i ] = fact [ i - 1 ] * i;\n  int left = n - ( r + g + b );\n  int sum = 0;\n  for ( int i = 0;\n  i <= left;\n  i ++ ) {\n    for ( int j = 0;\n    j <= left - i;\n    j ++ ) {\n      int k = left - ( i + j );\n      sum = sum + fact [ n ] / ( fact [ i + r ] * fact [ j + b ] * fact [ k + g ] );\n    }\n  }\n  return sum;\n}\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM_SET_2_O1_EXTRA_SPACE_1": "void rearrange ( int arr [ ], int n ) {\n  int max_ele = arr [ n - 1 ];\n  int min_ele = arr [ 0 ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i % 2 == 0 ) {\n      arr [ i ] = max_ele;\n      max_ele -= 1;\n    }\n    else {\n      arr [ i ] = min_ele;\n      min_ele += 1;\n    }\n  }\n}\n", "EVALUATE_AN_ARRAY_EXPRESSION_WITH_NUMBERS_AND": "int calculateSum ( string arr [ ], int n ) {\n  if ( n == 0 ) return 0;\n  string s = arr [ 0 ];\n  int value = stoi ( s );\n  int sum = value;\n  for ( int i = 2;\n  i < n;\n  i = i + 2 ) {\n    s = arr [ i ];\n    int value = stoi ( s );\n    char operation = arr [ i - 1 ] [ 0 ];\n    if ( operation == '+' ) sum += value;\n    else sum -= value;\n  }\n  return sum;\n}\n", "SUM_MATRIX_ELEMENT_ELEMENT_INTEGER_DIVISION_ROW_COLUMN_1": "int findSum ( int n ) {\n  int ans = 0, temp = 0, num;\n  for ( int i = 1;\n  i <= n && temp < n;\n  i ++ ) {\n    temp = i - 1;\n    num = 1;\n    while ( temp < n ) {\n      if ( temp + i <= n ) ans += ( i * num );\n      else ans += ( ( n - temp ) * num );\n      temp += i;\n      num ++;\n    }\n  }\n  return ans;\n}\n", "SHUFFLE_A_DECK_OF_CARDS_3": "void shuffle ( int card [ ], int n ) {\n  srand ( time ( 0 ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int r = i + ( rand ( ) % ( 52 - i ) );\n    swap ( card [ i ], card [ r ] );\n  }\n}\n", "DOOLITTLE_ALGORITHM_LU_DECOMPOSITION": "void luDecomposition ( int mat [ ] [ MAX ], int n ) {\n  int lower [ n ] [ n ], upper [ n ] [ n ];\n  memset ( lower, 0, sizeof ( lower ) );\n  memset ( upper, 0, sizeof ( upper ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int k = i;\n    k < n;\n    k ++ ) {\n      int sum = 0;\n      for ( int j = 0;\n      j < i;\n      j ++ ) sum += ( lower [ i ] [ j ] * upper [ j ] [ k ] );\n      upper [ i ] [ k ] = mat [ i ] [ k ] - sum;\n    }\n    for ( int k = i;\n    k < n;\n    k ++ ) {\n      if ( i == k ) lower [ i ] [ i ] = 1;\n      else {\n        int sum = 0;\n        for ( int j = 0;\n        j < i;\n        j ++ ) sum += ( lower [ k ] [ j ] * upper [ j ] [ i ] );\n        lower [ k ] [ i ] = ( mat [ k ] [ i ] - sum ) / upper [ i ] [ i ];\n      }\n    }\n  }\n  cout << setw ( 6 ) << \"      Lower Triangular\" << setw ( 32 ) << \"Upper Triangular\" << endl;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) cout << setw ( 6 ) << lower [ i ] [ j ] << \"\\t\";\n    cout << \"\\t\";\n    for ( int j = 0;\n    j < n;\n    j ++ ) cout << setw ( 6 ) << upper [ i ] [ j ] << \"\\t\";\n    cout << endl;\n  }\n}\n", "PROGRAM_NTH_CATALAN_NUMBER": "unsigned long int catalan ( unsigned int n ) {\n  if ( n <= 1 ) return 1;\n  unsigned long int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) res += catalan ( i ) * catalan ( n - i - 1 );\n  return res;\n}\n", "NUMBER_DIGITS_REMOVED_MAKE_NUMBER_DIVISIBLE_3": "int divisible ( string num ) {\n  int n = num . length ( );\n  int sum = accumulate ( begin ( num ), end ( num ), 0 ) - '0' * 1;\n  if ( sum % 3 == 0 ) return 0;\n  if ( n == 1 ) return - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( sum % 3 == ( num [ i ] - '0' ) % 3 ) return 1;\n  if ( n == 2 ) return - 1;\n  return 2;\n}\n", "CHECK_IF_A_NUMBER_IS_POWER_OF_ANOTHER_NUMBER_1": "bool isPower ( int x, int y ) {\n  int res1 = log ( y ) / log ( x );\n  double res2 = log ( y ) / log ( x );\n  return ( res1 == res2 );\n}\n", "LARGEST_SUBSEQUENCE_GCD_GREATER_1": "int largestGCDSubsequence ( int arr [ ], int n ) {\n  int ans = 0;\n  int maxele = * max_element ( arr, arr + n );\n  for ( int i = 2;\n  i <= maxele;\n  ++ i ) {\n    int count = 0;\n    for ( int j = 0;\n    j < n;\n    ++ j ) {\n      if ( arr [ j ] % i == 0 ) ++ count;\n    }\n    ans = max ( ans, count );\n  }\n  return ans;\n}\n", "FIND_COMMON_ELEMENT_ROWS_ROW_WISE_SORTED_MATRIX": "int findCommon ( int mat [ M ] [ N ] ) {\n  int column [ M ];\n  int min_row;\n  int i;\n  for ( i = 0;\n  i < M;\n  i ++ ) column [ i ] = N - 1;\n  min_row = 0;\n  while ( column [ min_row ] >= 0 ) {\n    for ( i = 0;\n    i < M;\n    i ++ ) {\n      if ( mat [ i ] [ column [ i ] ] < mat [ min_row ] [ column [ min_row ] ] ) min_row = i;\n    }\n    int eq_count = 0;\n    for ( i = 0;\n    i < M;\n    i ++ ) {\n      if ( mat [ i ] [ column [ i ] ] > mat [ min_row ] [ column [ min_row ] ] ) {\n        if ( column [ i ] == 0 ) return - 1;\n        column [ i ] -= 1;\n      }\n      else eq_count ++;\n    }\n    if ( eq_count == M ) return mat [ min_row ] [ column [ min_row ] ];\n  }\n  return - 1;\n}\n", "CHECK_GIVEN_CIRCLE_LIES_COMPLETELY_INSIDE_RING_FORMED_TWO_CONCENTRIC_CIRCLES": "bool checkcircle ( int r, int R, int r1, int x1, int y1 ) {\n  int dis = sqrt ( x1 * x1 + y1 * y1 );\n  return ( dis - r1 >= R && dis + r1 <= r );\n}\n", "COUNT_TOTAL_SET_BITS_IN_ALL_NUMBERS_FROM_1_TO_N": "int countSetBits ( int n ) {\n  int i = 0;\n  int ans = 0;\n  while ( ( 1 << i ) <= n ) {\n    bool k = 0;\n    int change = 1 << i;\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      ans += k;\n      if ( change == 1 ) {\n        k = ! k;\n        change = 1 << i;\n      }\n      else {\n        change --;\n      }\n    }\n    i ++;\n  }\n  return ans;\n}\n", "LONGEST_REPEATING_SUBSEQUENCE": "int findLongestRepeatingSubSeq ( string str ) {\n  int n = str . length ( );\n  int dp [ n + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) for ( int j = 0;\n  j <= n;\n  j ++ ) dp [ i ] [ j ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      if ( str [ i - 1 ] == str [ j - 1 ] && i != j ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ], dp [ i - 1 ] [ j ] );\n    }\n  }\n  return dp [ n ] [ n ];\n}\n", "FIND_THE_FIRST_MISSING_NUMBER": "int findFirstMissing ( int array [ ], int start, int end ) {\n  if ( start > end ) return end + 1;\n  if ( start != array [ start ] ) return start;\n  int mid = ( start + end ) / 2;\n  if ( array [ mid ] == mid ) return findFirstMissing ( array, mid + 1, end );\n  return findFirstMissing ( array, start, mid );\n}\n", "SORT_ARRAY_CONVERTING_ELEMENTS_SQUARES_1": "void sortSquares ( int arr [ ], int n ) {\n  int K = 0;\n  for ( K = 0;\n  K < n;\n  K ++ ) if ( arr [ K ] >= 0 ) break;\n  int i = K - 1;\n  int j = K;\n  int ind = 0;\n  int temp [ n ];\n  while ( i >= 0 && j < n ) {\n    if ( arr [ i ] * arr [ i ] < arr [ j ] * arr [ j ] ) {\n      temp [ ind ] = arr [ i ] * arr [ i ];\n      i --;\n    }\n    else {\n      temp [ ind ] = arr [ j ] * arr [ j ];\n      j ++;\n    }\n    ind ++;\n  }\n  while ( i >= 0 ) {\n    temp [ ind ] = arr [ i ] * arr [ i ];\n    i --;\n    ind ++;\n  }\n  while ( j < n ) {\n    temp [ ind ] = arr [ j ] * arr [ j ];\n    j ++;\n    ind ++;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = temp [ i ];\n}\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR": "int getRemainder ( int num, int divisor ) {\n  return ( num - divisor * ( num / divisor ) );\n}\n", "MINIMUM_COST_TO_FILL_GIVEN_WEIGHT_IN_A_BAG": "int MinimumCost ( int cost [ ], int n, int W ) {\n  vector < int > val, wt;\n  int size = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( cost [ i ] != - 1 ) {\n      val . push_back ( cost [ i ] );\n      wt . push_back ( i + 1 );\n      size ++;\n    }\n  }\n  n = size;\n  int min_cost [ n + 1 ] [ W + 1 ];\n  for ( int i = 0;\n  i <= W;\n  i ++ ) min_cost [ 0 ] [ i ] = INF;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) min_cost [ i ] [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= W;\n    j ++ ) {\n      if ( wt [ i - 1 ] > j ) min_cost [ i ] [ j ] = min_cost [ i - 1 ] [ j ];\n      else min_cost [ i ] [ j ] = min ( min_cost [ i - 1 ] [ j ], min_cost [ i ] [ j - wt [ i - 1 ] ] + val [ i - 1 ] );\n    }\n  }\n  return ( min_cost [ n ] [ W ] == INF ) ? - 1 : min_cost [ n ] [ W ];\n}\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS_1": "int countPairs ( string str ) {\n  int result = 0;\n  int n = str . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 1;\n  ( i + j ) < n && j <= MAX_CHAR;\n  j ++ ) if ( ( abs ( str [ i + j ] - str [ i ] ) == j ) ) result ++;\n  return result;\n}\n", "A_PRODUCT_ARRAY_PUZZLE": "void productArray ( int arr [ ], int n ) {\n  if ( n == 1 ) {\n    cout << 0;\n    return;\n  }\n  int * left = new int [ sizeof ( int ) * n ];\n  int * right = new int [ sizeof ( int ) * n ];\n  int * prod = new int [ sizeof ( int ) * n ];\n  int i, j;\n  left [ 0 ] = 1;\n  right [ n - 1 ] = 1;\n  for ( i = 1;\n  i < n;\n  i ++ ) left [ i ] = arr [ i - 1 ] * left [ i - 1 ];\n  for ( j = n - 2;\n  j >= 0;\n  j -- ) right [ j ] = arr [ j + 1 ] * right [ j + 1 ];\n  for ( i = 0;\n  i < n;\n  i ++ ) prod [ i ] = left [ i ] * right [ i ];\n  for ( i = 0;\n  i < n;\n  i ++ ) cout << prod [ i ] << \" \";\n  return;\n}\n", "FREQUENT_ELEMENT_ARRAY_1": "int mostFrequent ( int arr [ ], int n ) {\n  unordered_map < int, int > hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hash [ arr [ i ] ] ++;\n  int max_count = 0, res = - 1;\n  for ( auto i : hash ) {\n    if ( max_count < i . second ) {\n      res = i . first;\n      max_count = i . second;\n    }\n  }\n  return res;\n}\n", "PRINT_UNIQUE_ROWS": "void printArray ( int arr [ ] [ 5 ], int row, int col ) {\n  unordered_set < string > uset;\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    string s = \"\";\n    for ( int j = 0;\n    j < col;\n    j ++ ) s += to_string ( arr [ i ] [ j ] );\n    if ( uset . count ( s ) == 0 ) {\n      uset . insert ( s );\n      cout << s << endl;\n    }\n  }\n}\n", "COUNT_1S_SORTED_BINARY_ARRAY": "int countOnes ( bool arr [ ], int low, int high ) {\n  if ( high >= low ) {\n    int mid = low + ( high - low ) / 2;\n    if ( ( mid == high || arr [ mid + 1 ] == 0 ) && ( arr [ mid ] == 1 ) ) return mid + 1;\n    if ( arr [ mid ] == 1 ) return countOnes ( arr, ( mid + 1 ), high );\n    return countOnes ( arr, low, ( mid - 1 ) );\n  }\n  return 0;\n}\n", "POSSIBLE_MOVES_KNIGHT": "int findPossibleMoves ( int mat [ n ] [ m ], int p, int q ) {\n  int X [ 8 ] = {\n    2, 1, - 1, - 2, - 2, - 1, 1, 2 };\n    int Y [ 8 ] = {\n      1, 2, 2, 1, - 1, - 2, - 2, - 1 };\n      int count = 0;\n      for ( int i = 0;\n      i < 8;\n      i ++ ) {\n        int x = p + X [ i ];\n        int y = q + Y [ i ];\n        if ( x >= 0 && y >= 0 && x < n && y < m && mat [ x ] [ y ] == 0 ) count ++;\n      }\n      return count;\n    }\n    ", "ROTATE_MATRIX_ELEMENTS": "void rotatematrix ( int m, int n, int mat [ R ] [ C ] ) {\n  int row = 0, col = 0;\n  int prev, curr;\n  while ( row < m && col < n ) {\n    if ( row + 1 == m || col + 1 == n ) break;\n    prev = mat [ row + 1 ] [ col ];\n    for ( int i = col;\n    i < n;\n    i ++ ) {\n      curr = mat [ row ] [ i ];\n      mat [ row ] [ i ] = prev;\n      prev = curr;\n    }\n    row ++;\n    for ( int i = row;\n    i < m;\n    i ++ ) {\n      curr = mat [ i ] [ n - 1 ];\n      mat [ i ] [ n - 1 ] = prev;\n      prev = curr;\n    }\n    n --;\n    if ( row < m ) {\n      for ( int i = n - 1;\n      i >= col;\n      i -- ) {\n        curr = mat [ m - 1 ] [ i ];\n        mat [ m - 1 ] [ i ] = prev;\n        prev = curr;\n      }\n    }\n    m --;\n    if ( col < n ) {\n      for ( int i = m - 1;\n      i >= row;\n      i -- ) {\n        curr = mat [ i ] [ col ];\n        mat [ i ] [ col ] = prev;\n        prev = curr;\n      }\n    }\n    col ++;\n  }\n  for ( int i = 0;\n  i < R;\n  i ++ ) {\n    for ( int j = 0;\n    j < C;\n    j ++ ) cout << mat [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "FIND_KTH_CHARACTER_OF_DECRYPTED_STRING": "char encodedChar ( string str, int k ) {\n  string expand = \"\";\n  string temp;\n  int freq = 0;\n  for ( int i = 0;\n  str [ i ] != '\\0';\n  ) {\n    temp = \"\";\n    freq = 0;\n    while ( str [ i ] >= 'a' && str [ i ] <= 'z' ) {\n      temp . push_back ( str [ i ] );\n      i ++;\n    }\n    while ( str [ i ] >= '1' && str [ i ] <= '9' ) {\n      freq = freq * 10 + str [ i ] - '0';\n      i ++;\n    }\n    for ( int j = 1;\n    j <= freq;\n    j ++ ) expand . append ( temp );\n  }\n  if ( freq == 0 ) expand . append ( temp );\n  return expand [ k - 1 ];\n}\n", "EFFICIENT_SEARCH_IN_AN_ARRAY_WHERE_DIFFERENCE_BETWEEN_ADJACENT_IS_1": "int search ( int arr [ ], int n, int x ) {\n  int i = 0;\n  while ( i <= n - 1 ) {\n    if ( arr [ i ] == x ) return i;\n    i += abs ( arr [ i ] - x );\n  }\n  return - 1;\n}\n", "MAXIMUM_POSSIBLE_SUM_WINDOW_ARRAY_ELEMENTS_WINDOW_ARRAY_UNIQUE": "int returnMaxSum ( int A [ ], int B [ ], int n ) {\n  unordered_set < int > mp;\n  int result = 0;\n  int curr_sum = 0, curr_begin = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    while ( mp . find ( A [ i ] ) != mp . end ( ) ) {\n      mp . erase ( A [ curr_begin ] );\n      curr_sum -= B [ curr_begin ];\n      curr_begin ++;\n    }\n    mp . insert ( A [ i ] );\n    curr_sum += B [ i ];\n    result = max ( result, curr_sum );\n  }\n  return result;\n}\n", "WRITE_AN_EFFICIENT_METHOD_TO_CHECK_IF_A_NUMBER_IS_MULTIPLE_OF_3": "int isMultipleOf3 ( int n ) {\n  int odd_count = 0;\n  int even_count = 0;\n  if ( n < 0 ) n = - n;\n  if ( n == 0 ) return 1;\n  if ( n == 1 ) return 0;\n  while ( n ) {\n    if ( n & 1 ) odd_count ++;\n    if ( n & 2 ) even_count ++;\n    n = n >> 2;\n  }\n  return isMultipleOf3 ( abs ( odd_count - even_count ) );\n}\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY_1": "int maxSum ( int arr [ ], int n ) {\n  int cum_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) cum_sum += arr [ i ];\n  int curr_val = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) curr_val += i * arr [ i ];\n  int res = curr_val;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int 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  }\n  return res;\n}\n", "DYNAMIC_PROGRAMMING_SET_34_ASSEMBLY_LINE_SCHEDULING": "int carAssembly ( int a [ ] [ NUM_STATION ], int t [ ] [ NUM_STATION ], int * e, int * x ) {\n  int T1 [ NUM_STATION ], T2 [ NUM_STATION ], i;\n  T1 [ 0 ] = e [ 0 ] + a [ 0 ] [ 0 ];\n  T2 [ 0 ] = e [ 1 ] + a [ 1 ] [ 0 ];\n  for ( i = 1;\n  i < NUM_STATION;\n  ++ i ) {\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  }\n  return min ( T1 [ NUM_STATION - 1 ] + x [ 0 ], T2 [ NUM_STATION - 1 ] + x [ 1 ] );\n}\n", "PRINT_MATRIX_SPIRAL_FORM_STARTING_POINT": "void printSpiral ( int mat [ ] [ MAX ], int r, int c ) {\n  int i, a = 0, b = 2;\n  int low_row = ( 0 > a ) ? 0 : a;\n  int low_column = ( 0 > b ) ? 0 : b - 1;\n  int high_row = ( ( a + 1 ) >= r ) ? r - 1 : a + 1;\n  int high_column = ( ( b + 1 ) >= c ) ? c - 1 : b + 1;\n  while ( ( low_row > 0 - r && low_column > 0 - c ) ) {\n    for ( i = low_column + 1;\n    i <= high_column && i < c && low_row >= 0;\n    ++ i ) cout << mat [ low_row ] [ i ] << \" \";\n    low_row -= 1;\n    for ( i = low_row + 2;\n    i <= high_row && i < r && high_column < c;\n    ++ i ) cout << mat [ i ] [ high_column ] << \" \";\n    high_column += 1;\n    for ( i = high_column - 2;\n    i >= low_column && i >= 0 && high_row < r;\n    -- i ) cout << mat [ high_row ] [ i ] << \" \";\n    high_row += 1;\n    for ( i = high_row - 2;\n    i > low_row && i >= 0 && low_column >= 0;\n    -- i ) cout << mat [ i ] [ low_column ] << \" \";\n    low_column -= 1;\n  }\n  cout << endl;\n}\n", "MID_POINT_CIRCLE_DRAWING_ALGORITHM": "void midPointCircleDraw ( int x_centre, int y_centre, int r ) {\n  int x = r, y = 0;\n  cout << \"(\" << x + x_centre << \", \" << y + y_centre << \") \";\n  if ( r > 0 ) {\n    cout << \"(\" << x + x_centre << \", \" << - y + y_centre << \") \";\n    cout << \"(\" << y + x_centre << \", \" << x + y_centre << \") \";\n    cout << \"(\" << - y + x_centre << \", \" << x + y_centre << \")\\n\";\n  }\n  int P = 1 - r;\n  while ( x > y ) {\n    y ++;\n    if ( P <= 0 ) P = P + 2 * y + 1;\n    else {\n      x --;\n      P = P + 2 * y - 2 * x + 1;\n    }\n    if ( x < y ) break;\n    cout << \"(\" << x + x_centre << \", \" << y + y_centre << \") \";\n    cout << \"(\" << - x + x_centre << \", \" << y + y_centre << \") \";\n    cout << \"(\" << x + x_centre << \", \" << - y + y_centre << \") \";\n    cout << \"(\" << - x + x_centre << \", \" << - y + y_centre << \")\\n\";\n    if ( x != y ) {\n      cout << \"(\" << y + x_centre << \", \" << x + y_centre << \") \";\n      cout << \"(\" << - y + x_centre << \", \" << x + y_centre << \") \";\n      cout << \"(\" << y + x_centre << \", \" << - x + y_centre << \") \";\n      cout << \"(\" << - y + x_centre << \", \" << - x + y_centre << \")\\n\";\n    }\n  }\n}\n", "SMALLEST_ELEMENT_REPEATED_EXACTLY_K_TIMES_NOT_LIMITED_SMALL_RANGE": "int smallestKFreq ( int a [ ], int n, int k ) {\n  unordered_map < int, int > m;\n  for ( int i = 0;\n  i < n;\n  i ++ ) m [ a [ i ] ] ++;\n  int res = INT_MAX;\n  for ( auto it = m . begin ( );\n  it != m . end ( );\n  ++ it ) if ( it -> second == k ) res = min ( res, it -> first );\n  return ( res != INT_MAX ) ? res : - 1;\n}\n", "MINIMUM_XOR_VALUE_PAIR": "int minXOR ( int arr [ ], int n ) {\n  int min_xor = INT_MAX;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) min_xor = min ( min_xor, arr [ i ] ^ arr [ j ] );\n  return min_xor;\n}\n", "MIRROR_CHARACTERS_STRING": "string compute ( string str, int n ) {\n  string reverseAlphabet = \"zyxwvutsrqponmlkjihgfedcba\";\n  int l = str . length ( );\n  for ( int i = n;\n  i < l;\n  i ++ ) str [ i ] = reverseAlphabet [ str [ i ] - 'a' ];\n  return str;\n}\n", "PROGRAM_CHECK_PLUS_PERFECT_NUMBER": "bool checkplusperfect ( int x ) {\n  int temp = x;\n  int n = 0;\n  while ( x != 0 ) {\n    x /= 10;\n    n ++;\n  }\n  x = temp;\n  int sum = 0;\n  while ( x != 0 ) {\n    sum += pow ( x % 10, n );\n    x /= 10;\n  }\n  return ( sum == temp );\n}\n", "ARC_LENGTH_ANGLE": "double arcLength ( double diameter, double angle ) {\n  double pi = 22.0 / 7.0;\n  double arc;\n  if ( angle >= 360 ) {\n    cout << \"Angle cannot\", \" be formed\";\n    return 0;\n  }\n  else {\n    arc = ( pi * diameter ) * ( angle / 360.0 );\n    return arc;\n  }\n}\n", "FIND_LAST_INDEX_CHARACTER_STRING": "int findLastIndex ( string & str, char x ) {\n  int index = - 1;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) if ( str [ i ] == x ) index = i;\n  return index;\n}\n", "COUNT_TRAILING_ZEROES_FACTORIAL_NUMBER": "int findTrailingZeros ( int n ) {\n  int count = 0;\n  for ( int i = 5;\n  n / i >= 1;\n  i *= 5 ) count += n / i;\n  return count;\n}\n", "ROTATE_MATRIX_180_DEGREE": "void rotateMatrix ( int mat [ ] [ N ] ) {\n  for ( int i = N - 1;\n  i >= 0;\n  i -- ) {\n    for ( int j = N - 1;\n    j >= 0;\n    j -- ) printf ( \"%d \", mat [ i ] [ j ] );\n    printf ( \"\\n\" );\n  }\n}\n", "SUM_FIBONACCI_NUMBERS": "int calculateSum ( int n ) {\n  if ( n <= 0 ) return 0;\n  int fibo [ n + 1 ];\n  fibo [ 0 ] = 0, fibo [ 1 ] = 1;\n  int sum = fibo [ 0 ] + fibo [ 1 ];\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    fibo [ i ] = fibo [ i - 1 ] + fibo [ i - 2 ];\n    sum += fibo [ i ];\n  }\n  return sum;\n}\n", "LARGEST_LEXICOGRAPHIC_ARRAY_WITH_AT_MOST_K_CONSECUTIVE_SWAPS": "void KSwapMaximum ( int arr [ ], int n, int k ) {\n  for ( int i = 0;\n  i < n - 1 && k > 0;\n  ++ i ) {\n    int indexPosition = i;\n    for ( int j = i + 1;\n    j < n;\n    ++ j ) {\n      if ( k <= j - i ) break;\n      if ( arr [ j ] > arr [ indexPosition ] ) indexPosition = j;\n    }\n    for ( int j = indexPosition;\n    j > i;\n    -- j ) swap ( arr [ j ], arr [ j - 1 ] );\n    k -= indexPosition - i;\n  }\n}\n", "FIND_WHETHER_GIVEN_INTEGER_POWER_3_NOT": "bool check ( int n ) {\n  return 1162261467 % n == 0;\n}\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY": "void printRepeating ( int arr [ ], int size ) {\n  int i, j;\n  printf ( \" Repeating elements are \" );\n  for ( i = 0;\n  i < size;\n  i ++ ) for ( j = i + 1;\n  j < size;\n  j ++ ) if ( arr [ i ] == arr [ j ] ) cout << arr [ i ] << \" \";\n}\n", "C_PROGRAM_FIND_AREA_TRIANGLE": "float findArea ( float a, float b, float c ) {\n  if ( a < 0 || b < 0 || c < 0 || ( a + b <= c ) || a + c <= b || b + c <= a ) {\n    cout << \"Not a valid trianglen\";\n    exit ( 0 );\n  }\n  float s = ( a + b + c ) / 2;\n  return sqrt ( s * ( s - a ) * ( s - b ) * ( s - c ) );\n}\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8_1": "bool isSubSeqDivisible ( string str ) {\n  int n = str . length ( );\n  int dp [ n + 1 ] [ 10 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  int arr [ n + 1 ];\n  for ( int i = 1;\n  i <= n;\n  i ++ ) arr [ i ] = str [ i - 1 ] - '0';\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    dp [ i ] [ arr [ i ] % 8 ] = 1;\n    for ( int j = 0;\n    j < 8;\n    j ++ ) {\n      if ( dp [ i - 1 ] [ j ] > dp [ i ] [ ( j * 10 + arr [ i ] ) % 8 ] ) dp [ i ] [ ( j * 10 + arr [ i ] ) % 8 ] = dp [ i - 1 ] [ j ];\n      if ( dp [ i - 1 ] [ j ] > dp [ i ] [ j ] ) dp [ i ] [ j ] = dp [ i - 1 ] [ j ];\n    }\n  }\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    if ( dp [ i ] [ 0 ] == 1 ) return true;\n  }\n  return false;\n}\n", "DELETE_ARRAY_ELEMENTS_WHICH_ARE_SMALLER_THAN_NEXT_OR_BECOME_SMALLER": "void deleteElements ( int arr [ ], int n, int k ) {\n  stack < int > s;\n  s . push ( arr [ 0 ] );\n  int count = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    while ( ! s . empty ( ) && s . top ( ) < arr [ i ] && count < k ) {\n      s . pop ( );\n      count ++;\n    }\n    s . push ( arr [ i ] );\n  }\n  int m = s . size ( );\n  vector < int > v ( m );\n  while ( ! s . empty ( ) ) {\n    v [ -- m ] = s . top ( );\n    s . pop ( );\n  }\n  for ( auto x : v ) cout << x << \" \";\n  cout << endl;\n}\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE": "int smallestSubWithSum ( int arr [ ], int n, int x ) {\n  int curr_sum = 0, min_len = n + 1;\n  int start = 0, end = 0;\n  while ( end < n ) {\n    while ( curr_sum <= x && end < n ) curr_sum += arr [ end ++ ];\n    while ( curr_sum > x && start < n ) {\n      if ( end - start < min_len ) min_len = end - start;\n      curr_sum -= arr [ start ++ ];\n    }\n  }\n  return min_len;\n}\n", "FIND_PAIRS_IN_ARRAY_WHOSE_SUMS_ALREADY_EXIST_IN_ARRAY_1": "void findPair ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) s . insert ( arr [ i ] );\n  bool found = false;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      if ( s . find ( arr [ i ] + arr [ j ] ) != s . end ( ) ) {\n        cout << arr [ i ] << \" \" << arr [ j ] << endl;\n        found = true;\n      }\n    }\n  }\n  if ( found == false ) cout << \"Not exist\" << endl;\n}\n", "COUNT_ARITHMETIC_PROGRESSION_SUBSEQUENCES_ARRAY": "int numofAP ( int a [ ], int n ) {\n  int minarr = INT_MAX, maxarr = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    minarr = min ( minarr, a [ i ] );\n    maxarr = max ( maxarr, a [ i ] );\n  }\n  int dp [ n ], sum [ MAX ];\n  int ans = n + 1;\n  for ( int d = ( minarr - maxarr );\n  d <= ( maxarr - minarr );\n  d ++ ) {\n    memset ( sum, 0, sizeof sum );\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      dp [ i ] = 1;\n      if ( a [ i ] - d >= 1 && a [ i ] - d <= 1000000 ) dp [ i ] += sum [ a [ i ] - d ];\n      ans += dp [ i ] - 1;\n      sum [ a [ i ] ] += dp [ i ];\n    }\n  }\n  return ans;\n}\n", "COUNT_NUMBERS_THAT_DONT_CONTAIN_3": "int count ( int n ) {\n  if ( n < 3 ) return n;\n  if ( n >= 3 && n < 10 ) return n - 1;\n  int po = 1;\n  while ( n / po > 9 ) po = po * 10;\n  int msd = n / po;\n  if ( msd != 3 ) return count ( msd ) * count ( po - 1 ) + count ( msd ) + count ( n % po );\n  else return count ( msd * po - 1 );\n}\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX_2": "void transpose ( int A [ ] [ N ] ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = i + 1;\n  j < N;\n  j ++ ) swap ( A [ i ] [ j ], A [ j ] [ i ] );\n}\n", "SUM_DIAGONALS_SPIRAL_ODD_ORDER_SQUARE_MATRIX": "int spiralDiaSum ( int n ) {\n  if ( n == 1 ) return 1;\n  return ( 4 * n * n - 6 * n + 6 + spiralDiaSum ( n - 2 ) );\n}\n", "COUNT_INVERSIONS_OF_SIZE_THREE_IN_A_GIVE_ARRAY": "int getInvCount ( int arr [ ], int n ) {\n  int invcount = 0;\n  for ( int i = 0;\n  i < n - 2;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n - 1;\n    j ++ ) {\n      if ( arr [ i ] > arr [ j ] ) {\n        for ( int k = j + 1;\n        k < n;\n        k ++ ) {\n          if ( arr [ j ] > arr [ k ] ) invcount ++;\n        }\n      }\n    }\n  }\n  return invcount;\n}\n", "FIND_SUM_NODES_GIVEN_PERFECT_BINARY_TREE": "int sumNodes ( int l ) {\n  int leafNodeCount = pow ( 2, l - 1 );\n  vector < int > vec [ l ];\n  for ( int i = 1;\n  i <= leafNodeCount;\n  i ++ ) vec [ l - 1 ] . push_back ( i );\n  for ( int i = l - 2;\n  i >= 0;\n  i -- ) {\n    int k = 0;\n    while ( k < vec [ i + 1 ] . size ( ) - 1 ) {\n      vec [ i ] . push_back ( vec [ i + 1 ] [ k ] + vec [ i + 1 ] [ k + 1 ] );\n      k += 2;\n    }\n  }\n  int sum = 0;\n  for ( int i = 0;\n  i < l;\n  i ++ ) {\n    for ( int j = 0;\n    j < vec [ i ] . size ( );\n    j ++ ) sum += vec [ i ] [ j ];\n  }\n  return sum;\n}\n", "SUM_OF_ALL_PROPER_DIVISORS_OF_A_NATURAL_NUMBER": "int divSum ( int num ) {\n  int result = 0;\n  for ( int i = 2;\n  i <= sqrt ( num );\n  i ++ ) {\n    if ( num % i == 0 ) {\n      if ( i == ( num / i ) ) result += i;\n      else result += ( i + num / i );\n    }\n  }\n  return ( result + 1 );\n}\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE_2": "bool find3Numbers ( int A [ ], int arr_size, int sum ) {\n  for ( int i = 0;\n  i < arr_size - 2;\n  i ++ ) {\n    unordered_set < int > s;\n    int curr_sum = sum - A [ i ];\n    for ( int j = i + 1;\n    j < arr_size;\n    j ++ ) {\n      if ( s . find ( curr_sum - A [ j ] ) != s . end ( ) ) {\n        printf ( \"Triplet is %d, %d, %d\", A [ i ], A [ j ], curr_sum - A [ j ] );\n        return true;\n      }\n      s . insert ( A [ j ] );\n    }\n  }\n  return false;\n}\n", "NTH_EVEN_LENGTH_PALINDROME": "string evenlength ( string n ) {\n  string res = n;\n  for ( int j = n . length ( ) - 1;\n  j >= 0;\n  -- j ) res += n [ j ];\n  return res;\n}\n", "FINDING_POWER_PRIME_NUMBER_P_N": "int PowerOFPINnfactorial ( int n, int p ) {\n  int ans = 0;\n  int temp = p;\n  while ( temp <= n ) {\n    ans += n / temp;\n    temp = temp * p;\n  }\n  return ans;\n}\n", "MINIMUM_COST_MAKE_LONGEST_COMMON_SUBSEQUENCE_LENGTH_K": "int solve ( char X [ ], char Y [ ], int l, int r, int k, int dp [ ] [ N ] [ N ] ) {\n  if ( ! k ) return 0;\n  if ( l < 0 | r < 0 ) return 1e9;\n  if ( dp [ l ] [ r ] [ k ] != - 1 ) return dp [ l ] [ r ] [ k ];\n  int cost = ( X [ l ] - 'a' ) ^ ( Y [ r ] - 'a' );\n  return dp [ l ] [ r ] [ k ] = min ( {\n    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    );\n  }\n  ", "PRINT_STRING_SPECIFIED_CHARACTER_OCCURRED_GIVEN_NO_TIMES": "void printString ( string str, char ch, int count ) {\n  int occ = 0, i;\n  if ( count == 0 ) {\n    cout << str;\n    return;\n  }\n  for ( i = 0;\n  i < str . length ( );\n  i ++ ) {\n    if ( str [ i ] == ch ) occ ++;\n    if ( occ == count ) break;\n  }\n  if ( i < str . length ( ) - 1 ) cout << str . substr ( i + 1, str . length ( ) - ( i + 1 ) );\n  else cout << \"Empty string\";\n}\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS": "bool sortedAfterSwap ( int A [ ], bool B [ ], int n ) {\n  int i, j;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( B [ i ] ) {\n      j = i;\n      while ( B [ j ] ) j ++;\n      sort ( A + i, A + 1 + j );\n      i = j;\n    }\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( A [ i ] != i + 1 ) return false;\n  }\n  return true;\n}\n", "GENERATE_PYTHAGOREAN_TRIPLETS": "void pythagoreanTriplets ( int limit ) {\n  int a, b, c = 0;\n  int m = 2;\n  while ( c < limit ) {\n    for ( int n = 1;\n    n < m;\n    ++ n ) {\n      a = m * m - n * n;\n      b = 2 * m * n;\n      c = m * m + n * n;\n      if ( c > limit ) break;\n      printf ( \"%d %d %d\\n\", a, b, c );\n    }\n    m ++;\n  }\n}\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS": "int countSeq ( int n, int diff ) {\n  if ( abs ( diff ) > n ) return 0;\n  if ( n == 1 && diff == 0 ) return 2;\n  if ( n == 1 && abs ( diff ) == 1 ) return 1;\n  int res = countSeq ( n - 1, diff + 1 ) + 2 * countSeq ( n - 1, diff ) + countSeq ( n - 1, diff - 1 );\n  return res;\n}\n", "POSSIBLE_FORM_TRIANGLE_ARRAY_VALUES": "bool isPossibleTriangle ( int arr [ ], int N ) {\n  if ( N < 3 ) return false;\n  sort ( arr, arr + N );\n  for ( int i = 0;\n  i < N - 2;\n  i ++ ) if ( arr [ i ] + arr [ i + 1 ] > arr [ i + 2 ] ) return true;\n}\n", "PRINT_ARRAY_STRINGS_SORTED_ORDER_WITHOUT_COPYING_ONE_STRING_ANOTHER": "void printInSortedOrder ( string arr [ ], int n ) {\n  int index [ n ];\n  int i, j, min;\n  for ( i = 0;\n  i < n;\n  i ++ ) index [ i ] = i;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) {\n    min = i;\n    for ( j = i + 1;\n    j < n;\n    j ++ ) {\n      if ( arr [ index [ min ] ] . compare ( arr [ index [ j ] ] ) > 0 ) min = j;\n    }\n    if ( min != i ) {\n      int temp = index [ min ];\n      index [ min ] = index [ i ];\n      index [ i ] = temp;\n    }\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) cout << arr [ index [ i ] ] << \" \";\n}\n", "GAME_REPLACING_ARRAY_ELEMENTS": "int playGame ( int arr [ ], int n ) {\n  unordered_set < int > hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hash . insert ( arr [ i ] );\n  return ( hash . size ( ) % 2 == 0 ? 1 : 2 );\n}\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS": "int gcd ( int a, int b ) {\n  if ( a == 0 ) return b;\n  return gcd ( b % a, a );\n}\n", "SORT_ARRAY_WAVE_FORM_2_1": "void sortInWave ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i += 2 ) {\n    if ( i > 0 && arr [ i - 1 ] > arr [ i ] ) swap ( & arr [ i ], & arr [ i - 1 ] );\n    if ( i < n - 1 && arr [ i ] < arr [ i + 1 ] ) swap ( & arr [ i ], & arr [ i + 1 ] );\n  }\n}\n", "MAXIMUM_SUBARRAY_SUM_USING_PREFIX_SUM": "int maximumSumSubarray ( int arr [ ], int n ) {\n  int min_prefix_sum = 0;\n  int res = numeric_limits < int > :: min ( );\n  int prefix_sum [ n ];\n  prefix_sum [ 0 ] = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) prefix_sum [ i ] = prefix_sum [ i - 1 ] + arr [ i ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    res = max ( res, prefix_sum [ i ] - min_prefix_sum );\n    min_prefix_sum = min ( min_prefix_sum, prefix_sum [ i ] );\n  }\n  return res;\n}\n", "STRING_CONTAINING_FIRST_LETTER_EVERY_WORD_GIVEN_STRING_SPACES": "string firstLetterWord ( string str ) {\n  string result = \"\";\n  bool v = true;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    if ( str [ i ] == ' ' ) v = true;\n    else if ( str [ i ] != ' ' && v == true ) {\n      result . push_back ( str [ i ] );\n      v = false;\n    }\n  }\n  return result;\n}\n", "SUM_PAIRWISE_PRODUCTS_1": "long long int findSum ( int n ) {\n  long long int multiTerms = n * ( n + 1 ) / 2;\n  long long int sum = multiTerms;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    multiTerms = multiTerms - ( i - 1 );\n    sum = sum + multiTerms * i;\n  }\n  return sum;\n}\n", "CLUSTERINGPARTITIONING_AN_ARRAY_SUCH_THAT_SUM_OF_SQUARE_DIFFERENCES_IS_MINIMUM_1": "int minCost ( int a [ ], int n, int k ) {\n  int dp [ n + 1 ] [ k + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) for ( int j = 0;\n  j <= k;\n  j ++ ) dp [ i ] [ j ] = inf;\n  dp [ 0 ] [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= k;\n  j ++ ) for ( int m = i - 1;\n  m >= 0;\n  m -- ) 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}\n", "LEIBNIZ_HARMONIC_TRIANGLE": "void LeibnizHarmonicTriangle ( int n ) {\n  int C [ n + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= min ( i, n );\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ];\n    }\n  }\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= i;\n    j ++ ) cout << \"1/\" << i * C [ i - 1 ] [ j - 1 ] << \" \";\n    cout << endl;\n  }\n}\n", "CHECK_WHETHER_SECOND_STRING_CAN_FORMED_FIRST_STRING_USING_COUNT_ARRAY": "bool canMakeStr2 ( string str1, string str2 ) {\n  int count [ MAX ] = {\n    0 };\n    for ( int i = 0;\n    i < str1 . length ( );\n    i ++ ) count [ str1 [ i ] ] ++;\n    for ( int i = 0;\n    i < str2 . length ( );\n    i ++ ) {\n      if ( count [ str2 [ i ] ] == 0 ) return false;\n      count [ str2 [ i ] ] --;\n    }\n    return true;\n  }\n  ", "SUM_MINIMUM_MAXIMUM_ELEMENTS_SUBARRAYS_SIZE_K": "int SumOfKsubArray ( int arr [ ], int n, int k ) {\n  int sum = 0;\n  deque < int > S ( k ), G ( k );\n  int i = 0;\n  for ( i = 0;\n  i < k;\n  i ++ ) {\n    while ( ( ! S . empty ( ) ) && arr [ S . back ( ) ] >= arr [ i ] ) S . pop_back ( );\n    while ( ( ! G . empty ( ) ) && arr [ G . back ( ) ] <= arr [ i ] ) G . pop_back ( );\n    G . push_back ( i );\n    S . push_back ( i );\n  }\n  for (;\n  i < n;\n  i ++ ) {\n    sum += arr [ S . front ( ) ] + arr [ G . front ( ) ];\n    while ( ! S . empty ( ) && S . front ( ) <= i - k ) S . pop_front ( );\n    while ( ! G . empty ( ) && G . front ( ) <= i - k ) G . pop_front ( );\n    while ( ( ! S . empty ( ) ) && arr [ S . back ( ) ] >= arr [ i ] ) S . pop_back ( );\n    while ( ( ! G . empty ( ) ) && arr [ G . back ( ) ] <= arr [ i ] ) G . pop_back ( );\n    G . push_back ( i );\n    S . push_back ( i );\n  }\n  sum += arr [ S . front ( ) ] + arr [ G . front ( ) ];\n  return sum;\n}\n", "LONGEST_COMMON_SUBSEQUENCE": "int lcs ( char * X, char * Y, int m, int n ) {\n  if ( m == 0 || n == 0 ) return 0;\n  if ( X [ m - 1 ] == Y [ n - 1 ] ) return 1 + lcs ( X, Y, m - 1, n - 1 );\n  else return max ( lcs ( X, Y, m, n - 1 ), lcs ( X, Y, m - 1, n ) );\n}\n", "MINIMUM_SUM_ABSOLUTE_DIFFERENCE_PAIRS_TWO_ARRAYS": "long long int findMinSum ( int a [ ], int b [ ], int n ) {\n  sort ( a, a + n );\n  sort ( b, b + n );\n  long long int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum = sum + abs ( a [ i ] - b [ i ] );\n  return sum;\n}\n", "COUNT_DISTINCT_NON_NEGATIVE_PAIRS_X_Y_SATISFY_INEQUALITY_XX_YY_N_2": "int countSolutions ( int n ) {\n  int res = 0;\n  for ( int x = 0;\n  x * x < n;\n  x ++ ) for ( int y = 0;\n  x * x + y * y < n;\n  y ++ ) res ++;\n  return res;\n}\n", "FIND_NUMBER_TRANSFORMATION_MAKE_TWO_MATRIX_EQUAL": "int countOps ( int A [ ] [ MAX ], int B [ ] [ MAX ], int m, int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) A [ i ] [ j ] -= B [ i ] [ j ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) for ( int j = 1;\n  j < m;\n  j ++ ) if ( A [ i ] [ j ] - A [ i ] [ 0 ] - A [ 0 ] [ j ] + A [ 0 ] [ 0 ] != 0 ) return - 1;\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) result += abs ( A [ i ] [ 0 ] );\n  for ( int j = 0;\n  j < m;\n  j ++ ) result += abs ( A [ 0 ] [ j ] - A [ 0 ] [ 0 ] );\n  return ( result );\n}\n", "EFFICIENTLY_FIND_FIRST_REPEATED_CHARACTER_STRING_WITHOUT_USING_ADDITIONAL_DATA_STRUCTURE_ONE_TRAVERSAL": "int FirstRepeated ( string str ) {\n  int checker = 0;\n  for ( int i = 0;\n  i < str . length ( );\n  ++ i ) {\n    int val = ( str [ i ] - 'a' );\n    if ( ( checker & ( 1 << val ) ) > 0 ) return i;\n    checker |= ( 1 << val );\n  }\n  return - 1;\n}\n", "MAXIMUM_UNIQUE_ELEMENT_EVERY_SUBARRAY_SIZE_K": "void find_max ( int A [ ], int N, int K ) {\n  map < int, int > Count;\n  for ( int i = 0;\n  i < K - 1;\n  i ++ ) Count [ A [ i ] ] ++;\n  set < int > Myset;\n  for ( auto x : Count ) if ( x . second == 1 ) Myset . insert ( x . first );\n  for ( int i = K - 1;\n  i < N;\n  i ++ ) {\n    Count [ A [ i ] ] ++;\n    if ( Count [ A [ i ] ] == 1 ) Myset . insert ( A [ i ] );\n    else Myset . erase ( A [ i ] );\n    if ( Myset . size ( ) == 0 ) printf ( \"Nothing\\n\" );\n    else printf ( \"%d\\n\", * Myset . rbegin ( ) );\n    int x = A [ i - K + 1 ];\n    Count [ x ] --;\n    if ( Count [ x ] == 1 ) Myset . insert ( x );\n    if ( Count [ x ] == 0 ) Myset . erase ( x );\n  }\n}\n", "MINIMUM_COST_SORT_MATRIX_NUMBERS_0_N2_1": "int calculateEnergy ( int mat [ SIZE ] [ SIZE ], int n ) {\n  int i_des, j_des, q;\n  int tot_energy = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\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    }\n  }\n  return tot_energy;\n}\n", "LONGEST_COMMON_SUBSTRING": "int LCSubStr ( char * X, char * Y, int m, int n ) {\n  int LCSuff [ m + 1 ] [ n + 1 ];\n  int result = 0;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( i == 0 || j == 0 ) LCSuff [ i ] [ j ] = 0;\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) {\n        LCSuff [ i ] [ j ] = LCSuff [ i - 1 ] [ j - 1 ] + 1;\n        result = max ( result, LCSuff [ i ] [ j ] );\n      }\n      else LCSuff [ i ] [ j ] = 0;\n    }\n  }\n  return result;\n}\n", "MAXIMUM_SUM_BITONIC_SUBARRAY": "int maxSumBitonicSubArr ( int arr [ ], int n ) {\n  int msis [ n ], msds [ n ];\n  int max_sum = INT_MIN;\n  msis [ 0 ] = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( arr [ i ] > arr [ i - 1 ] ) msis [ i ] = msis [ i - 1 ] + arr [ i ];\n  else msis [ i ] = arr [ i ];\n  msds [ n - 1 ] = arr [ n - 1 ];\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) if ( arr [ i ] > arr [ i + 1 ] ) msds [ i ] = msds [ i + 1 ] + arr [ i ];\n  else msds [ i ] = arr [ i ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( max_sum < ( msis [ i ] + msds [ i ] - arr [ i ] ) ) max_sum = msis [ i ] + msds [ i ] - arr [ i ];\n  return max_sum;\n}\n", "NEWMAN_CONWAY_SEQUENCE": "int sequence ( int n ) {\n  if ( n == 1 || n == 2 ) return 1;\n  else return sequence ( sequence ( n - 1 ) ) + sequence ( n - sequence ( n - 1 ) );\n}\n", "PRINT_TRIPLETS_SORTED_ARRAY_FORM_AP": "void printAllAPTriplets ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int diff = arr [ j ] - arr [ i ];\n      if ( s . find ( arr [ i ] - diff ) != s . end ( ) ) cout << arr [ i ] - diff << \" \" << arr [ i ] << \" \" << arr [ j ] << endl;\n    }\n    s . insert ( arr [ i ] );\n  }\n}\n", "QUERIES_COUNTS_ARRAY_ELEMENTS_VALUES_GIVEN_RANGE": "int countInRange ( int arr [ ], int n, int x, int y ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] >= x && arr [ i ] <= y ) count ++;\n  }\n  return count;\n}\n", "HIGHWAY_BILLBOARD_PROBLEM": "int maxRevenue ( int m, int x [ ], int revenue [ ], int n, int t ) {\n  int maxRev [ m + 1 ];\n  memset ( maxRev, 0, sizeof ( maxRev ) );\n  int nxtbb = 0;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    if ( nxtbb < n ) {\n      if ( x [ nxtbb ] != i ) maxRev [ i ] = maxRev [ i - 1 ];\n      else {\n        if ( i <= t ) maxRev [ i ] = max ( maxRev [ i - 1 ], revenue [ nxtbb ] );\n        else maxRev [ i ] = max ( maxRev [ i - t - 1 ] + revenue [ nxtbb ], maxRev [ i - 1 ] );\n        nxtbb ++;\n      }\n    }\n    else maxRev [ i ] = maxRev [ i - 1 ];\n  }\n  return maxRev [ m ];\n}\n", "CONSTRUCT_GRAPH_GIVEN_DEGREES_VERTICES": "void printMat ( int degseq [ ], int n ) {\n  int mat [ n ] [ n ];\n  memset ( mat, 0, sizeof ( mat ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      if ( degseq [ i ] > 0 && degseq [ j ] > 0 ) {\n        degseq [ i ] --;\n        degseq [ j ] --;\n        mat [ i ] [ j ] = 1;\n        mat [ j ] [ i ] = 1;\n      }\n    }\n  }\n  cout << \"\\n\" << setw ( 3 ) << \"     \";\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << setw ( 3 ) << \"(\" << i << \")\";\n  cout << \"\\n\\n\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cout << setw ( 4 ) << \"(\" << i << \")\";\n    for ( int j = 0;\n    j < n;\n    j ++ ) cout << setw ( 5 ) << mat [ i ] [ j ];\n    cout << \"\\n\";\n  }\n}\n", "DETECT_IF_TWO_INTEGERS_HAVE_OPPOSITE_SIGNS": "bool oppositeSigns ( int x, int y ) {\n  return ( ( x ^ y ) < 0 );\n}\n", "TRIANGULAR_NUMBERS_1": "bool isTriangular ( int num ) {\n  if ( num < 0 ) return false;\n  int c = ( - 2 * num );\n  int b = 1, a = 1;\n  int d = ( b * b ) - ( 4 * a * c );\n  if ( d < 0 ) return false;\n  float root1 = ( - b + sqrt ( d ) ) / ( 2 * a );\n  float root2 = ( - b - sqrt ( d ) ) / ( 2 * a );\n  if ( root1 > 0 && floor ( root1 ) == root1 ) return true;\n  if ( root2 > 0 && floor ( root2 ) == root2 ) return true;\n  return false;\n}\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT": "public : bool isPowerOfFour ( int n ) {\n  if ( n == 0 ) return 0;\n  while ( n != 1 ) {\n    if ( n % 4 != 0 ) return 0;\n    n = n / 4;\n  }\n  return 1;\n}\n", "LAST_NON_ZERO_DIGIT_FACTORIAL": "int lastNon0Digit ( int n ) {\n  if ( n < 10 ) return dig [ n ];\n  if ( ( ( n / 10 ) % 10 ) % 2 == 0 ) return ( 6 * lastNon0Digit ( n / 5 ) * dig [ n % 10 ] ) % 10;\n  else return ( 4 * lastNon0Digit ( n / 5 ) * dig [ n % 10 ] ) % 10;\n}\n", "SORT_STRING_ACCORDING_ORDER_DEFINED_ANOTHER_STRING": "void sortByPattern ( string & str, string pat ) {\n  int count [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < str . length ( );\n    i ++ ) count [ str [ i ] - 'a' ] ++;\n    int index = 0;\n    for ( int i = 0;\n    i < pat . length ( );\n    i ++ ) for ( int j = 0;\n    j < count [ pat [ i ] - 'a' ];\n    j ++ ) str [ index ++ ] = pat [ i ];\n  }\n  ", "NUMBER_VISIBLE_BOXES_PUTTING_ONE_INSIDE_ANOTHER": "int minimumBox ( int arr [ ], int n ) {\n  queue < int > q;\n  sort ( arr, arr + n );\n  q . push ( arr [ 0 ] );\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int now = q . front ( );\n    if ( arr [ i ] >= 2 * now ) q . pop ( );\n    q . push ( arr [ i ] );\n  }\n  return q . size ( );\n}\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY": "int binarySearch ( int arr [ ], int low, int high, int key ) {\n  if ( high < low ) return - 1;\n  int mid = ( low + high ) / 2;\n  if ( key == arr [ mid ] ) return mid;\n  if ( key > arr [ mid ] ) return binarySearch ( arr, ( mid + 1 ), high, key );\n  return binarySearch ( arr, low, ( mid - 1 ), key );\n}\n", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_3": "void printRepeating ( int arr [ ], int size ) {\n  int i;\n  cout << \"The repeating elements are\";\n  for ( i = 0;\n  i < size;\n  i ++ ) {\n    if ( arr [ abs ( arr [ i ] ) ] > 0 ) arr [ abs ( arr [ i ] ) ] = - arr [ abs ( arr [ i ] ) ];\n    else cout << \" \" << abs ( arr [ i ] ) << \" \";\n  }\n}\n", "COUNT_POSSIBLE_GROUPS_SIZE_2_3_SUM_MULTIPLE_3": "int findgroups ( int arr [ ], int n ) {\n  int c [ 3 ] = {\n    0 },\n    i;\n    int res = 0;\n    for ( i = 0;\n    i < n;\n    i ++ ) c [ arr [ i ] % 3 ] ++;\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  }\n  ", "PRINT_STRING_IGNORING_ALTERNATE_OCCURRENCES_CHARACTER": "void printStringAlternate ( string str ) {\n  unordered_map < char, int > occ;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    char temp = tolower ( str [ i ] );\n    occ [ temp ] ++;\n    if ( occ [ temp ] & 1 ) cout << str [ i ];\n  }\n  cout << endl;\n}\n", "NUMBER_DAYS_TANK_WILL_BECOME_EMPTY": "int minDaysToEmpty ( int C, int l ) {\n  if ( l >= C ) return C;\n  double eq_root = ( std :: sqrt ( 1 + 8 * ( C - l ) ) - 1 ) / 2;\n  return std :: ceil ( eq_root ) + l;\n}\n", "REVERSE_STRING_WITHOUT_USING_ANY_TEMPORARY_VARIABLE": "string reversingString ( string str, int start, int end ) {\n  while ( start < end ) {\n    str [ start ] ^= str [ end ];\n    str [ end ] ^= str [ start ];\n    str [ start ] ^= str [ end ];\n    ++ start;\n    -- end;\n  }\n  return str;\n}\n", "FREQUENCY_ELEMENT_UNSORTED_ARRAY": "void countFreq ( int a [ ], int n ) {\n  unordered_map < int, int > hm;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hm [ a [ i ] ] ++;\n  set < pair < int, int > > st;\n  for ( auto x : hm ) {\n    st . insert ( {\n      x . first, x . second }\n      );\n    }\n    int cumul = 0;\n    for ( auto x : st ) {\n      cumul += x . second;\n      cout << x . first << \" \" << cumul << endl;\n    }\n  }\n  ", "FIND_ROTATION_COUNT_ROTATED_SORTED_ARRAY": "int countRotations ( int arr [ ], int n ) {\n  int min = arr [ 0 ], min_index;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( min > arr [ i ] ) {\n      min = arr [ i ];\n      min_index = i;\n    }\n  }\n  return min_index;\n}\n", "LONGEST_INCREASING_SUBSEQUENCE_1": "int lis ( int arr [ ], int n ) {\n  int lis [ n ];\n  lis [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    lis [ i ] = 1;\n    for ( int j = 0;\n    j < i;\n    j ++ ) if ( arr [ i ] > arr [ j ] && lis [ i ] < lis [ j ] + 1 ) lis [ i ] = lis [ j ] + 1;\n  }\n  return * max_element ( lis, lis + n );\n}\n", "MEDIAN_OF_TWO_SORTED_ARRAYS": "int getMedian ( int ar1 [ ], int ar2 [ ], int n ) {\n  int i = 0;\n  int j = 0;\n  int count;\n  int m1 = - 1, m2 = - 1;\n  for ( count = 0;\n  count <= n;\n  count ++ ) {\n    if ( i == n ) {\n      m1 = m2;\n      m2 = ar2 [ 0 ];\n      break;\n    }\n    else if ( j == n ) {\n      m1 = m2;\n      m2 = ar1 [ 0 ];\n      break;\n    }\n    if ( ar1 [ i ] < ar2 [ j ] ) {\n      m1 = m2;\n      m2 = ar1 [ i ];\n      i ++;\n    }\n    else {\n      m1 = m2;\n      m2 = ar2 [ j ];\n      j ++;\n    }\n  }\n  return ( m1 + m2 ) / 2;\n}\n", "LEXICOGRAPHICALLY_MINIMUM_STRING_ROTATION": "string minLexRotation ( string str ) {\n  int n = str . length ( );\n  string arr [ n ];\n  string concat = str + str;\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = concat . substr ( i, n );\n  sort ( arr, arr + n );\n  return arr [ 0 ];\n}\n", "INTERPOLATION_SEARCH": "int interpolationSearch ( int arr [ ], int n, int x ) {\n  int lo = 0, hi = ( n - 1 );\n  while ( lo <= hi && x >= arr [ lo ] && x <= arr [ hi ] ) {\n    if ( lo == hi ) {\n      if ( arr [ lo ] == x ) return lo;\n      return - 1;\n    }\n    int pos = lo + ( ( ( double ) ( hi - lo ) / ( arr [ hi ] - arr [ lo ] ) ) * ( x - arr [ lo ] ) );\n    if ( arr [ pos ] == x ) return pos;\n    if ( arr [ pos ] < x ) lo = pos + 1;\n    else hi = pos - 1;\n  }\n  return - 1;\n}\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X_2": "int countPairs ( int arr1 [ ], int arr2 [ ], int m, int n, int x ) {\n  int count = 0;\n  int l = 0, r = n - 1;\n  while ( l < m && r >= 0 ) {\n    if ( ( arr1 [ l ] + arr2 [ r ] ) == x ) {\n      l ++;\n      r --;\n      count ++;\n    }\n    else if ( ( arr1 [ l ] + arr2 [ r ] ) < x ) l ++;\n    else r --;\n  }\n  return count;\n}\n", "COUNT_SUBSETS_DISTINCT_EVEN_NUMBERS": "int countSubsets ( int arr [ ], int n ) {\n  unordered_set < int > us;\n  int even_count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] % 2 == 0 ) us . insert ( arr [ i ] );\n  unordered_set < int > :: iterator itr;\n  for ( itr = us . begin ( );\n  itr != us . end ( );\n  itr ++ ) even_count ++;\n  return ( pow ( 2, even_count ) - 1 );\n}\n", "COUNT_NUMBER_OF_OCCURRENCES_OR_FREQUENCY_IN_A_SORTED_ARRAY": "int countOccurrences ( int arr [ ], int n, int x ) {\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( x == arr [ i ] ) res ++;\n  return res;\n}\n", "CONSTRUCT_THE_ROOTED_TREE_BY_USING_START_AND_FINISH_TIME_OF_ITS_DFS_TRAVERSAL": "vector < int > Restore_Tree ( int Start [ ], int End [ ] ) {\n  vector < int > Identity ( N, 0 );\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    Identity [ Start [ i ] ] = i;\n  }\n  vector < int > parent ( N, - 1 );\n  int curr_parent = Identity [ 0 ];\n  for ( int j = 1;\n  j < N;\n  j ++ ) {\n    int child = Identity [ j ];\n    if ( End [ child ] - j > 1 ) {\n      parent [ child ] = curr_parent;\n      curr_parent = child;\n    }\n    else 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 ] ) break;\n    }\n  }\n  for ( int i = 0;\n  i < N;\n  i ++ ) parent [ i ] += 1;\n  return parent;\n}\n", "NUMBER_SUBSEQUENCES_AB_STRING_REPEATED_K_TIMES": "int countOccurrences ( string s, int K ) {\n  int n = s . length ( );\n  int C, c1 = 0, c2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s [ i ] == 'a' ) c1 ++;\n    if ( s [ i ] == 'b' ) {\n      c2 ++;\n      C += c1;\n    }\n  }\n  return C * K + ( K * ( K - 1 ) / 2 ) * c1 * c2;\n}\n", "NUMBER_SUBSTRINGS_STRING": "int countNonEmptySubstr ( string str ) {\n  int n = str . length ( );\n  return n * ( n + 1 ) / 2;\n}\n", "MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING_1": "int maximumChars ( string & str ) {\n  int n = str . length ( );\n  int res = - 1;\n  int firstInd [ MAX_CHAR ];\n  for ( int i = 0;\n  i < MAX_CHAR;\n  i ++ ) firstInd [ i ] = - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int first_ind = firstInd [ str [ i ] ];\n    if ( first_ind == - 1 ) firstInd [ str [ i ] ] = i;\n    else res = max ( res, abs ( i - first_ind - 1 ) );\n  }\n  return res;\n}\n", "SUM_SQUARES_BINOMIAL_COEFFICIENTS": "int sumofsquare ( int n ) {\n  int C [ n + 1 ] [ n + 1 ];\n  int i, j;\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( j = 0;\n    j <= min ( i, n );\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ];\n    }\n  }\n  int sum = 0;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) sum += ( C [ n ] [ i ] * C [ n ] [ i ] );\n  return sum;\n}\n", "PRINT_POSSIBLE_STRINGS_CAN_MADE_PLACING_SPACES_2": "void printSubsequences ( string str ) {\n  int n = str . length ( );\n  unsigned int opsize = pow ( 2, n - 1 );\n  for ( int counter = 0;\n  counter < opsize;\n  counter ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      cout << str [ j ];\n      if ( counter & ( 1 << j ) ) cout << \" \";\n    }\n    cout << endl;\n  }\n}\n", "NON_REPEATING_ELEMENT": "int firstNonRepeating ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < n;\n    j ++ ) if ( i != j && arr [ i ] == arr [ j ] ) break;\n    if ( j == n ) return arr [ i ];\n  }\n  return - 1;\n}\n", "SUM_OF_ALL_ELEMENTS_UP_TO_NTH_ROW_IN_A_PASCALS_TRIANGLE": "long long int calculateSum ( int n ) {\n  long long int sum = 0;\n  for ( int row = 0;\n  row < n;\n  row ++ ) {\n    sum = sum + ( 1 << row );\n  }\n  return sum;\n}\n", "CHECK_TWO_STRINGS_K_ANAGRAMS_NOT": "bool arekAnagrams ( string str1, string str2, int k ) {\n  int n = str1 . length ( );\n  if ( str2 . length ( ) != n ) return false;\n  int count1 [ MAX_CHAR ] = {\n    0 };\n    int count2 [ MAX_CHAR ] = {\n      0 };\n      for ( int i = 0;\n      i < n;\n      i ++ ) count1 [ str1 [ i ] - 'a' ] ++;\n      for ( int i = 0;\n      i < n;\n      i ++ ) count2 [ str2 [ i ] - 'a' ] ++;\n      int count = 0;\n      for ( int i = 0;\n      i < MAX_CHAR;\n      i ++ ) if ( count1 [ i ] > count2 [ i ] ) count = count + abs ( count1 [ i ] - count2 [ i ] );\n      return ( count <= k );\n    }\n    ", "LONGEST_SPAN_SUM_TWO_BINARY_ARRAYS": "int longestCommonSum ( bool arr1 [ ], bool arr2 [ ], int n ) {\n  int maxLen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int sum1 = 0, sum2 = 0;\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      sum1 += arr1 [ j ];\n      sum2 += arr2 [ j ];\n      if ( sum1 == sum2 ) {\n        int len = j - i + 1;\n        if ( len > maxLen ) maxLen = len;\n      }\n    }\n  }\n  return maxLen;\n}\n", "REMAINDER_7_LARGE_NUMBERS": "int remainderWith7 ( string num ) {\n  int series [ ] = {\n    1, 3, 2, - 1, - 3, - 2 };\n    int series_index = 0;\n    int result = 0;\n    for ( int i = num . size ( ) - 1;\n    i >= 0;\n    i -- ) {\n      int digit = num [ i ] - '0';\n      result += digit * series [ series_index ];\n      series_index = ( series_index + 1 ) % 6;\n      result %= 7;\n    }\n    if ( result < 0 ) result = ( result + 7 ) % 7;\n    return result;\n  }\n  ", "LEXICOGRAPHICALLY_PREVIOUS_PERMUTATION_IN_C": "bool prevPermutation ( string & str ) {\n  int n = str . length ( ) - 1;\n  int i = n;\n  while ( i > 0 && str [ i - 1 ] <= str [ i ] ) i --;\n  if ( i <= 0 ) return false;\n  int j = i - 1;\n  while ( j + 1 <= n && str [ j + 1 ] <= str [ i - 1 ] ) j ++;\n  swap ( str [ i - 1 ], str [ j ] );\n  reverse ( str . begin ( ) + i, str . end ( ) );\n  return true;\n}\n", "NUMBER_SUBSEQUENCES_FORM_AI_BJ_CK": "int countSubsequences ( string s ) {\n  int aCount = 0;\n  int bCount = 0;\n  int cCount = 0;\n  for ( unsigned int i = 0;\n  i < s . size ( );\n  i ++ ) {\n    if ( s [ i ] == 'a' ) aCount = ( 1 + 2 * aCount );\n    else if ( s [ i ] == 'b' ) bCount = ( aCount + 2 * bCount );\n    else if ( s [ i ] == 'c' ) cCount = ( bCount + 2 * cCount );\n  }\n  return cCount;\n}\n", "PROGRAM_PRINT_IDENTITY_MATRIX_1": "bool isIdentity ( int mat [ ] [ MAX ], int N ) {\n  for ( int row = 0;\n  row < N;\n  row ++ ) {\n    for ( int col = 0;\n    col < N;\n    col ++ ) {\n      if ( row == col && mat [ row ] [ col ] != 1 ) return false;\n      else if ( row != col && mat [ row ] [ col ] != 0 ) return false;\n    }\n  }\n  return true;\n}\n", "MAXIMUM_POSSIBLE_DIFFERENCE_TWO_SUBSETS_ARRAY_1": "int maxDiff ( int arr [ ], int n ) {\n  int result = 0;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( arr [ i ] != arr [ i + 1 ] ) result += abs ( arr [ i ] );\n    else i ++;\n  }\n  if ( arr [ n - 2 ] != arr [ n - 1 ] ) result += abs ( arr [ n - 1 ] );\n  return result;\n}\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM": "int summingSeries ( long n ) {\n  int S = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) S += i * i - ( i - 1 ) * ( i - 1 );\n  return S;\n}\n", "PREFIX_SUM_2D_ARRAY": "void prefixSum2D ( int a [ ] [ C ] ) {\n  int psa [ R ] [ C ];\n  psa [ 0 ] [ 0 ] = a [ 0 ] [ 0 ];\n  for ( int i = 1;\n  i < C;\n  i ++ ) psa [ 0 ] [ i ] = psa [ 0 ] [ i - 1 ] + a [ 0 ] [ i ];\n  for ( int i = 0;\n  i < R;\n  i ++ ) psa [ i ] [ 0 ] = psa [ i - 1 ] [ 0 ] + a [ i ] [ 0 ];\n  for ( int i = 1;\n  i < R;\n  i ++ ) {\n    for ( int j = 1;\n    j < C;\n    j ++ ) psa [ i ] [ j ] = psa [ i - 1 ] [ j ] + psa [ i ] [ j - 1 ] - psa [ i - 1 ] [ j - 1 ] + a [ i ] [ j ];\n  }\n  for ( int i = 0;\n  i < R;\n  i ++ ) {\n    for ( int j = 0;\n    j < C;\n    j ++ ) cout << psa [ i ] [ j ] << \" \";\n    cout << \"\\n\";\n  }\n}\n", "MAXIMUM_NUMBER_2X2_SQUARES_CAN_FIT_INSIDE_RIGHT_ISOSCELES_TRIANGLE": "int numberOfSquares ( int base ) {\n  base = ( base - 2 );\n  base = base / 2;\n  return base * ( base + 1 ) / 2;\n}\n", "GIVEN_BINARY_STRING_COUNT_NUMBER_SUBSTRINGS_START_END_1_1": "int countSubStr ( char str [ ] ) {\n  int m = 0;\n  for ( int i = 0;\n  str [ i ] != '\\0';\n  i ++ ) {\n    if ( str [ i ] == '1' ) m ++;\n  }\n  return m * ( m - 1 ) / 2;\n}\n", "CONVERTING_ONE_STRING_USING_APPEND_DELETE_LAST_OPERATIONS": "bool isConvertible ( string str1, string str2, int k ) {\n  if ( ( str1 . length ( ) + str2 . length ( ) ) < k ) return true;\n  int commonLength = 0;\n  for ( int i = 0;\n  i < min ( str1 . length ( ), str2 . length ( ) );\n  i ++ ) {\n    if ( str1 [ i ] == str2 [ i ] ) commonLength ++;\n    else break;\n  }\n  if ( ( k - str1 . length ( ) - str2 . length ( ) + 2 * commonLength ) % 2 == 0 ) return true;\n  return false;\n}\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES_2": "int getOddOccurrence ( int ar [ ], int ar_size ) {\n  int res = 0;\n  for ( int i = 0;\n  i < ar_size;\n  i ++ ) res = res ^ ar [ i ];\n  return res;\n}\n", "SUM_MIDDLE_ROW_COLUMN_MATRIX": "void middlesum ( int mat [ ] [ MAX ], int n ) {\n  int row_sum = 0, col_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) row_sum += mat [ n / 2 ] [ i ];\n  cout << \"Sum of middle row = \" << row_sum << endl;\n  for ( int i = 0;\n  i < n;\n  i ++ ) col_sum += mat [ i ] [ n / 2 ];\n  cout << \"Sum of middle column = \" << col_sum;\n}\n", "K_TH_DISTINCT_OR_NON_REPEATING_ELEMENT_IN_AN_ARRAY": "int printKDistinct ( int arr [ ], int n, int k ) {\n  int dist_count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < n;\n    j ++ ) if ( i != j && arr [ j ] == arr [ i ] ) break;\n    if ( j == n ) dist_count ++;\n    if ( dist_count == k ) return arr [ i ];\n  }\n  return - 1;\n}\n", "MERGING_INTERVALS": "void mergeIntervals ( Interval arr [ ], int n ) {\n  sort ( arr, arr + n, mycomp );\n  int index = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( arr [ index ] . e >= arr [ i ] . s ) {\n      arr [ index ] . e = max ( arr [ index ] . e, arr [ i ] . e );\n      arr [ index ] . s = min ( arr [ index ] . s, arr [ i ] . s );\n    }\n    else {\n      arr [ index ] = arr [ i ];\n      index ++;\n    }\n  }\n  cout << \"\\n The Merged Intervals are: \";\n  for ( int i = 0;\n  i <= index;\n  i ++ ) cout << \"[\" << arr [ i ] . s << \", \" << arr [ i ] . e << \"] \";\n}\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS_1": "int countSquares ( int a, int b ) {\n  return ( floor ( sqrt ( b ) ) - ceil ( sqrt ( a ) ) + 1 );\n}\n", "LARGEST_SUBSET_WHOSE_ALL_ELEMENTS_ARE_FIBONACCI_NUMBERS": "void findFibSubset ( int arr [ ], int n ) {\n  int max = * std :: max_element ( arr, arr + n );\n  int a = 0, b = 1;\n  unordered_set < int > hash;\n  hash . insert ( a );\n  hash . insert ( b );\n  while ( b < max ) {\n    int c = a + b;\n    a = b;\n    b = c;\n    hash . insert ( b );\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( hash . find ( arr [ i ] ) != hash . end ( ) ) printf ( \"%d \", arr [ i ] );\n}\n", "LEXICOGRAPHICAL_CONCATENATION_SUBSTRINGS_STRING": "string lexicographicSubConcat ( string s ) {\n  int n = s . length ( );\n  int sub_count = n * ( n + 1 ) / 2;\n  string arr [ sub_count ];\n  int index = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int len = 1;\n  len <= n - i;\n  len ++ ) arr [ index ++ ] = s . substr ( i, len );\n  sort ( arr, arr + sub_count );\n  string res = \"\";\n  for ( int i = 0;\n  i < sub_count;\n  i ++ ) res += arr [ i ];\n  return res;\n}\n", "COUNT_OPERATIONS_MAKE_STRINGAB_FREE": "int abFree ( string s ) {\n  int n = s . length ( );\n  char char_array [ n + 1 ];\n  strcpy ( char_array, s . c_str ( ) );\n  int b_count = 0;\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( char_array [ n - i - 1 ] == 'a' ) {\n      res = ( res + b_count );\n      b_count = ( b_count * 2 );\n    }\n    else {\n      b_count += 1;\n    }\n  }\n  return res;\n}\n", "MAXIMUM_HEIGHT_OF_TRIANGULAR_ARRANGEMENT_OF_ARRAY_VALUES_1": "int MaximumHeight ( int a [ ], int n ) {\n  return floor ( ( - 1 + sqrt ( 1 + ( 8 * n ) ) ) / 2 );\n}\n", "MAXIMIZE_VOLUME_CUBOID_GIVEN_SUM_SIDES": "int maxvolume ( int s ) {\n  int maxvalue = 0;\n  for ( int i = 1;\n  i <= s - 2;\n  i ++ ) {\n    for ( int j = 1;\n    j <= s - 1;\n    j ++ ) {\n      int k = s - i - j;\n      maxvalue = max ( maxvalue, i * j * k );\n    }\n  }\n  return maxvalue;\n}\n", "PROGRAM_DECIMAL_HEXADECIMAL_CONVERSION": "void decToHexa ( int n ) {\n  char hexaDeciNum [ 100 ];\n  int i = 0;\n  while ( n != 0 ) {\n    int temp = 0;\n    temp = n % 16;\n    if ( temp < 10 ) {\n      hexaDeciNum [ i ] = temp + 48;\n      i ++;\n    }\n    else {\n      hexaDeciNum [ i ] = temp + 55;\n      i ++;\n    }\n    n = n / 16;\n  }\n  for ( int j = i - 1;\n  j >= 0;\n  j -- ) cout << hexaDeciNum [ j ];\n}\n", "SMALLEST_SUBARRAY_WITH_ALL_OCCURRENCES_OF_A_MOST_FREQUENT_ELEMENT": "void smallestSubsegment ( int a [ ], int n ) {\n  unordered_map < int, int > left;\n  unordered_map < int, int > count;\n  int mx = 0;\n  int mn, strindex;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int x = a [ i ];\n    if ( count [ x ] == 0 ) {\n      left [ x ] = i;\n      count [ x ] = 1;\n    }\n    else count [ x ] ++;\n    if ( count [ x ] > mx ) {\n      mx = count [ x ];\n      mn = i - left [ x ] + 1;\n      strindex = left [ x ];\n    }\n    else if ( count [ x ] == mx && i - left [ x ] + 1 < mn ) {\n      mn = i - left [ x ] + 1;\n      strindex = left [ x ];\n    }\n  }\n  for ( int i = strindex;\n  i < strindex + mn;\n  i ++ ) cout << a [ i ] << \" \";\n}\n", "FIND_LAST_INDEX_CHARACTER_STRING_1": "int findLastIndex ( string & str, char x ) {\n  for ( int i = str . length ( ) - 1;\n  i >= 0;\n  i -- ) if ( str [ i ] == x ) return i;\n  return - 1;\n}\n", "RECAMANS_SEQUENCE": "int recaman ( int n ) {\n  int arr [ n ];\n  arr [ 0 ] = 0;\n  printf ( \"%d, \", arr [ 0 ] );\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int curr = arr [ i - 1 ] - i;\n    int j;\n    for ( j = 0;\n    j < i;\n    j ++ ) {\n      if ( ( arr [ j ] == curr ) || curr < 0 ) {\n        curr = arr [ i - 1 ] + i;\n        break;\n      }\n    }\n    arr [ i ] = curr;\n    printf ( \"%d, \", arr [ i ] );\n  }\n}\n", "C_PROGRAM_FIND_SECOND_FREQUENT_CHARACTER": "char getSecondMostFreq ( string str ) {\n  int count [ NO_OF_CHARS ] = {\n    0 },\n    i;\n    for ( i = 0;\n    str [ i ];\n    i ++ ) ( count [ str [ i ] ] ) ++;\n    int first = 0, second = 0;\n    for ( i = 0;\n    i < NO_OF_CHARS;\n    i ++ ) {\n      if ( count [ i ] > count [ first ] ) {\n        second = first;\n        first = i;\n      }\n      else if ( count [ i ] > count [ second ] && count [ i ] != count [ first ] ) second = i;\n    }\n    return second;\n  }\n  ", "FIND_MAXIMUM_HEIGHT_PYRAMID_FROM_THE_GIVEN_ARRAY_OF_OBJECTS": "int maxLevel ( int boxes [ ], int n ) {\n  sort ( boxes, boxes + n );\n  int ans = 1;\n  int prev_width = boxes [ 0 ];\n  int prev_count = 1;\n  int curr_count = 0;\n  int curr_width = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    curr_width += boxes [ i ];\n    curr_count += 1;\n    if ( curr_width > prev_width && curr_count > prev_count ) {\n      prev_width = curr_width;\n      prev_count = curr_count;\n      curr_count = 0;\n      curr_width = 0;\n      ans ++;\n    }\n  }\n  return ans;\n}\n", "COUNTING_INVERSIONS": "int getInvCount ( int arr [ ], int n ) {\n  int inv_count = 0;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( arr [ i ] > arr [ j ] ) inv_count ++;\n  return inv_count;\n}\n", "SQUARES_OF_MATRIX_DIAGONAL_ELEMENTS": "void diagonalsquare ( int mat [ ] [ MAX ], int row, int column ) {\n  cout << \"Diagonal one : \";\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    for ( int j = 0;\n    j < column;\n    j ++ ) if ( i == j ) cout << mat [ i ] [ j ] * mat [ i ] [ j ] << \" \";\n  }\n  cout << \" \\n\\nDiagonal two : \";\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    for ( int j = 0;\n    j < column;\n    j ++ ) if ( i + j == column - 1 ) cout << mat [ i ] [ j ] * mat [ i ] [ j ] << \"  \";\n  }\n}\n", "ROW_WISE_COMMON_ELEMENTS_TWO_DIAGONALS_SQUARE_MATRIX": "int countCommon ( int mat [ ] [ MAX ], int n ) {\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( mat [ i ] [ i ] == mat [ i ] [ n - i - 1 ] ) res ++;\n  return res;\n}\n", "EULERIAN_NUMBER": "int eulerian ( int n, int m ) {\n  if ( m >= n || n == 0 ) return 0;\n  if ( m == 0 ) return 1;\n  return ( n - m ) * eulerian ( n - 1, m - 1 ) + ( m + 1 ) * eulerian ( n - 1, m );\n}\n", "EULERS_CRITERION_CHECK_IF_SQUARE_ROOT_UNDER_MODULO_P_EXISTS": "bool squareRootExists ( int n, int p ) {\n  n = n % p;\n  for ( int x = 2;\n  x < p;\n  x ++ ) if ( ( x * x ) % p == n ) return true;\n  return false;\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_3": "int numberOfPaths ( int m, int n ) {\n  int path = 1;\n  for ( int i = n;\n  i < ( m + n - 1 );\n  i ++ ) {\n    path *= i;\n    path /= ( i - n + 1 );\n  }\n  return path;\n}\n", "MODIFY_ARRAY_TO_MAXIMIZE_SUM_OF_ADJACENT_DIFFERENCES": "int maximumDifferenceSum ( int arr [ ], int N ) {\n  int dp [ N ] [ 2 ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) dp [ i ] [ 0 ] = dp [ i ] [ 1 ] = 0;\n  for ( int i = 0;\n  i < ( N - 1 );\n  i ++ ) {\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  }\n  return max ( dp [ N - 1 ] [ 0 ], dp [ N - 1 ] [ 1 ] );\n}\n", "STERN_BROCOT_SEQUENCE": "void SternSequenceFunc ( vector < int > & BrocotSequence, int n ) {\n  for ( int i = 1;\n  BrocotSequence . size ( ) < n;\n  i ++ ) {\n    int considered_element = BrocotSequence [ i ];\n    int precedent = BrocotSequence [ i - 1 ];\n    BrocotSequence . push_back ( considered_element + precedent );\n    BrocotSequence . push_back ( considered_element );\n  }\n  for ( int i = 0;\n  i < 15;\n  ++ i ) cout << BrocotSequence [ i ] << \" \";\n}\n", "NUMBER_SUBSEQUENCES_STRING_DIVISIBLE_N": "int countDivisibleSubseq ( string str, int n ) {\n  int len = str . length ( );\n  int dp [ len ] [ n ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ ( str [ 0 ] - '0' ) % n ] ++;\n  for ( int i = 1;\n  i < len;\n  i ++ ) {\n    dp [ i ] [ ( str [ i ] - '0' ) % n ] ++;\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      dp [ i ] [ j ] += dp [ i - 1 ] [ j ];\n      dp [ i ] [ ( j * 10 + ( str [ i ] - '0' ) ) % n ] += dp [ i - 1 ] [ j ];\n    }\n  }\n  return dp [ len - 1 ] [ 0 ];\n}\n", "HOW_TO_BEGIN_WITH_COMPETITIVE_PROGRAMMING": "int search ( int arr [ ], int n, int x ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == x ) return i;\n  }\n  return - 1;\n}\n", "COUNT_PAIRS_WITH_GIVEN_SUM_1": "int getPairsCount ( int arr [ ], int n, int sum ) {\n  unordered_map < int, int > m;\n  for ( int i = 0;\n  i < n;\n  i ++ ) m [ arr [ i ] ] ++;\n  int twice_count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    twice_count += m [ sum - arr [ i ] ];\n    if ( sum - arr [ i ] == arr [ i ] ) twice_count --;\n  }\n  return twice_count / 2;\n}\n", "FIND_THE_MINIMUM_DISTANCE_BETWEEN_TWO_NUMBERS": "int minDist ( int arr [ ], int n, int x, int y ) {\n  int i, j;\n  int min_dist = INT_MAX;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    for ( j = i + 1;\n    j < n;\n    j ++ ) {\n      if ( ( x == arr [ i ] && y == arr [ j ] || y == arr [ i ] && x == arr [ j ] ) && min_dist > abs ( i - j ) ) {\n        min_dist = abs ( i - j );\n      }\n    }\n  }\n  return min_dist;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_2": "int findRepeating ( int arr [ ], int n ) {\n  int res = 0;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) res = res ^ ( i + 1 ) ^ arr [ i ];\n  res = res ^ arr [ n - 1 ];\n  return res;\n}\n", "SHORTEST_PATH_EXACTLY_K_EDGES_DIRECTED_WEIGHTED_GRAPH_1": "INT_MAX int shortestPath ( int graph [ ] [ V ], int u, int v, int k ) {\n  int sp [ V ] [ V ] [ k + 1 ];\n  for ( int e = 0;\n  e <= k;\n  e ++ ) {\n    for ( int i = 0;\n    i < V;\n    i ++ ) {\n      for ( int j = 0;\n      j < V;\n      j ++ ) {\n        sp [ i ] [ j ] [ e ] = INF;\n        if ( e == 0 && i == j ) sp [ i ] [ j ] [ e ] = 0;\n        if ( e == 1 && graph [ i ] [ j ] != INF ) sp [ i ] [ j ] [ e ] = graph [ i ] [ j ];\n        if ( e > 1 ) {\n          for ( int a = 0;\n          a < V;\n          a ++ ) {\n            if ( graph [ i ] [ a ] != INF && i != a && j != a && sp [ a ] [ j ] [ e - 1 ] != INF ) sp [ i ] [ j ] [ e ] = min ( sp [ i ] [ j ] [ e ], graph [ i ] [ a ] + sp [ a ] [ j ] [ e - 1 ] );\n          }\n        }\n      }\n    }\n  }\n  return sp [ u ] [ v ] [ k ];\n}\n", "LONGEST_SUBARRAY_NOT_K_DISTINCT_ELEMENTS": "void longest ( int a [ ], int n, int k ) {\n  unordered_map < int, int > freq;\n  int start = 0, end = 0, now = 0, l = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    freq [ a [ i ] ] ++;\n    if ( freq [ a [ i ] ] == 1 ) now ++;\n    while ( now > k ) {\n      freq [ a [ l ] ] --;\n      if ( freq [ a [ l ] ] == 0 ) now --;\n      l ++;\n    }\n    if ( i - l + 1 >= end - start + 1 ) end = i, start = l;\n  }\n  for ( int i = start;\n  i <= end;\n  i ++ ) cout << a [ i ] << \" \";\n}\n", "MAXIMUM_XOR_VALUE_MATRIX": "int maxXOR ( int mat [ ] [ MAX ], int N ) {\n  int r_xor, c_xor;\n  int max_xor = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    r_xor = 0, c_xor = 0;\n    for ( int j = 0;\n    j < N;\n    j ++ ) {\n      r_xor = r_xor ^ mat [ i ] [ j ];\n      c_xor = c_xor ^ mat [ j ] [ i ];\n    }\n    if ( max_xor < max ( r_xor, c_xor ) ) max_xor = max ( r_xor, c_xor );\n  }\n  return max_xor;\n}\n", "LENGTH_LONGEST_SUB_STRING_CAN_MAKE_REMOVED": "int longestNull ( string str ) {\n  vector < pair < char, int > > arr;\n  arr . push_back ( {\n    '@', - 1 }\n    );\n    int maxlen = 0;\n    for ( int i = 0;\n    i < str . length ( );\n    ++ i ) {\n      arr . push_back ( {\n        str [ i ], i }\n        );\n        while ( arr . size ( ) >= 3 && arr [ arr . size ( ) - 3 ] . first == '1' && arr [ arr . size ( ) - 2 ] . first == '0' && arr [ arr . size ( ) - 1 ] . first == '0' ) {\n          arr . pop_back ( );\n          arr . pop_back ( );\n          arr . pop_back ( );\n        }\n        int tmp = arr . back ( ) . second;\n        maxlen = max ( maxlen, i - tmp );\n      }\n      return maxlen;\n    }\n    ", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY": "void alternateSubarray ( bool arr [ ], int n ) {\n  int len [ n ];\n  len [ n - 1 ] = 1;\n  for ( int i = n - 2;\n  i >= 0;\n  -- i ) {\n    if ( arr [ i ] ^ arr [ i + 1 ] == 1 ) len [ i ] = len [ i + 1 ] + 1;\n    else len [ i ] = 1;\n  }\n  for ( int i = 0;\n  i < n;\n  ++ i ) cout << len [ i ] << \" \";\n}\n", "WILDCARD_CHARACTER_MATCHING": "bool match ( char * first, char * second ) {\n  if ( * first == '\\0' && * second == '\\0' ) return true;\n  if ( * first == '*' && * ( first + 1 ) != '\\0' && * second == '\\0' ) return false;\n  if ( * first == '?' || * first == * second ) return match ( first + 1, second + 1 );\n  if ( * first == '*' ) return match ( first + 1, second ) || match ( first, second + 1 );\n  return false;\n}\n", "FIND_FACTORIAL_NUMBERS_LESS_EQUAL_N": "void printFactorialNums ( int n ) {\n  int fact = 1;\n  int x = 2;\n  while ( fact <= n ) {\n    cout << fact << \" \";\n    fact = fact * x;\n    x ++;\n  }\n}\n", "FRIENDS_PAIRING_PROBLEM_2": "int countFriendsPairings ( int n ) {\n  int a = 1, b = 2, c = 0;\n  if ( n <= 2 ) {\n    return n;\n  }\n  for ( int i = 3;\n  i <= n;\n  i ++ ) {\n    c = b + ( i - 1 ) * a;\n    a = b;\n    b = c;\n  }\n  return c;\n}\n", "FIND_THE_LARGEST_RECTANGLE_OF_1S_WITH_SWAPPING_OF_COLUMNS_ALLOWED": "int maxArea ( bool mat [ R ] [ C ] ) {\n  int hist [ R + 1 ] [ C + 1 ];\n  for ( int i = 0;\n  i < C;\n  i ++ ) {\n    hist [ 0 ] [ i ] = mat [ 0 ] [ i ];\n    for ( int j = 1;\n    j < R;\n    j ++ ) hist [ j ] [ i ] = ( mat [ j ] [ i ] == 0 ) ? 0 : hist [ j - 1 ] [ i ] + 1;\n  }\n  for ( int i = 0;\n  i < R;\n  i ++ ) {\n    int count [ R + 1 ] = {\n      0 };\n      for ( int j = 0;\n      j < C;\n      j ++ ) count [ hist [ i ] [ j ] ] ++;\n      int col_no = 0;\n      for ( int j = R;\n      j >= 0;\n      j -- ) {\n        if ( count [ j ] > 0 ) {\n          for ( int k = 0;\n          k < count [ j ];\n          k ++ ) {\n            hist [ i ] [ col_no ] = j;\n            col_no ++;\n          }\n        }\n      }\n    }\n    int curr_area, max_area = 0;\n    for ( int i = 0;\n    i < R;\n    i ++ ) {\n      for ( int j = 0;\n      j < C;\n      j ++ ) {\n        curr_area = ( j + 1 ) * hist [ i ] [ j ];\n        if ( curr_area > max_area ) max_area = curr_area;\n      }\n    }\n    return max_area;\n  }\n  ", "SUM_SEQUENCE_2_22_222": "float sumOfSeries ( int n ) {\n  return 0.0246 * ( pow ( 10, n ) - 1 - ( 9 * n ) );\n}\n", "PROGRAM_FIRST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "void firstFit ( int blockSize [ ], int m, int processSize [ ], int n ) {\n  int allocation [ n ];\n  memset ( allocation, - 1, sizeof ( allocation ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( blockSize [ j ] >= processSize [ i ] ) {\n        allocation [ i ] = j;\n        blockSize [ j ] -= processSize [ i ];\n        break;\n      }\n    }\n  }\n  cout << \"\\nProcess No.\\tProcess Size\\tBlock no.\\n\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cout << \" \" << i + 1 << \"\\t\\t\" << processSize [ i ] << \"\\t\\t\";\n    if ( allocation [ i ] != - 1 ) cout << allocation [ i ] + 1;\n    else cout << \"Not Allocated\";\n    cout << endl;\n  }\n}\n", "CHECK_IF_A_NUMBER_IS_POWER_OF_ANOTHER_NUMBER": "bool isPower ( int x, long int y ) {\n  if ( x == 1 ) return ( y == 1 );\n  long int pow = 1;\n  while ( pow < y ) pow *= x;\n  return ( pow == y );\n}\n", "DIVIDE_LARGE_NUMBER_REPRESENTED_STRING": "string longDivision ( string number, int divisor ) {\n  string ans;\n  int idx = 0;\n  int temp = number [ idx ] - '0';\n  while ( temp < divisor ) temp = temp * 10 + ( number [ ++ idx ] - '0' );\n  while ( number . size ( ) > idx ) {\n    ans += ( temp / divisor ) + '0';\n    temp = ( temp % divisor ) * 10 + number [ ++ idx ] - '0';\n  }\n  if ( ans . length ( ) == 0 ) return \"0\";\n  return ans;\n}\n", "FIND_ROW_NUMBER_BINARY_MATRIX_MAXIMUM_NUMBER_1S": "void findMax ( int arr [ ] [ N ] ) {\n  int row = 0, i, j;\n  for ( i = 0, j = N - 1;\n  i < N;\n  i ++ ) {\n    while ( arr [ i ] [ j ] == 1 && j >= 0 ) {\n      row = i;\n      j --;\n    }\n  }\n  cout << \"Row number = \" << row + 1;\n  cout << \", MaxCount = \" << N - 1 - j;\n}\n", "MINIMUM_ROTATIONS_REQUIRED_GET_STRING": "int findRotations ( string str ) {\n  string tmp = str + str;\n  int n = str . length ( );\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    string substring = tmp . substr ( i, str . size ( ) );\n    if ( str == substring ) return i;\n  }\n  return n;\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX": "int numberOfPaths ( int m, int n ) {\n  if ( m == 1 || n == 1 ) return 1;\n  return numberOfPaths ( m - 1, n ) + numberOfPaths ( m, n - 1 );\n}\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN_1": "int findNth ( int n ) {\n  int count = 0;\n  for ( int curr = 19;\n  ;\n  curr += 9 ) {\n    int sum = 0;\n    for ( int x = curr;\n    x > 0;\n    x = x / 10 ) sum = sum + x % 10;\n    if ( sum == 10 ) count ++;\n    if ( count == n ) return curr;\n  }\n  return - 1;\n}\n", "SUM_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING_1": "int sumAtKthLevel ( string tree, int k, int & i, int level ) {\n  if ( tree [ i ++ ] == '(' ) {\n    if ( tree [ i ] == ')' ) return 0;\n    int sum = 0;\n    if ( level == k ) sum = tree [ i ] - '0';\n    int leftsum = sumAtKthLevel ( tree, k, ++ i, level + 1 );\n    int rightsum = sumAtKthLevel ( tree, k, ++ i, level + 1 );\n    ++ i;\n    return sum + leftsum + rightsum;\n  }\n}\n", "COUNT_OFDIFFERENT_WAYS_EXPRESS_N_SUM_1_3_4": "int countWays ( int n ) {\n  int DP [ n + 1 ];\n  DP [ 0 ] = DP [ 1 ] = DP [ 2 ] = 1;\n  DP [ 3 ] = 2;\n  for ( int i = 4;\n  i <= n;\n  i ++ ) DP [ i ] = DP [ i - 1 ] + DP [ i - 3 ] + DP [ i - 4 ];\n  return DP [ n ];\n}\n", "MAXIMUM_EQULIBRIUM_SUM_ARRAY": "int findMaxSum ( int arr [ ], int n ) {\n  int res = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int prefix_sum = arr [ i ];\n    for ( int j = 0;\n    j < i;\n    j ++ ) prefix_sum += arr [ j ];\n    int suffix_sum = arr [ i ];\n    for ( int j = n - 1;\n    j > i;\n    j -- ) suffix_sum += arr [ j ];\n    if ( prefix_sum == suffix_sum ) res = max ( res, prefix_sum );\n  }\n  return res;\n}\n", "STEINS_ALGORITHM_FOR_FINDING_GCD_1": "int gcd ( int a, int b ) {\n  if ( a == b ) return a;\n  if ( a == 0 ) return b;\n  if ( b == 0 ) return a;\n  if ( ~ a & 1 ) {\n    if ( b & 1 ) return gcd ( a >> 1, b );\n    else return gcd ( a >> 1, b >> 1 ) << 1;\n  }\n  if ( ~ b & 1 ) return gcd ( a, b >> 1 );\n  if ( a > b ) return gcd ( ( a - b ) >> 1, b );\n  return gcd ( ( b - a ) >> 1, a );\n}\n", "PROGRAM_TO_FIND_THE_VOLUME_OF_A_TRIANGULAR_PRISM": "float findVolume ( float l, float b, float h ) {\n  float volume = ( l * b * h ) / 2;\n  return volume;\n}\n", "FIND_RECTANGLE_BINARY_MATRIX_CORNERS_1": "bool isRectangle ( const vector < vector < int > > & m ) {\n  int rows = m . size ( );\n  if ( rows == 0 ) return false;\n  int columns = m [ 0 ] . size ( );\n  for ( int y1 = 0;\n  y1 < rows;\n  y1 ++ ) for ( int x1 = 0;\n  x1 < columns;\n  x1 ++ ) if ( m [ y1 ] [ x1 ] == 1 ) for ( int y2 = y1 + 1;\n  y2 < rows;\n  y2 ++ ) for ( int x2 = x1 + 1;\n  x2 < columns;\n  x2 ++ ) if ( m [ y1 ] [ x2 ] == 1 && m [ y2 ] [ x1 ] == 1 && m [ y2 ] [ x2 ] == 1 ) return true;\n  return false;\n}\n", "CHECK_IF_STRING_REMAINS_PALINDROME_AFTER_REMOVING_GIVEN_NUMBER_OF_CHARACTERS": "bool isPossible ( string str, int n ) {\n  int len = str . length ( );\n  if ( len >= n ) return true;\n  return false;\n}\n", "CHECK_STAR_GRAPH": "bool checkStar ( int mat [ ] [ size ] ) {\n  int vertexD1 = 0, vertexDn_1 = 0;\n  if ( size == 1 ) return ( mat [ 0 ] [ 0 ] == 0 );\n  if ( size == 2 ) return ( mat [ 0 ] [ 0 ] == 0 && mat [ 0 ] [ 1 ] == 1 && mat [ 1 ] [ 0 ] == 1 && mat [ 1 ] [ 1 ] == 0 );\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\n    int degreeI = 0;\n    for ( int j = 0;\n    j < size;\n    j ++ ) if ( mat [ i ] [ j ] ) degreeI ++;\n    if ( degreeI == 1 ) vertexD1 ++;\n    else if ( degreeI == size - 1 ) vertexDn_1 ++;\n  }\n  return ( vertexD1 == ( size - 1 ) && vertexDn_1 == 1 );\n}\n", "ROOTS_OF_UNITY": "void printRoots ( int n ) {\n  double theta = M_PI * 2 / n;\n  for ( int k = 0;\n  k < n;\n  k ++ ) {\n    double real = cos ( k * theta );\n    double img = sin ( k * theta );\n    printf ( \"%.6f\", real );\n    img >= 0 ? printf ( \" + i \" ) : printf ( \" - i \" );\n    printf ( \"%.6f\\n\", abs ( img ) );\n  }\n}\n", "FIND_LARGEST_D_IN_ARRAY_SUCH_THAT_A_B_C_D": "int findLargestd ( int S [ ], int n ) {\n  bool found = false;\n  sort ( S, S + n );\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( i == j ) continue;\n      for ( int k = j + 1;\n      k < n;\n      k ++ ) {\n        if ( i == k ) continue;\n        for ( int l = k + 1;\n        l < n;\n        l ++ ) {\n          if ( i == l ) continue;\n          if ( S [ i ] == S [ j ] + S [ k ] + S [ l ] ) {\n            found = true;\n            return S [ i ];\n          }\n        }\n      }\n    }\n  }\n  if ( found == false ) return INT_MIN;\n}\n", "GIVEN_NUMBER_STRING_FIND_NUMBER_CONTIGUOUS_SUBSEQUENCES_RECURSIVELY_ADD_9_SET_2": "int count9s ( char number [ ] ) {\n  int n = strlen ( number );\n  int d [ 9 ];\n  memset ( d, 0, sizeof ( d ) );\n  d [ 0 ] = 1;\n  int result = 0;\n  int mod_sum = 0, continuous_zero = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ! int ( number [ i ] - '0' ) ) continuous_zero ++;\n    else continuous_zero = 0;\n    mod_sum += int ( number [ i ] - '0' );\n    mod_sum %= 9;\n    result += d [ mod_sum ];\n    d [ mod_sum ] ++;\n    result -= continuous_zero;\n  }\n  return result;\n}\n", "LEXICOGRAPHICAL_MAXIMUM_SUBSTRING_STRING": "string LexicographicalMaxString ( string str ) {\n  string mx = \"\";\n  for ( int i = 0;\n  i < str . length ( );\n  ++ i ) mx = max ( mx, str . substr ( i ) );\n  return mx;\n}\n", "CHECK_TWO_GIVEN_SETS_DISJOINT_1": "bool areDisjoint ( int set1 [ ], int set2 [ ], int m, int n ) {\n  sort ( set1, set1 + m );\n  sort ( set2, set2 + n );\n  int i = 0, j = 0;\n  while ( i < m && j < n ) {\n    if ( set1 [ i ] < set2 [ j ] ) i ++;\n    else if ( set2 [ j ] < set1 [ i ] ) j ++;\n    else return false;\n  }\n  return true;\n}\n", "EQUILIBRIUM_INDEX_OF_AN_ARRAY_1": "int equilibrium ( int arr [ ], int n ) {\n  int sum = 0;\n  int leftsum = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) sum += arr [ i ];\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    sum -= arr [ i ];\n    if ( leftsum == sum ) return i;\n    leftsum += arr [ i ];\n  }\n  return - 1;\n}\n", "AREA_CIRCUMSCRIBED_CIRCLE_SQUARE": "float areacircumscribed ( float a ) {\n  return ( a * a * ( PI / 2 ) );\n}\n", "LONGEST_REPEATING_AND_NON_OVERLAPPING_SUBSTRING": "string longestRepeatedSubstring ( string str ) {\n  int n = str . length ( );\n  int LCSRe [ n + 1 ] [ n + 1 ];\n  memset ( LCSRe, 0, sizeof ( LCSRe ) );\n  string res;\n  int res_length = 0;\n  int i, index = 0;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j <= n;\n    j ++ ) {\n      if ( str [ i - 1 ] == str [ j - 1 ] && 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        }\n      }\n      else LCSRe [ i ] [ j ] = 0;\n    }\n  }\n  if ( res_length > 0 ) for ( i = index - res_length + 1;\n  i <= index;\n  i ++ ) res . push_back ( str [ i - 1 ] );\n  return res;\n}\n", "HOW_TO_AVOID_OVERFLOW_IN_MODULAR_MULTIPLICATION": "ll mulmod ( ll a, ll b, ll mod ) {\n  ll res = 0;\n  a = a % mod;\n  while ( b > 0 ) {\n    if ( b % 2 == 1 ) res = ( res + a ) % mod;\n    a = ( a * 2 ) % mod;\n    b /= 2;\n  }\n  return res % mod;\n}\n", "PAIR_WITH_GIVEN_PRODUCT_SET_1_FIND_IF_ANY_PAIR_EXISTS_1": "bool isProduct ( int arr [ ], int n, int x ) {\n  if ( n < 2 ) return false;\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == 0 ) {\n      if ( x == 0 ) return true;\n      else continue;\n    }\n    if ( x % arr [ i ] == 0 ) {\n      if ( s . find ( x / arr [ i ] ) != s . end ( ) ) return true;\n      s . insert ( arr [ i ] );\n    }\n  }\n  return false;\n}\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS": "int kthgroupsum ( int k ) {\n  int cur = ( k * ( k - 1 ) ) + 1;\n  int sum = 0;\n  while ( k -- ) {\n    sum += cur;\n    cur += 2;\n  }\n  return sum;\n}\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS_1": "void findElements ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 2;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "MINIMUM_STEPS_TO_DELETE_A_STRING_AFTER_REPEATED_DELETION_OF_PALINDROME_SUBSTRINGS": "int minStepToDeleteString ( string str ) {\n  int N = str . length ( );\n  int dp [ N + 1 ] [ N + 1 ];\n  for ( int i = 0;\n  i <= N;\n  i ++ ) for ( int j = 0;\n  j <= N;\n  j ++ ) dp [ i ] [ j ] = 0;\n  for ( int len = 1;\n  len <= N;\n  len ++ ) {\n    for ( int i = 0, j = len - 1;\n    j < N;\n    i ++, j ++ ) {\n      if ( len == 1 ) dp [ i ] [ j ] = 1;\n      else {\n        dp [ i ] [ j ] = 1 + dp [ i + 1 ] [ j ];\n        if ( str [ i ] == str [ i + 1 ] ) dp [ i ] [ j ] = min ( 1 + dp [ i + 2 ] [ j ], dp [ i ] [ j ] );\n        for ( int K = i + 2;\n        K <= j;\n        K ++ ) if ( str [ i ] == str [ K ] ) dp [ i ] [ j ] = min ( dp [ i + 1 ] [ K - 1 ] + dp [ K + 1 ] [ j ], dp [ i ] [ j ] );\n      }\n    }\n  }\n  return dp [ 0 ] [ N - 1 ];\n}\n", "CALCULATE_AREA_TETRAHEDRON": "double vol_tetra ( int side ) {\n  double volume = ( pow ( side, 3 ) / ( 6 * sqrt ( 2 ) ) );\n  return volume;\n}\n", "SIEVE_OF_ATKIN": "int SieveOfAtkin ( int limit ) {\n  if ( limit > 2 ) cout << 2 << \" \";\n  if ( limit > 3 ) cout << 3 << \" \";\n  bool sieve [ limit ];\n  for ( int i = 0;\n  i < limit;\n  i ++ ) sieve [ i ] = false;\n  for ( int x = 1;\n  x * x < limit;\n  x ++ ) {\n    for ( int y = 1;\n    y * y < limit;\n    y ++ ) {\n      int n = ( 4 * x * x ) + ( y * y );\n      if ( n <= limit && ( n % 12 == 1 || n % 12 == 5 ) ) sieve [ n ] ^= true;\n      n = ( 3 * x * x ) + ( y * y );\n      if ( n <= limit && n % 12 == 7 ) sieve [ n ] ^= true;\n      n = ( 3 * x * x ) - ( y * y );\n      if ( x > y && n <= limit && n % 12 == 11 ) sieve [ n ] ^= true;\n    }\n  }\n  for ( int r = 5;\n  r * r < limit;\n  r ++ ) {\n    if ( sieve [ r ] ) {\n      for ( int i = r * r;\n      i < limit;\n      i += r * r ) sieve [ i ] = false;\n    }\n  }\n  for ( int a = 5;\n  a < limit;\n  a ++ ) if ( sieve [ a ] ) cout << a << \" \";\n}\n", "LENGTH_OF_THE_LONGEST_ARITHMATIC_PROGRESSION_IN_A_SORTED_ARRAY": "int lenghtOfLongestAP ( int set [ ], int n ) {\n  if ( n <= 2 ) return n;\n  int L [ n ] [ n ];\n  int llap = 2;\n  for ( int i = 0;\n  i < n;\n  i ++ ) L [ i ] [ n - 1 ] = 2;\n  for ( int j = n - 2;\n  j >= 1;\n  j -- ) {\n    int i = j - 1, k = j + 1;\n    while ( i >= 0 && k <= n - 1 ) {\n      if ( set [ i ] + set [ k ] < 2 * set [ j ] ) k ++;\n      else if ( set [ i ] + set [ k ] > 2 * set [ j ] ) {\n        L [ i ] [ j ] = 2, i --;\n      }\n      else {\n        L [ i ] [ j ] = L [ j ] [ k ] + 1;\n        llap = max ( llap, L [ i ] [ j ] );\n        i --;\n        k ++;\n      }\n    }\n    while ( i >= 0 ) {\n      L [ i ] [ j ] = 2;\n      i --;\n    }\n  }\n  return llap;\n}\n", "COUNT_GROUPINGS_NUMBER_SUM_DIGITS_EVERY_SUB_GROUP_LESS_EQUALS_IMMEDIATE_RIGHT_SUB_GROUP_1": "int countGroups ( int position, int previous_sum, int length, char * num ) {\n  if ( position == length ) return 1;\n  if ( dp [ position ] [ previous_sum ] != - 1 ) return dp [ position ] [ previous_sum ];\n  dp [ position ] [ previous_sum ] = 0;\n  int res = 0;\n  int sum = 0;\n  for ( int i = position;\n  i < length;\n  i ++ ) {\n    sum += ( num [ i ] - '0' );\n    if ( sum >= previous_sum ) res += countGroups ( i + 1, sum, length, num );\n  }\n  dp [ position ] [ previous_sum ] = res;\n  return res;\n}\n", "LONGEST_SPAN_SUM_TWO_BINARY_ARRAYS_1": "int longestCommonSum ( bool arr1 [ ], bool arr2 [ ], int n ) {\n  int maxLen = 0;\n  int preSum1 = 0, preSum2 = 0;\n  int diff [ 2 * n + 1 ];\n  memset ( diff, - 1, sizeof ( diff ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    preSum1 += arr1 [ i ];\n    preSum2 += arr2 [ i ];\n    int curr_diff = preSum1 - preSum2;\n    int diffIndex = n + curr_diff;\n    if ( curr_diff == 0 ) maxLen = i + 1;\n    else if ( diff [ diffIndex ] == - 1 ) diff [ diffIndex ] = i;\n    else {\n      int len = i - diff [ diffIndex ];\n      if ( len > maxLen ) maxLen = len;\n    }\n  }\n  return maxLen;\n}\n", "PROGRAM_TO_PRINT_FIRST_N_FIBONACCI_NUMBERS": "void printFibonacciNumbers ( int n ) {\n  int f1 = 0, f2 = 1, i;\n  if ( n < 1 ) return;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    cout << f2 << \" \";\n    int next = f1 + f2;\n    f1 = f2;\n    f2 = next;\n  }\n}\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY_3": "int maxSubArraySum ( int a [ ], int size ) {\n  int max_so_far = INT_MIN, max_ending_here = 0, start = 0, end = 0, s = 0;\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\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    }\n    if ( max_ending_here < 0 ) {\n      max_ending_here = 0;\n      s = i + 1;\n    }\n  }\n  cout << \"Maximum contiguous sum is \" << max_so_far << endl;\n  cout << \"Starting index \" << start << endl << \"Ending index \" << end << endl;\n}\n", "FIND_EQUAL_POINT_STRING_BRACKETS": "int findIndex ( string str ) {\n  int len = str . length ( );\n  int open [ len + 1 ], close [ len + 1 ];\n  int index = - 1;\n  memset ( open, 0, sizeof ( open ) );\n  memset ( close, 0, sizeof ( close ) );\n  open [ 0 ] = 0;\n  close [ len ] = 0;\n  if ( str [ 0 ] == '(' ) open [ 1 ] = 1;\n  if ( str [ len - 1 ] == ')' ) close [ len - 1 ] = 1;\n  for ( int i = 1;\n  i < len;\n  i ++ ) {\n    if ( str [ i ] == '(' ) open [ i + 1 ] = open [ i ] + 1;\n    else open [ i + 1 ] = open [ i ];\n  }\n  for ( int i = len - 2;\n  i >= 0;\n  i -- ) {\n    if ( str [ i ] == ')' ) close [ i ] = close [ i + 1 ] + 1;\n    else close [ i ] = close [ i + 1 ];\n  }\n  if ( open [ len ] == 0 ) return len;\n  if ( close [ 0 ] == 0 ) return 0;\n  for ( int i = 0;\n  i <= len;\n  i ++ ) if ( open [ i ] == close [ i ] ) index = i;\n  return index;\n}\n", "COUNT_NUMBER_OF_WAYS_TO_PARTITION_A_SET_INTO_K_SUBSETS_1": "int countP ( int n, int k ) {\n  int dp [ n + 1 ] [ k + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) dp [ i ] [ 0 ] = 0;\n  for ( int i = 0;\n  i <= k;\n  i ++ ) dp [ 0 ] [ k ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= i;\n  j ++ ) if ( j == 1 || i == j ) dp [ i ] [ j ] = 1;\n  else dp [ i ] [ j ] = j * dp [ i - 1 ] [ j ] + dp [ i - 1 ] [ j - 1 ];\n  return dp [ n ] [ k ];\n}\n", "LONGEST_INCREASING_SUBSEQUENCE": "int lis ( int arr [ ], int n ) {\n  int max = 1;\n  _lis ( arr, n, & max );\n  return max;\n}\n", "FIND_REPEATED_CHARACTER_PRESENT_FIRST_STRING": "int findRepeatFirstN2 ( char * s ) {\n  int p = - 1, i, j;\n  for ( i = 0;\n  i < strlen ( s );\n  i ++ ) {\n    for ( j = i + 1;\n    j < strlen ( s );\n    j ++ ) {\n      if ( s [ i ] == s [ j ] ) {\n        p = i;\n        break;\n      }\n    }\n    if ( p != - 1 ) break;\n  }\n  return p;\n}\n", "K_TH_SMALLEST_ELEMENT_REMOVING_INTEGERS_NATURAL_NUMBERS": "int ksmallest ( int arr [ ], int n, int k ) {\n  int b [ MAX ];\n  memset ( b, 0, sizeof b );\n  for ( int i = 0;\n  i < n;\n  i ++ ) b [ arr [ i ] ] = 1;\n  for ( int j = 1;\n  j < MAX;\n  j ++ ) {\n    if ( b [ j ] != 1 ) k --;\n    if ( ! k ) return j;\n  }\n}\n", "CHECK_IF_STACK_ELEMENTS_ARE_PAIRWISE_CONSECUTIVE": "bool pairWiseConsecutive ( stack < int > s ) {\n  stack < int > aux;\n  while ( ! s . empty ( ) ) {\n    aux . push ( s . top ( ) );\n    s . pop ( );\n  }\n  bool result = true;\n  while ( aux . empty ( ) > 1 ) {\n    int x = aux . top ( );\n    aux . pop ( );\n    int y = aux . top ( );\n    aux . pop ( );\n    if ( abs ( x - y ) != 1 ) result = false;\n    s . push ( x );\n    s . push ( y );\n  }\n  if ( aux . size ( ) == 1 ) s . push ( aux . top ( ) );\n  return result;\n}\n", "BINARY_SEARCH_1": "int binarySearch ( int arr [ ], int l, int r, int x ) {\n  while ( l <= r ) {\n    int m = l + ( r - l ) / 2;\n    if ( arr [ m ] == x ) return m;\n    if ( arr [ m ] < x ) l = m + 1;\n    else r = m - 1;\n  }\n  return - 1;\n}\n", "COUNT_DISTINCT_OCCURRENCES_AS_A_SUBSEQUENCE": "int findSubsequenceCount ( string S, string T ) {\n  int m = T . length ( ), n = S . length ( );\n  if ( m > n ) return 0;\n  int mat [ m + 1 ] [ n + 1 ];\n  for ( int i = 1;\n  i <= m;\n  i ++ ) mat [ i ] [ 0 ] = 0;\n  for ( int j = 0;\n  j <= n;\n  j ++ ) mat [ 0 ] [ j ] = 1;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      if ( T [ i - 1 ] != S [ j - 1 ] ) mat [ i ] [ j ] = mat [ i ] [ j - 1 ];\n      else mat [ i ] [ j ] = mat [ i ] [ j - 1 ] + mat [ i - 1 ] [ j - 1 ];\n    }\n  }\n  return mat [ m ] [ n ];\n}\n", "SWAP_TWO_NUMBERS_WITHOUT_USING_TEMPORARY_VARIABLE": "void swap ( int * xp, int * yp ) {\n  * xp = * xp ^ * yp;\n  * yp = * xp ^ * yp;\n  * xp = * xp ^ * yp;\n}\n", "POLICEMEN_CATCH_THIEVES": "int policeThief ( char arr [ ], int n, int k ) {\n  int res = 0;\n  vector < int > thi;\n  vector < int > pol;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == 'P' ) pol . push_back ( i );\n    else if ( arr [ i ] == 'T' ) thi . push_back ( i );\n  }\n  int l = 0, r = 0;\n  while ( l < thi . size ( ) && r < pol . size ( ) ) {\n    if ( abs ( thi [ l ] - pol [ r ] ) <= k ) {\n      res ++;\n      l ++;\n      r ++;\n    }\n    else if ( thi [ l ] < pol [ r ] ) l ++;\n    else r ++;\n  }\n  return res;\n}\n", "LARGEST_SUBARRAY_WITH_EQUAL_NUMBER_OF_0S_AND_1S_1": "int maxLen ( int arr [ ], int n ) {\n  unordered_map < int, int > hM;\n  int sum = 0;\n  int max_len = 0;\n  int ending_index = - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = ( arr [ i ] == 0 ) ? - 1 : 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ];\n    if ( sum == 0 ) {\n      max_len = i + 1;\n      ending_index = i;\n    }\n    if ( hM . find ( sum + n ) != hM . end ( ) ) {\n      if ( max_len < i - hM [ sum + n ] ) {\n        max_len = i - hM [ sum + n ];\n        ending_index = i;\n      }\n    }\n    else hM [ sum + n ] = i;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = ( arr [ i ] == - 1 ) ? 0 : 1;\n  printf ( \"%d to %d\\n\", ending_index - max_len + 1, ending_index );\n  return max_len;\n}\n", "MAXIMUM_DIFFERENCE_ZEROS_ONES_BINARY_STRING_SET_2_TIME": "int findLength ( string str, int n ) {\n  int current_sum = 0;\n  int max_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    current_sum += ( str [ i ] == '0' ? 1 : - 1 );\n    if ( current_sum < 0 ) current_sum = 0;\n    max_sum = max ( current_sum, max_sum );\n  }\n  return max_sum == 0 ? - 1 : max_sum;\n}\n", "MAXIMUM_CONSECUTIVE_NUMBERS_PRESENT_ARRAY": "int findLongestConseqSubseq ( int arr [ ], int n ) {\n  unordered_set < int > S;\n  for ( int i = 0;\n  i < n;\n  i ++ ) S . insert ( arr [ i ] );\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( S . find ( arr [ i ] - 1 ) == S . end ( ) ) {\n      int j = arr [ i ];\n      while ( S . find ( j ) != S . end ( ) ) j ++;\n      ans = max ( ans, j - arr [ i ] );\n    }\n  }\n  return ans;\n}\n", "LEXICOGRAPHICALLY_NEXT_STRING": "string nextWord ( string s ) {\n  if ( s == \"\" ) return \"a\";\n  int i = s . length ( ) - 1;\n  while ( s [ i ] == 'z' && i >= 0 ) i --;\n  if ( i == - 1 ) s = s + 'a';\n  else s [ i ] ++;\n  return s;\n}\n", "SCHEDULE_JOBS_SERVER_GETS_EQUAL_LOAD": "int solve ( int a [ ], int b [ ], int n ) {\n  int i;\n  long long int s = 0;\n  for ( i = 0;\n  i < n;\n  i ++ ) s += ( a [ i ] + b [ i ] );\n  if ( n == 1 ) return a [ 0 ] + b [ 0 ];\n  if ( s % n != 0 ) return - 1;\n  int x = s / n;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] > x ) return - 1;\n    if ( i > 0 ) {\n      a [ i ] += b [ i - 1 ];\n      b [ i - 1 ] = 0;\n    }\n    if ( a [ i ] == x ) continue;\n    int y = a [ i ] + b [ i ];\n    if ( i + 1 < n ) y += b [ i + 1 ];\n    if ( y == x ) {\n      a [ i ] = y;\n      b [ i ] = b [ i + 1 ] = 0;\n      continue;\n    }\n    if ( a [ i ] + b [ i ] == x ) {\n      a [ i ] += b [ i ];\n      b [ i ] = 0;\n      continue;\n    }\n    if ( i + 1 < n && a [ i ] + b [ i + 1 ] == x ) {\n      a [ i ] += b [ i + 1 ];\n      b [ i + 1 ] = 0;\n      continue;\n    }\n    return - 1;\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( b [ i ] != 0 ) return - 1;\n  return x;\n}\n", "FORM_MINIMUM_NUMBER_FROM_GIVEN_SEQUENCE_1": "string getMinNumberForPattern ( string seq ) {\n  int n = seq . length ( );\n  if ( n >= 9 ) return \"-1\";\n  string result ( n + 1, ' ' );\n  int count = 1;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    if ( i == n || seq [ i ] == 'I' ) {\n      for ( int j = i - 1;\n      j >= - 1;\n      j -- ) {\n        result [ j + 1 ] = '0' + count ++;\n        if ( j >= 0 && seq [ j ] == 'I' ) break;\n      }\n    }\n  }\n  return result;\n}\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE": "void shuffleArray ( int a [ ], int n ) {\n  for ( int i = 0, q = 1, k = n;\n  i < n;\n  i ++, k ++, q ++ ) for ( int j = k;\n  j > i + q;\n  j -- ) swap ( a [ j - 1 ], a [ j ] );\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_1": "int findRepeating ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s . find ( arr [ i ] ) != s . end ( ) ) return arr [ i ];\n    s . insert ( arr [ i ] );\n  }\n  return - 1;\n}\n", "C_PROGRAM_SUBTRACTION_MATICES": "void multiply ( int A [ ] [ N ], int B [ ] [ N ], int C [ ] [ N ] ) {\n  int i, j;\n  for ( i = 0;\n  i < N;\n  i ++ ) for ( j = 0;\n  j < N;\n  j ++ ) C [ i ] [ j ] = A [ i ] [ j ] - B [ i ] [ j ];\n}\n", "FIRST_NEGATIVE_INTEGER_EVERY_WINDOW_SIZE_K": "void printFirstNegativeInteger ( int arr [ ], int n, int k ) {\n  bool flag;\n  for ( int i = 0;\n  i < ( n - k + 1 );\n  i ++ ) {\n    flag = false;\n    for ( int j = 0;\n    j < k;\n    j ++ ) {\n      if ( arr [ i + j ] < 0 ) {\n        cout << arr [ i + j ] << \" \";\n        flag = true;\n        break;\n      }\n    }\n    if ( ! flag ) cout << \"0\" << \" \";\n  }\n}\n", "NUMBER_FULL_BINARY_TREES_NODE_PRODUCT_CHILDREN": "int numoffbt ( int arr [ ], int n ) {\n  int maxvalue = INT_MIN, minvalue = INT_MAX;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    maxvalue = max ( maxvalue, arr [ i ] );\n    minvalue = min ( minvalue, arr [ i ] );\n  }\n  int mark [ maxvalue + 2 ];\n  int value [ maxvalue + 2 ];\n  memset ( mark, 0, sizeof ( mark ) );\n  memset ( value, 0, sizeof ( value ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    mark [ arr [ i ] ] = 1;\n    value [ arr [ i ] ] = 1;\n  }\n  int ans = 0;\n  for ( int i = minvalue;\n  i <= maxvalue;\n  i ++ ) {\n    if ( mark [ i ] ) {\n      for ( int j = i + i;\n      j <= maxvalue && j / i <= i;\n      j += i ) {\n        if ( ! mark [ j ] ) continue;\n        value [ j ] = value [ j ] + ( value [ i ] * value [ j / i ] );\n        if ( i != j / i ) value [ j ] = value [ j ] + ( value [ i ] * value [ j / i ] );\n      }\n    }\n    ans += value [ i ];\n  }\n  return ans;\n}\n", "TRIANGULAR_MATCHSTICK_NUMBER": "int numberOfSticks ( int x ) {\n  return ( 3 * x * ( x + 1 ) ) / 2;\n}\n", "K_MAXIMUM_SUM_COMBINATIONS_TWO_ARRAYS": "void KMaxCombinations ( int A [ ], int B [ ], int N, int K ) {\n  priority_queue < int > pq;\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < N;\n  j ++ ) pq . push ( A [ i ] + B [ j ] );\n  int count = 0;\n  while ( count < K ) {\n    cout << pq . top ( ) << endl;\n    pq . pop ( );\n    count ++;\n  }\n}\n", "CONSTRUCT_ARRAY_PAIR_SUM_ARRAY": "void constructArr ( int arr [ ], int pair [ ], int n ) {\n  arr [ 0 ] = ( pair [ 0 ] + pair [ 1 ] - pair [ n - 1 ] ) / 2;\n  for ( int i = 1;\n  i < n;\n  i ++ ) arr [ i ] = pair [ i - 1 ] - arr [ 0 ];\n}\n", "CHECK_HALF_STRING_CHARACTER_FREQUENCY_CHARACTER": "bool checkCorrectOrNot ( string s ) {\n  int count1 [ MAX_CHAR ] = {\n    0 };\n    int count2 [ MAX_CHAR ] = {\n      0 };\n      int n = s . length ( );\n      if ( n == 1 ) return true;\n      for ( int i = 0, j = n - 1;\n      i < j;\n      i ++, j -- ) {\n        count1 [ s [ i ] - 'a' ] ++;\n        count2 [ s [ j ] - 'a' ] ++;\n      }\n      for ( int i = 0;\n      i < MAX_CHAR;\n      i ++ ) if ( count1 [ i ] != count2 [ i ] ) return false;\n      return true;\n    }\n    ", "MINIMIZE_THE_MAXIMUM_DIFFERENCE_BETWEEN_THE_HEIGHTS": "int getMinDiff ( int arr [ ], int n, int k ) {\n  if ( n == 1 ) return 0;\n  sort ( arr, arr + n );\n  int ans = arr [ n - 1 ] - arr [ 0 ];\n  int small = arr [ 0 ] + k;\n  int big = arr [ n - 1 ] - k;\n  if ( small > big ) swap ( small, big );\n  for ( int i = 1;\n  i < n - 1;\n  i ++ ) {\n    int subtract = arr [ i ] - k;\n    int add = arr [ i ] + k;\n    if ( subtract >= small || add <= big ) continue;\n    if ( big - subtract <= add - small ) small = subtract;\n    else big = add;\n  }\n  return min ( ans, big - small );\n}\n", "MINIMUM_POSSIBLE_VALUE_AI_AJ_K_GIVEN_ARRAY_K": "void pairs ( int arr [ ], int n, int k ) {\n  int smallest = INT_MAX;\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) {\n    if ( abs ( arr [ i ] + arr [ j ] - k ) < smallest ) {\n      smallest = abs ( arr [ i ] + arr [ j ] - k );\n      count = 1;\n    }\n    else if ( abs ( arr [ i ] + arr [ j ] - k ) == smallest ) count ++;\n  }\n  cout << \"Minimal Value = \" << smallest << \"\\n\";\n  cout << \"Total Pairs = \" << count << \"\\n\";\n}\n", "SIZE_SUBARRAY_MAXIMUM_SUM": "int maxSubArraySum ( int a [ ], int size ) {\n  int max_so_far = INT_MIN, max_ending_here = 0, start = 0, end = 0, s = 0;\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\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    }\n    if ( max_ending_here < 0 ) {\n      max_ending_here = 0;\n      s = i + 1;\n    }\n  }\n  return ( end - start + 1 );\n}\n", "MINIMUM_NUMBER_OF_SQUARES_WHOSE_SUM_EQUALS_TO_GIVEN_NUMBER_N_1": "int getMinSquares ( int n ) {\n  int * dp = new int [ n + 1 ];\n  dp [ 0 ] = 0;\n  dp [ 1 ] = 1;\n  dp [ 2 ] = 2;\n  dp [ 3 ] = 3;\n  for ( int i = 4;\n  i <= n;\n  i ++ ) {\n    dp [ i ] = i;\n    for ( int x = 1;\n    x <= ceil ( sqrt ( i ) );\n    x ++ ) {\n      int temp = x * x;\n      if ( temp > i ) break;\n      else dp [ i ] = min ( dp [ i ], 1 + dp [ i - temp ] );\n    }\n  }\n  int res = dp [ n ];\n  delete [ ] dp;\n  return res;\n}\n", "DIVISIBILITY_BY_7": "int isDivisibleBy7 ( int num ) {\n  if ( num < 0 ) return isDivisibleBy7 ( - num );\n  if ( num == 0 || num == 7 ) return 1;\n  if ( num < 10 ) return 0;\n  return isDivisibleBy7 ( num / 10 - 2 * ( num - num / 10 * 10 ) );\n}\n", "POSITION_OF_RIGHTMOST_SET_BIT_2": "int Right_most_setbit ( int num ) {\n  int pos = 1;\n  for ( int i = 0;\n  i < INT_SIZE;\n  i ++ ) {\n    if ( ! ( num & ( 1 << i ) ) ) pos ++;\n    else break;\n  }\n  return pos;\n}\n", "EFFICIENT_WAY_TO_MULTIPLY_WITH_7": "long multiplyBySeven ( long n ) {\n  return ( ( n << 3 ) - n );\n}\n", "NEXT_HIGHER_NUMBER_WITH_SAME_NUMBER_OF_SET_BITS": "uint_t snoob ( uint_t x ) {\n  uint_t rightOne;\n  uint_t nextHigherOneBit;\n  uint_t rightOnesPattern;\n  uint_t next = 0;\n  if ( x ) {\n    rightOne = x & - ( signed ) x;\n    nextHigherOneBit = x + rightOne;\n    rightOnesPattern = x ^ nextHigherOneBit;\n    rightOnesPattern = ( rightOnesPattern ) / rightOne;\n    rightOnesPattern >>= 2;\n    next = nextHigherOneBit | rightOnesPattern;\n  }\n  return next;\n}\n", "CHANGE_ARRAY_PERMUTATION_NUMBERS_1_N": "void makePermutation ( int a [ ], int n ) {\n  unordered_map < int, int > count;\n  for ( int i = 0;\n  i < n;\n  i ++ ) count [ a [ i ] ] ++;\n  int next_missing = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( count [ a [ i ] ] != 1 || a [ i ] > n || a [ i ] < 1 ) {\n      count [ a [ i ] ] --;\n      while ( count . find ( next_missing ) != count . end ( ) ) next_missing ++;\n      a [ i ] = next_missing;\n      count [ next_missing ] = 1;\n    }\n  }\n}\n", "MAXIMUM_AREA_QUADRILATERAL": "double maxArea ( double a, double b, double c, double d ) {\n  double semiperimeter = ( a + b + c + d ) / 2;\n  return sqrt ( ( semiperimeter - a ) * ( semiperimeter - b ) * ( semiperimeter - c ) * ( semiperimeter - d ) );\n}\n", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE_1": "void translate ( char * str ) {\n  int len = strlen ( str );\n  if ( len < 2 ) return;\n  int i = 0;\n  int j = 0;\n  while ( j < len - 1 ) {\n    if ( str [ j ] == 'A' && str [ j + 1 ] == 'B' ) {\n      j = j + 2;\n      str [ i ++ ] = 'C';\n      continue;\n    }\n    str [ i ++ ] = str [ j ++ ];\n  }\n  if ( j == len - 1 ) str [ i ++ ] = str [ j ];\n  str [ i ] = '';\n}\n", "FIND_POWER_POWER_MOD_PRIME": "unsigned int Calculate ( unsigned int A, unsigned int B, unsigned int C, unsigned int M ) {\n  unsigned int res, ans;\n  res = power ( B, C, M - 1 );\n  ans = power ( A, res, M );\n  return ans;\n}\n", "CHECK_EXIST_TWO_ELEMENTS_ARRAY_WHOSE_SUM_EQUAL_SUM_REST_ARRAY": "bool checkPair ( int arr [ ], int n ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += arr [ i ];\n  if ( sum % 2 != 0 ) return false;\n  sum = sum / 2;\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int val = sum - arr [ i ];\n    if ( s . find ( val ) != s . end ( ) ) {\n      printf ( \"Pair elements are %d and %d\\n\", arr [ i ], val );\n      return true;\n    }\n    s . insert ( arr [ i ] );\n  }\n  return false;\n}\n", "PROGRAM_FOR_SURFACE_AREA_OF_OCTAHEDRON": "double surface_area_octahedron ( double side ) {\n  return ( 2 * ( sqrt ( 3 ) ) * ( side * side ) );\n}\n", "FIND_A_SPECIFIC_PAIR_IN_MATRIX": "int findMaxValue ( int mat [ ] [ N ] ) {\n  int maxValue = INT_MIN;\n  for ( int a = 0;\n  a < N - 1;\n  a ++ ) for ( int b = 0;\n  b < N - 1;\n  b ++ ) for ( int d = a + 1;\n  d < N;\n  d ++ ) for ( int e = b + 1;\n  e < N;\n  e ++ ) if ( maxValue < ( mat [ d ] [ e ] - mat [ a ] [ b ] ) ) maxValue = mat [ d ] [ e ] - mat [ a ] [ b ];\n  return maxValue;\n}\n", "MULTIPLY_TWO_NUMBERS_WITHOUT_USING_MULTIPLY_DIVISION_BITWISE_OPERATORS_AND_NO_LOOPS": "public : int multiply ( int x, int y ) {\n  if ( y == 0 ) return 0;\n  if ( y > 0 ) return ( x + multiply ( x, y - 1 ) );\n  if ( y < 0 ) return - multiply ( x, - y );\n}\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_1": "void findTriplets ( int arr [ ], int n ) {\n  bool found = false;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    unordered_set < int > s;\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      int x = - ( arr [ i ] + arr [ j ] );\n      if ( s . find ( x ) != s . end ( ) ) {\n        printf ( \"%d %d %d\\n\", x, arr [ i ], arr [ j ] );\n        found = true;\n      }\n      else s . insert ( arr [ j ] );\n    }\n  }\n  if ( found == false ) cout << \" No Triplet Found\" << endl;\n}\n", "FIND_MAXIMUM_VALUE_OF_SUM_IARRI_WITH_ONLY_ROTATIONS_ON_GIVEN_ARRAY_ALLOWED": "int maxSum ( int arr [ ], int n ) {\n  int arrSum = 0;\n  int currVal = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    arrSum = arrSum + arr [ i ];\n    currVal = currVal + ( i * arr [ i ] );\n  }\n  int maxVal = currVal;\n  for ( int j = 1;\n  j < n;\n  j ++ ) {\n    currVal = currVal + arrSum - n * arr [ n - j ];\n    if ( currVal > maxVal ) maxVal = currVal;\n  }\n  return maxVal;\n}\n", "PROGRAM_FOR_SCALAR_MULTIPLICATION_OF_A_MATRIX": "void scalarProductMat ( int mat [ ] [ N ], int k ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < N;\n  j ++ ) mat [ i ] [ j ] = mat [ i ] [ j ] * k;\n}\n", "PRINT_SQUARES_FIRST_N_NATURAL_NUMBERS_WITHOUT_USING_1": "void printSquares ( int n ) {\n  int square = 0, odd = 1;\n  for ( int x = 0;\n  x < n;\n  x ++ ) {\n    cout << square << \" \";\n    square = square + odd;\n    odd = odd + 2;\n  }\n}\n", "NTH_PENTAGONAL_NUMBER": "int pentagonalNum ( int n ) {\n  return ( 3 * n * n - n ) / 2;\n}\n", "COUNT_ARRAYS_ADJACENT_ELEMENTS_ONE_DIVIDE_ANOTHER": "int numofArray ( int n, int m ) {\n  int dp [ MAX ] [ MAX ];\n  vector < int > di [ MAX ];\n  vector < int > mu [ MAX ];\n  memset ( dp, 0, sizeof dp );\n  memset ( di, 0, sizeof di );\n  memset ( mu, 0, sizeof mu );\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    for ( int j = 2 * i;\n    j <= m;\n    j += i ) {\n      di [ j ] . push_back ( i );\n      mu [ i ] . push_back ( j );\n    }\n    di [ i ] . push_back ( i );\n  }\n  for ( int i = 1;\n  i <= m;\n  i ++ ) dp [ 1 ] [ i ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= m;\n    j ++ ) {\n      dp [ i ] [ j ] = 0;\n      for ( auto x : di [ j ] ) dp [ i ] [ j ] += dp [ i - 1 ] [ x ];\n      for ( auto x : mu [ j ] ) dp [ i ] [ j ] += dp [ i - 1 ] [ x ];\n    }\n  }\n  int ans = 0;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    ans += dp [ n ] [ i ];\n    di [ i ] . clear ( );\n    mu [ i ] . clear ( );\n  }\n  return ans;\n}\n", "0_1_KNAPSACK_PROBLEM_DP_10": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  if ( n == 0 || W == 0 ) return 0;\n  if ( wt [ n - 1 ] > W ) return knapSack ( W, wt, val, n - 1 );\n  else return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ], wt, val, n - 1 ), knapSack ( W, wt, val, n - 1 ) );\n}\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO": "void findTriplets ( int arr [ ], int n ) {\n  bool found = true;\n  for ( int i = 0;\n  i < n - 2;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n - 1;\n    j ++ ) {\n      for ( int k = j + 1;\n      k < n;\n      k ++ ) {\n        if ( arr [ i ] + arr [ j ] + arr [ k ] == 0 ) {\n          cout << arr [ i ] << \" \" << arr [ j ] << \" \" << arr [ k ] << endl;\n          found = true;\n        }\n      }\n    }\n  }\n  if ( found == false ) cout << \" not exist \" << endl;\n}\n", "COUNT_NUMBER_WAYS_REACH_GIVEN_SCORE_GAME": "int count ( int n ) {\n  int table [ n + 1 ], i;\n  for ( int j = 0;\n  j < n + 1;\n  j ++ ) table [ j ] = 0;\n  table [ 0 ] = 1;\n  for ( i = 3;\n  i <= n;\n  i ++ ) table [ i ] += table [ i - 3 ];\n  for ( i = 5;\n  i <= n;\n  i ++ ) table [ i ] += table [ i - 5 ];\n  for ( i = 10;\n  i <= n;\n  i ++ ) table [ i ] += table [ i - 10 ];\n  return table [ n ];\n}\n", "MAXIMUM_SUM_ABSOLUTE_DIFFERENCE_ARRAY": "int MaxSumDifference ( int a [ ], int n ) {\n  vector < int > finalSequence;\n  sort ( a, a + n );\n  for ( int i = 0;\n  i < n / 2;\n  ++ i ) {\n    finalSequence . push_back ( a [ i ] );\n    finalSequence . push_back ( a [ n - i - 1 ] );\n  }\n  int MaximumSum = 0;\n  for ( int i = 0;\n  i < n - 1;\n  ++ i ) {\n    MaximumSum = MaximumSum + abs ( finalSequence [ i ] - finalSequence [ i + 1 ] );\n  }\n  MaximumSum = MaximumSum + abs ( finalSequence [ n - 1 ] - finalSequence [ 0 ] );\n  return MaximumSum;\n}\n", "PROGRAM_FIND_MID_POINT_LINE": "void midpoint ( int x1, int x2, int y1, int y2 ) {\n  cout << ( float ) ( x1 + x2 ) / 2 << \" , \" << ( float ) ( y1 + y2 ) / 2;\n}\n", "ALTERNATIVE_SORTING": "void alternateSort ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int i = 0, j = n - 1;\n  while ( i < j ) {\n    cout << arr [ j -- ] << \" \";\n    cout << arr [ i ++ ] << \" \";\n  }\n  if ( n % 2 != 0 ) cout << arr [ i ];\n}\n", "NUMBER_SUBARRAYS_SUM_EXACTLY_EQUAL_K": "int findSubarraySum ( int arr [ ], int n, int sum ) {\n  unordered_map < int, int > prevSum;\n  int res = 0;\n  int currsum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    currsum += arr [ i ];\n    if ( currsum == sum ) res ++;\n    if ( prevSum . find ( currsum - sum ) != prevSum . end ( ) ) res += ( prevSum [ currsum - sum ] );\n    prevSum [ currsum ] ++;\n  }\n  return res;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_IN_A_SORTED_ARRAY": "void search ( int * arr, int low, int high ) {\n  if ( low > high ) return;\n  if ( low == high ) {\n    printf ( \"The required element is %d \", arr [ low ] );\n    return;\n  }\n  int mid = ( low + high ) / 2;\n  if ( mid % 2 == 0 ) {\n    if ( arr [ mid ] == arr [ mid + 1 ] ) search ( arr, mid + 2, high );\n    else search ( arr, low, mid );\n  }\n  else {\n    if ( arr [ mid ] == arr [ mid - 1 ] ) search ( arr, mid + 1, high );\n    else search ( arr, low, mid - 1 );\n  }\n}\n", "FORM_SMALLEST_NUMBER_USING_ONE_SWAP_OPERATION": "string smallestNumber ( string num ) {\n  int n = num . size ( );\n  int rightMin [ n ], right;\n  rightMin [ n - 1 ] = - 1;\n  right = n - 1;\n  for ( int i = n - 2;\n  i >= 1;\n  i -- ) {\n    if ( num [ i ] >= num [ right ] ) rightMin [ i ] = right;\n    else {\n      if ( num [ i ] == num [ i + 1 ] ) {\n        rightMin [ i ] = right;\n      }\n      else {\n        rightMin [ i ] = - 1;\n        right = i;\n      }\n    }\n  }\n  int small = - 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( num [ i ] != '0' ) {\n    if ( small == - 1 ) {\n      if ( num [ i ] < num [ 0 ] ) small = i;\n    }\n    else if ( num [ i ] <= num [ small ] ) small = i;\n  }\n  if ( small != - 1 ) swap ( num [ 0 ], num [ small ] );\n  else {\n    for ( int i = 1;\n    i < n;\n    i ++ ) {\n      if ( rightMin [ i ] != - 1 && num [ i ] != num [ rightMin [ i ] ] ) {\n        swap ( num [ i ], num [ rightMin [ i ] ] );\n        break;\n      }\n    }\n  }\n  return num;\n}\n", "PROGRAM_AREA_SQUARE": "int areaSquare ( int side ) {\n  int area = side * side;\n  return area;\n}\n", "FIND_DAY_OF_THE_WEEK_FOR_A_GIVEN_DATE": "int dayofweek ( int d, int m, int y ) {\n  static int t [ ] = {\n    0, 3, 2, 5, 0, 3, 5, 1, 4, 6, 2, 4 };\n    y -= m < 3;\n    return ( y + y / 4 - y / 100 + y / 400 + t [ m - 1 ] + d ) % 7;\n  }\n  ", "CHECK_QUEUE_CAN_SORTED_ANOTHER_QUEUE_USING_STACK": "bool checkSorted ( int n, queue < int > & q ) {\n  stack < int > st;\n  int expected = 1;\n  int fnt;\n  while ( ! q . empty ( ) ) {\n    fnt = q . front ( );\n    q . pop ( );\n    if ( fnt == expected ) expected ++;\n    else {\n      if ( st . empty ( ) ) {\n        st . push ( fnt );\n      }\n      else if ( ! st . empty ( ) && st . top ( ) < fnt ) {\n        return false;\n      }\n      else st . push ( fnt );\n    }\n    while ( ! st . empty ( ) && st . top ( ) == expected ) {\n      st . pop ( );\n      expected ++;\n    }\n  }\n  if ( expected - 1 == n && st . empty ( ) ) return true;\n  return false;\n}\n", "SORT_ARRAY_CONTAIN_1_N_VALUES": "void sortit ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    arr [ i ] = i + 1;\n  }\n}\n", "LCS_LONGEST_COMMON_SUBSEQUENCE_THREE_STRINGS_1": "int lcsOf3 ( int i, int j, int k ) {\n  if ( i == - 1 || j == - 1 || k == - 1 ) return 0;\n  if ( dp [ i ] [ j ] [ k ] != - 1 ) return dp [ i ] [ j ] [ k ];\n  if ( X [ i ] == Y [ j ] && Y [ j ] == Z [ k ] ) return dp [ i ] [ j ] [ k ] = 1 + lcsOf3 ( i - 1, j - 1, k - 1 );\n  else return dp [ i ] [ j ] [ k ] = max ( max ( lcsOf3 ( i - 1, j, k ), lcsOf3 ( i, j - 1, k ) ), lcsOf3 ( i, j, k - 1 ) );\n}\n", "LOWER_INSERTION_POINT": "int LowerInsertionPoint ( int arr [ ], int n, int X ) {\n  if ( X < arr [ 0 ] ) return 0;\n  else if ( X > arr [ n - 1 ] ) return n;\n  int lowerPnt = 0;\n  int i = 1;\n  while ( i < n && arr [ i ] < X ) {\n    lowerPnt = i;\n    i = i * 2;\n  }\n  while ( lowerPnt < n && arr [ lowerPnt ] < X ) lowerPnt ++;\n  return lowerPnt;\n}\n", "CONSTRUCT_LEXICOGRAPHICALLY_SMALLEST_PALINDROME": "string constructPalin ( string str, int len ) {\n  int i = 0, j = len - 1;\n  for (;\n  i < j;\n  i ++, j -- ) {\n    if ( str [ i ] == str [ j ] && str [ i ] != '*' ) continue;\n    else if ( str [ i ] == str [ j ] && str [ i ] == '*' ) {\n      str [ i ] = 'a';\n      str [ j ] = 'a';\n      continue;\n    }\n    else if ( str [ i ] == '*' ) {\n      str [ i ] = str [ j ];\n      continue;\n    }\n    else if ( str [ j ] == '*' ) {\n      str [ j ] = str [ i ];\n      continue;\n    }\n    cout << \"Not Possible\";\n    return \"\";\n  }\n  return str;\n}\n", "SECTION_FORMULA_POINT_DIVIDES_LINE_GIVEN_RATIO": "void section ( double x1, double x2, double y1, double y2, double m, double n ) {\n  double x = ( ( n * x1 ) + ( m * x2 ) ) / ( m + n );\n  double y = ( ( n * y1 ) + ( m * y2 ) ) / ( m + n );\n  cout << \"(\" << x << \", \";\n  cout << y << \")\" << endl;\n}\n", "SQUARE_ROOT_NUMBER_USING_LOG": "double squareRoot ( double n ) {\n  return pow ( 2, 0.5 * log2 ( n ) );\n}\n", "MAXIMIZE_SUM_ARRII": "int maxSum ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += ( arr [ i ] * i );\n  return sum;\n}\n", "STRING_K_DISTINCT_CHARACTERS_NO_CHARACTERS_ADJACENT": "string findString ( int n, int k ) {\n  string res = \"\";\n  for ( int i = 0;\n  i < k;\n  i ++ ) res = res + ( char ) ( 'a' + i );\n  int count = 0;\n  for ( int i = 0;\n  i < n - k;\n  i ++ ) {\n    res = res + ( char ) ( 'a' + count );\n    count ++;\n    if ( count == k ) count = 0;\n  }\n  return res;\n}\n", "COUNT_WORDS_WHOSE_TH_LETTER_EITHER_1_TH_TH_I1_TH_LETTER_GIVEN_WORD": "int countWords ( char str [ ], int len ) {\n  int count = 1;\n  if ( len == 1 ) return count;\n  if ( str [ 0 ] == str [ 1 ] ) count *= 1;\n  else count *= 2;\n  for ( int j = 1;\n  j < len - 1;\n  j ++ ) {\n    if ( str [ j ] == str [ j - 1 ] && str [ j ] == str [ j + 1 ] ) count *= 1;\n    else if ( str [ j ] == str [ j - 1 ] || str [ j ] == str [ j + 1 ] || str [ j - 1 ] == str [ j + 1 ] ) count *= 2;\n    else count *= 3;\n  }\n  if ( str [ len - 1 ] == str [ len - 2 ] ) count *= 1;\n  else count *= 2;\n  return count;\n}\n", "NUMBER_JUMP_REQUIRED_GIVEN_LENGTH_REACH_POINT_FORM_D_0_ORIGIN_2D_PLANE": "int minJumps ( int a, int b, int d ) {\n  int temp = a;\n  a = min ( a, b );\n  b = max ( temp, b );\n  if ( d >= b ) return ( d + b - 1 ) / b;\n  if ( d == 0 ) return 0;\n  if ( d == a ) return 1;\n  return 2;\n}\n", "SUM_FACTORS_NUMBER_1": "int sumofFactors ( int n ) {\n  int res = 1;\n  for ( int i = 2;\n  i <= sqrt ( n );\n  i ++ ) {\n    int curr_sum = 1;\n    int curr_term = 1;\n    while ( n % i == 0 ) {\n      n = n / i;\n      curr_term *= i;\n      curr_sum += curr_term;\n    }\n    res *= curr_sum;\n  }\n  if ( n >= 2 ) res *= ( 1 + n );\n  return res;\n}\n", "DELETE_CONSECUTIVE_WORDS_SEQUENCE": "int removeConsecutiveSame ( vector < string > v ) {\n  int n = v . size ( );\n  for ( int i = 0;\n  i < n - 1;\n  ) {\n    if ( v [ i ] . compare ( v [ i + 1 ] ) == 0 ) {\n      v . erase ( v . begin ( ) + i );\n      v . erase ( v . begin ( ) + i );\n      if ( i > 0 ) i --;\n      n = n - 2;\n    }\n    else i ++;\n  }\n  return v . size ( );\n}\n", "COUNT_NUMBER_BINARY_STRINGS_WITHOUT_CONSECUTIVE_1S": "int countStrings ( int n ) {\n  int a [ n ], b [ n ];\n  a [ 0 ] = b [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    a [ i ] = a [ i - 1 ] + b [ i - 1 ];\n    b [ i ] = a [ i - 1 ];\n  }\n  return a [ n - 1 ] + b [ n - 1 ];\n}\n", "FIND_THE_MISSING_NUMBER": "int getMissingNo ( int a [ ], int n ) {\n  int total = ( n + 1 ) * ( n + 2 ) / 2;\n  for ( int i = 0;\n  i < n;\n  i ++ ) total -= a [ i ];\n  return total;\n}\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE": "public : float squareRoot ( float n ) {\n  float x = n;\n  float y = 1;\n  float e = 0.000001;\n  while ( x - y > e ) {\n    x = ( x + y ) / 2;\n    y = n / x;\n  }\n  return x;\n}\n", "SUBSET_SUM_PROBLEM_OSUM_SPACE": "bool isSubsetSum ( int arr [ ], int n, int sum ) {\n  bool subset [ 2 ] [ sum + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= sum;\n    j ++ ) {\n      if ( j == 0 ) subset [ i % 2 ] [ j ] = true;\n      else if ( i == 0 ) subset [ i % 2 ] [ j ] = false;\n      else if ( arr [ i - 1 ] <= j ) subset [ i % 2 ] [ j ] = subset [ ( i + 1 ) % 2 ] [ j - arr [ i - 1 ] ] || subset [ ( i + 1 ) % 2 ] [ j ];\n      else subset [ i % 2 ] [ j ] = subset [ ( i + 1 ) % 2 ] [ j ];\n    }\n  }\n  return subset [ n % 2 ] [ sum ];\n}\n", "MULTIPLICATIVE_INVERSE_UNDER_MODULO_M": "int modInverse ( int a, int m ) {\n  a = a % m;\n  for ( int x = 1;\n  x < m;\n  x ++ ) if ( ( a * x ) % m == 1 ) return x;\n}\n", "COMPUTE_AVERAGE_TWO_NUMBERS_WITHOUT_OVERFLOW": "int compute_average ( int a, int b ) {\n  return ( a + b ) / 2;\n}\n", "REPRESENT_GIVEN_SET_POINTS_BEST_POSSIBLE_STRAIGHT_LINE": "void bestApproximate ( int x [ ], int y [ ], int n ) {\n  float m, c, sum_x = 0, sum_y = 0, sum_xy = 0, sum_x2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\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  }\n  m = ( n * sum_xy - sum_x * sum_y ) / ( n * sum_x2 - pow ( sum_x, 2 ) );\n  c = ( sum_y - m * sum_x ) / n;\n  cout << \"m =\" << m;\n  cout << \"\\nc =\" << c;\n}\n", "SPLIT_ARRAY_ADD_FIRST_PART_END": "void splitArr ( int arr [ ], int n, int k ) {\n  for ( int i = 0;\n  i < k;\n  i ++ ) {\n    int x = arr [ 0 ];\n    for ( int j = 0;\n    j < n - 1;\n    ++ j ) arr [ j ] = arr [ j + 1 ];\n    arr [ n - 1 ] = x;\n  }\n}\n", "MAXIMUM_POSSIBLE_DIFFERENCE_TWO_SUBSETS_ARRAY": "int maxDiff ( int arr [ ], int n ) {\n  int SubsetSum_1 = 0, SubsetSum_2 = 0;\n  for ( int i = 0;\n  i <= n - 1;\n  i ++ ) {\n    bool isSingleOccurance = true;\n    for ( int j = i + 1;\n    j <= n - 1;\n    j ++ ) {\n      if ( arr [ i ] == arr [ j ] ) {\n        isSingleOccurance = false;\n        arr [ i ] = arr [ j ] = 0;\n        break;\n      }\n    }\n    if ( isSingleOccurance ) {\n      if ( arr [ i ] > 0 ) SubsetSum_1 += arr [ i ];\n      else SubsetSum_2 += arr [ i ];\n    }\n  }\n  return abs ( SubsetSum_1 - SubsetSum_2 );\n}\n", "LONGEST_SUBSEQUENCE_DIFFERENCE_ADJACENTS_ONE_SET_2": "int longLenSub ( int arr [ ], int n ) {\n  unordered_map < int, int > um;\n  int longLen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int len = 0;\n    if ( um . find ( arr [ i ] - 1 ) != um . end ( ) && len < um [ arr [ i ] - 1 ] ) len = um [ arr [ i ] - 1 ];\n    if ( um . find ( arr [ i ] + 1 ) != um . end ( ) && len < um [ arr [ i ] + 1 ] ) len = um [ arr [ i ] + 1 ];\n    um [ arr [ i ] ] = len + 1;\n    if ( longLen < um [ arr [ i ] ] ) longLen = um [ arr [ i ] ];\n  }\n  return longLen;\n}\n", "LONGEST_REPEATED_SUBSEQUENCE_1": "string longestRepeatedSubSeq ( string str ) {\n  int n = str . length ( );\n  int dp [ n + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) for ( int j = 0;\n  j <= n;\n  j ++ ) dp [ i ] [ j ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= n;\n  j ++ ) if ( str [ i - 1 ] == str [ j - 1 ] && i != j ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ];\n  else dp [ i ] [ j ] = max ( dp [ i ] [ j - 1 ], dp [ i - 1 ] [ j ] );\n  string res = \"\";\n  int i = n, j = n;\n  while ( i > 0 && j > 0 ) {\n    if ( dp [ i ] [ j ] == dp [ i - 1 ] [ j - 1 ] + 1 ) {\n      res = res + str [ i - 1 ];\n      i --;\n      j --;\n    }\n    else if ( dp [ i ] [ j ] == dp [ i - 1 ] [ j ] ) i --;\n    else j --;\n  }\n  reverse ( res . begin ( ), res . end ( ) );\n  return res;\n}\n", "FIND_INDEX_MAXIMUM_OCCURRING_ELEMENT_EQUAL_PROBABILITY": "void findRandomIndexOfMax ( int arr [ ], int n ) {\n  unordered_map < int, int > freq;\n  for ( int i = 0;\n  i < n;\n  i ++ ) freq [ arr [ i ] ] += 1;\n  int max_element;\n  int max_so_far = INT_MIN;\n  for ( pair < int, int > p : freq ) {\n    if ( p . second > max_so_far ) {\n      max_so_far = p . second;\n      max_element = p . first;\n    }\n  }\n  int r = ( rand ( ) % max_so_far ) + 1;\n  for ( int i = 0, count = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == max_element ) count ++;\n    if ( count == r ) {\n      cout << \"Element with maximum frequency present \" \"at index \" << i << endl;\n      break;\n    }\n  }\n}\n", "CHECK_NUMBER_IS_PERFECT_SQUARE_USING_ADDITIONSUBTRACTION": "bool isPerfectSquare ( int n ) {\n  for ( int sum = 0, i = 1;\n  sum < n;\n  i += 2 ) {\n    sum += i;\n    if ( sum == n ) return true;\n  }\n  return false;\n}\n", "N_BONACCI_NUMBERS_1": "void bonacciseries ( long n, int m ) {\n  int a [ m ] = {\n    0 };\n    a [ n - 1 ] = 1;\n    a [ n ] = 1;\n    for ( int i = n + 1;\n    i < m;\n    i ++ ) a [ i ] = 2 * a [ i - 1 ] - a [ i - n - 1 ];\n    for ( int i = 0;\n    i < m;\n    i ++ ) cout << a [ i ] << \" \";\n  }\n  ", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY_1": "int countPairs ( int arr [ ], int n ) {\n  unordered_map < int, int > mp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mp [ arr [ i ] ] ++;\n  int ans = 0;\n  for ( auto it = mp . begin ( );\n  it != mp . end ( );\n  it ++ ) {\n    int count = it -> second;\n    ans += ( count * ( count - 1 ) ) / 2;\n  }\n  return ans;\n}\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER": "void bitonicGenerator ( int arr [ ], int n ) {\n  vector < int > evenArr;\n  vector < int > oddArr;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ! ( i % 2 ) ) evenArr . push_back ( arr [ i ] );\n    else oddArr . push_back ( arr [ i ] );\n  }\n  sort ( evenArr . begin ( ), evenArr . end ( ) );\n  sort ( oddArr . begin ( ), oddArr . end ( ), greater < int > ( ) );\n  int i = 0;\n  for ( int j = 0;\n  j < evenArr . size ( );\n  j ++ ) arr [ i ++ ] = evenArr [ j ];\n  for ( int j = 0;\n  j < oddArr . size ( );\n  j ++ ) arr [ i ++ ] = oddArr [ j ];\n}\n", "DYNAMIC_PROGRAMMING_SET_9_BINOMIAL_COEFFICIENT": "int binomialCoeff ( int n, int k ) {\n  if ( k == 0 || k == n ) return 1;\n  return binomialCoeff ( n - 1, k - 1 ) + binomialCoeff ( n - 1, k );\n}\n", "WRITE_A_C_PROGRAM_TO_FIND_THE_PARITY_OF_AN_UNSIGNED_INTEGER": "bool getParity ( unsigned int n ) {\n  bool parity = 0;\n  while ( n ) {\n    parity = ! parity;\n    n = n & ( n - 1 );\n  }\n  return parity;\n}\n", "CHECK_WHETHER_LARGE_NUMBER_DIVISIBLE_7": "int isdivisible7 ( char num [ ] ) {\n  int n = strlen ( num ), gSum;\n  if ( n == 0 && num [ 0 ] == '\\n' ) return 1;\n  if ( n % 3 == 1 ) {\n    strcat ( num, \"00\" );\n    n += 2;\n  }\n  else if ( n % 3 == 2 ) {\n    strcat ( num, \"0\" );\n    n ++;\n  }\n  int i, GSum = 0, p = 1;\n  for ( i = n - 1;\n  i >= 0;\n  i -- ) {\n    int group = 0;\n    group += num [ i -- ] - '0';\n    group += ( num [ i -- ] - '0' ) * 10;\n    group += ( num [ i ] - '0' ) * 100;\n    gSum = gSum + group * p;\n    p *= ( - 1 );\n  }\n  return ( gSum % 7 == 0 );\n}\n", "PRODUCT_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING": "int productAtKthLevel ( string tree, int k ) {\n  int level = - 1;\n  int product = 1;\n  int n = tree . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( tree [ i ] == '(' ) level ++;\n    else if ( tree [ i ] == ')' ) level --;\n    else {\n      if ( level == k ) product *= ( tree [ i ] - '0' );\n    }\n  }\n  return product;\n}\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD": "bool isEven ( int n ) {\n  return ( n % 2 == 0 );\n}\n", "COUNT_GROUPINGS_NUMBER_SUM_DIGITS_EVERY_SUB_GROUP_LESS_EQUALS_IMMEDIATE_RIGHT_SUB_GROUP": "int countGroups ( int position, int previous_sum, int length, char * num ) {\n  if ( position == length ) return 1;\n  int res = 0;\n  int sum = 0;\n  for ( int i = position;\n  i < length;\n  i ++ ) {\n    sum += ( num [ i ] - '0' );\n    if ( sum >= previous_sum ) res += countGroups ( i + 1, sum, length, num );\n  }\n  return res;\n}\n", "FIND_THE_ELEMENT_THAT_ODD_NUMBER_OF_TIMES_IN_OLOG_N_TIME": "void search ( int * arr, int low, int high ) {\n  if ( low > high ) return;\n  if ( low == high ) {\n    printf ( \"The required element is %d \", arr [ low ] );\n    return;\n  }\n  int mid = ( low + high ) / 2;\n  if ( mid % 2 == 0 ) {\n    if ( arr [ mid ] == arr [ mid + 1 ] ) search ( arr, mid + 2, high );\n    else search ( arr, low, mid );\n  }\n  else {\n    if ( arr [ mid ] == arr [ mid - 1 ] ) search ( arr, mid + 1, high );\n    else search ( arr, low, mid - 1 );\n  }\n}\n", "DELETE_CONSECUTIVE_WORDS_SEQUENCE_1": "int removeConsecutiveSame ( vector < string > v ) {\n  stack < string > st;\n  for ( int i = 0;\n  i < v . size ( );\n  i ++ ) {\n    if ( st . empty ( ) ) st . push ( v [ i ] );\n    else {\n      string str = st . top ( );\n      if ( str . compare ( v [ i ] ) == 0 ) st . pop ( );\n      else st . push ( v [ i ] );\n    }\n  }\n  return st . size ( );\n}\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY_2": "int minJumps ( int arr [ ], int n ) {\n  int * jumps = new int [ n ];\n  int min;\n  jumps [ n - 1 ] = 0;\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( arr [ i ] == 0 ) jumps [ i ] = INT_MAX;\n    else if ( arr [ i ] >= n - i - 1 ) jumps [ i ] = 1;\n    else {\n      min = INT_MAX;\n      for ( int j = i + 1;\n      j < n && j <= arr [ i ] + i;\n      j ++ ) {\n        if ( min > jumps [ j ] ) min = jumps [ j ];\n      }\n      if ( min != INT_MAX ) jumps [ i ] = min + 1;\n      else jumps [ i ] = min;\n    }\n  }\n  return jumps [ 0 ];\n}\n", "PROGRAM_FIND_GCD_FLOATING_POINT_NUMBERS": "double gcd ( double a, double b ) {\n  if ( a < b ) return gcd ( b, a );\n  if ( fabs ( b ) < 0.001 ) return a;\n  else return ( gcd ( b, a - floor ( a / b ) * b ) );\n}\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_TWICE": "int maxProfit ( int price [ ], int n ) {\n  int * profit = new int [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) profit [ i ] = 0;\n  int max_price = price [ n - 1 ];\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( price [ i ] > max_price ) max_price = price [ i ];\n    profit [ i ] = max ( profit [ i + 1 ], max_price - price [ i ] );\n  }\n  int min_price = price [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( price [ i ] < min_price ) min_price = price [ i ];\n    profit [ i ] = max ( profit [ i - 1 ], profit [ i ] + ( price [ i ] - min_price ) );\n  }\n  int result = profit [ n - 1 ];\n  delete [ ] profit;\n  return result;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_1": "int countSetBits ( int n ) {\n  if ( n == 0 ) return 0;\n  else return ( n & 1 ) + countSetBits ( n >> 1 );\n}\n", "REORDER_A_ARRAY_ACCORDING_TO_GIVEN_INDEXES": "void reorder ( int arr [ ], int index [ ], int n ) {\n  int temp [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) temp [ index [ i ] ] = arr [ i ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    arr [ i ] = temp [ i ];\n    index [ i ] = i;\n  }\n}\n", "CHECK_IF_A_GIVEN_ARRAY_CAN_REPRESENT_PREORDER_TRAVERSAL_OF_BINARY_SEARCH_TREE": "bool canRepresentBST ( int pre [ ], int n ) {\n  stack < int > s;\n  int root = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( pre [ i ] < root ) return false;\n    while ( ! s . empty ( ) && s . top ( ) < pre [ i ] ) {\n      root = s . top ( );\n      s . pop ( );\n    }\n    s . push ( pre [ i ] );\n  }\n  return true;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_3": "int findRepeating ( int arr [ ], int n ) {\n  int missingElement = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int element = arr [ abs ( arr [ i ] ) ];\n    if ( element < 0 ) {\n      missingElement = arr [ i ];\n      break;\n    }\n    arr [ abs ( arr [ i ] ) ] = - arr [ abs ( arr [ i ] ) ];\n  }\n  return abs ( missingElement );\n}\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION_1": "int MatrixChainOrder ( int p [ ], int n ) {\n  int m [ n ] [ n ];\n  int i, j, k, L, q;\n  for ( i = 1;\n  i < n;\n  i ++ ) m [ i ] [ i ] = 0;\n  for ( L = 2;\n  L < n;\n  L ++ ) {\n    for ( i = 1;\n    i < n - L + 1;\n    i ++ ) {\n      j = i + L - 1;\n      m [ i ] [ j ] = INT_MAX;\n      for ( k = i;\n      k <= j - 1;\n      k ++ ) {\n        q = m [ i ] [ k ] + m [ k + 1 ] [ j ] + p [ i - 1 ] * p [ k ] * p [ j ];\n        if ( q < m [ i ] [ j ] ) m [ i ] [ j ] = q;\n      }\n    }\n  }\n  return m [ 1 ] [ n - 1 ];\n}\n", "COUNT_NUMBER_ISLANDS_EVERY_ISLAND_SEPARATED_LINE": "int countIslands ( int mat [ ] [ N ] ) {\n  int count = 0;\n  for ( int i = 0;\n  i < M;\n  i ++ ) {\n    for ( int j = 0;\n    j < N;\n    j ++ ) {\n      if ( mat [ i ] [ j ] == 'X' ) {\n        if ( ( i == 0 || mat [ i - 1 ] [ j ] == 'O' ) && ( j == 0 || mat [ i ] [ j - 1 ] == 'O' ) ) count ++;\n      }\n    }\n  }\n  return count;\n}\n", "MINIMIZE_MAXAI_BJ_CK_MINAI_BJ_CK_THREE_DIFFERENT_SORTED_ARRAYS": "int solve ( int A [ ], int B [ ], int C [ ], int i, int j, int k ) {\n  int min_diff, current_diff, max_term;\n  min_diff = abs ( max ( A [ i ], max ( B [ j ], C [ k ] ) ) - min ( A [ i ], min ( B [ j ], C [ k ] ) ) );\n  while ( i != - 1 && j != - 1 && k != - 1 ) {\n    current_diff = abs ( max ( A [ i ], max ( B [ j ], C [ k ] ) ) - min ( A [ i ], min ( B [ j ], C [ k ] ) ) );\n    if ( current_diff < min_diff ) min_diff = current_diff;\n    max_term = max ( A [ i ], max ( B [ j ], C [ k ] ) );\n    if ( A [ i ] == max_term ) i -= 1;\n    else if ( B [ j ] == max_term ) j -= 1;\n    else k -= 1;\n  }\n  return min_diff;\n}\n", "ROOTS_QUADRATIC_EQUATION": "void findRoots ( int a, int b, int c ) {\n  if ( a == 0 ) {\n    cout << \"Invalid\";\n    return;\n  }\n  int d = b * b - 4 * a * c;\n  double sqrt_val = sqrt ( abs ( d ) );\n  if ( d > 0 ) {\n    cout << \"Roots are real and different \\n\";\n    cout << ( double ) ( - b + sqrt_val ) / ( 2 * a ) << \"\\n\" << ( double ) ( - b - sqrt_val ) / ( 2 * a );\n  }\n  else if ( d == 0 ) {\n    cout << \"Roots are real and same \\n\";\n    cout << - ( double ) b / ( 2 * a );\n  }\n  else {\n    cout << \"Roots are complex \\n\";\n    cout << - ( double ) b / ( 2 * a ) << \" + i\" << sqrt_val << \"\\n\" << - ( double ) b / ( 2 * a ) << \" - i\" << sqrt_val;\n  }\n}\n", "GIVEN_LEVEL_ORDER_TRAVERSAL_BINARY_TREE_CHECK_TREE_MIN_HEAP": "bool isMinHeap ( int level [ ], int n ) {\n  for ( int i = ( n / 2 - 1 );\n  i >= 0;\n  i -- ) {\n    if ( level [ i ] > level [ 2 * i + 1 ] ) return false;\n    if ( 2 * i + 2 < n ) {\n      if ( level [ i ] > level [ 2 * i + 2 ] ) return false;\n    }\n  }\n  return true;\n}\n", "FIND_MINIMUM_ELEMENT_IN_A_SORTED_AND_ROTATED_ARRAY": "int findMin ( int arr [ ], int low, int high ) {\n  if ( high < low ) return arr [ 0 ];\n  if ( high == low ) return arr [ low ];\n  int mid = low + ( high - low ) / 2;\n  if ( mid < high && arr [ mid + 1 ] < arr [ mid ] ) return arr [ mid + 1 ];\n  if ( mid > low && arr [ mid ] < arr [ mid - 1 ] ) return arr [ mid ];\n  if ( arr [ high ] > arr [ mid ] ) return findMin ( arr, low, mid - 1 );\n  return findMin ( arr, mid + 1, high );\n}\n", "SMALLEST_LENGTH_STRING_WITH_REPEATED_REPLACEMENT_OF_TWO_DISTINCT_ADJACENT": "int stringReduction ( string str ) {\n  int n = str . length ( );\n  int count [ 3 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    ++ i ) count [ str [ i ] - 'a' ] ++;\n    if ( count [ 0 ] == n || count [ 1 ] == n || count [ 2 ] == n ) return n;\n    if ( ( count [ 0 ] % 2 ) == ( count [ 1 ] % 2 ) && ( count [ 1 ] % 2 ) == ( count [ 2 ] % 2 ) ) return 2;\n    return 1;\n  }\n  ", "CHECK_LARGE_NUMBER_DIVISIBLE_3_NOT": "int check ( string str ) {\n  int n = str . length ( );\n  int digitSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) digitSum += ( str [ i ] - '0' );\n  return ( digitSum % 3 == 0 );\n}\n", "COMPUTE_N_UNDER_MODULO_P": "int modFact ( int n, int p ) {\n  if ( n >= p ) return 0;\n  int result = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) result = ( result * i ) % p;\n  return result;\n}\n", "POSSIBILITY_OF_A_WORD_FROM_A_GIVEN_SET_OF_CHARACTERS": "bool isPresent ( string s, string q ) {\n  int freq [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < s . length ( );\n    i ++ ) freq [ s [ i ] ] ++;\n    for ( int i = 0;\n    i < q . length ( );\n    i ++ ) {\n      freq [ q [ i ] ] --;\n      if ( freq [ q [ i ] ] < 0 ) return false;\n    }\n    return true;\n  }\n  ", "NEXT_POWER_OF_2_1": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  unsigned int p = 1;\n  if ( n && ! ( n & ( n - 1 ) ) ) return n;\n  while ( p < n ) p <<= 1;\n  return p;\n}\n", "REORDER_A_ARRAY_ACCORDING_TO_GIVEN_INDEXES_1": "void reorder ( int arr [ ], int index [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( index [ i ] != i ) {\n      int oldTargetI = index [ index [ i ] ];\n      char 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    }\n  }\n}\n", "UNBOUNDED_KNAPSACK_REPETITION_ITEMS_ALLOWED": "int unboundedKnapsack ( int W, int n, int val [ ], int wt [ ] ) {\n  int dp [ W + 1 ];\n  memset ( dp, 0, sizeof dp );\n  int ans = 0;\n  for ( int i = 0;\n  i <= W;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) if ( wt [ j ] <= i ) dp [ i ] = max ( dp [ i ], dp [ i - wt [ j ] ] + val [ j ] );\n  return dp [ W ];\n}\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX": "bool isDiagonalMatrix ( int mat [ N ] [ N ] ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < N;\n  j ++ ) if ( ( i != j ) && ( mat [ i ] [ j ] != 0 ) ) return false;\n  return true;\n}\n", "MAXIMUM_REMOVAL_FROM_ARRAY_WHEN_REMOVAL_TIME_WAITING_TIME": "int maxRemoval ( int arr [ ], int n ) {\n  int count = 0;\n  int cummulative_sum = 0;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] >= cummulative_sum ) {\n      count ++;\n      cummulative_sum += arr [ i ];\n    }\n  }\n  return count;\n}\n", "PROGRAM_CENSOR_WORD_ASTERISKS_SENTENCE": "string censor ( string text, string word ) {\n  vector < string > word_list;\n  boost :: split ( word_list, text, boost :: is_any_of ( \"\\\\ +\" ) );\n  string result = \"\";\n  string stars = \"\";\n  for ( int i = 0;\n  i < word . size ( );\n  i ++ ) stars += '*';\n  int index = 0;\n  for ( string i : word_list ) {\n    if ( i . compare ( word ) == 0 ) {\n      word_list [ index ] = stars;\n    }\n    index ++;\n  }\n  for ( string i : word_list ) {\n    result += i + ' ';\n  }\n  return result;\n}\n", "COUNT_STRINGS_WITH_CONSECUTIVE_1S": "int countStrings ( int n ) {\n  int a [ n ], b [ n ];\n  a [ 0 ] = b [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    a [ i ] = a [ i - 1 ] + b [ i - 1 ];\n    b [ i ] = a [ i - 1 ];\n  }\n  return ( 1 << n ) - a [ n - 1 ] - b [ n - 1 ];\n}\n", "LENGTH_LONGEST_BALANCED_SUBSEQUENCE": "int maxLength ( char s [ ], int n ) {\n  int dp [ n ] [ n ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) if ( s [ i ] == '(' && s [ i + 1 ] == ')' ) dp [ i ] [ i + 1 ] = 2;\n  for ( int l = 2;\n  l < n;\n  l ++ ) {\n    for ( int i = 0, j = l;\n    j < n;\n    i ++, j ++ ) {\n      if ( s [ i ] == '(' && s [ j ] == ')' ) dp [ i ] [ j ] = 2 + dp [ i + 1 ] [ j - 1 ];\n      for ( int k = i;\n      k < j;\n      k ++ ) dp [ i ] [ j ] = max ( dp [ i ] [ j ], dp [ i ] [ k ] + dp [ k + 1 ] [ j ] );\n    }\n  }\n  return dp [ 0 ] [ n - 1 ];\n}\n", "FIND_THE_POINT_WHERE_MAXIMUM_INTERVALS_OVERLAP": "void findMaxGuests ( int arrl [ ], int exit [ ], int n ) {\n  sort ( arrl, arrl + n );\n  sort ( exit, exit + n );\n  int guests_in = 1, max_guests = 1, time = arrl [ 0 ];\n  int i = 1, j = 0;\n  while ( i < n && j < n ) {\n    if ( arrl [ i ] <= exit [ j ] ) {\n      guests_in ++;\n      if ( guests_in > max_guests ) {\n        max_guests = guests_in;\n        time = arrl [ i ];\n      }\n      i ++;\n    }\n    else {\n      guests_in --;\n      j ++;\n    }\n  }\n  cout << \"Maximum Number of Guests = \" << max_guests << \" at time \" << time;\n}\n", "EFFICIENT_WAY_CHECK_WHETHER_N_TH_FIBONACCI_NUMBER_MULTIPLE_10": "bool isMultipleOf10 ( int n ) {\n  return ( n % 15 == 0 );\n}\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE": "int maxSumPairWithDifferenceLessThanK ( int arr [ ], int N, int K ) {\n  sort ( arr, arr + N );\n  int dp [ N ];\n  dp [ 0 ] = 0;\n  for ( int i = 1;\n  i < N;\n  i ++ ) {\n    dp [ i ] = dp [ i - 1 ];\n    if ( arr [ i ] - arr [ i - 1 ] < K ) {\n      if ( i >= 2 ) dp [ i ] = max ( dp [ i ], dp [ i - 2 ] + arr [ i ] + arr [ i - 1 ] );\n      else dp [ i ] = max ( dp [ i ], arr [ i ] + arr [ i - 1 ] );\n    }\n  }\n  return dp [ N - 1 ];\n}\n", "FIND_K_PAIRS_SMALLEST_SUMS_TWO_ARRAYS": "void kSmallestPair ( int arr1 [ ], int n1, int arr2 [ ], int n2, int k ) {\n  if ( k > n1 * n2 ) {\n    cout << \"k pairs don't exist\";\n    return;\n  }\n  int index2 [ n1 ];\n  memset ( index2, 0, sizeof ( index2 ) );\n  while ( k > 0 ) {\n    int min_sum = INT_MAX;\n    int min_index = 0;\n    for ( int i1 = 0;\n    i1 < n1;\n    i1 ++ ) {\n      if ( index2 [ i1 ] < n2 && arr1 [ i1 ] + arr2 [ index2 [ i1 ] ] < min_sum ) {\n        min_index = i1;\n        min_sum = arr1 [ i1 ] + arr2 [ index2 [ i1 ] ];\n      }\n    }\n    cout << \"(\" << arr1 [ min_index ] << \", \" << arr2 [ index2 [ min_index ] ] << \") \";\n    index2 [ min_index ] ++;\n    k --;\n  }\n}\n", "FIRST_UPPERCASE_LETTER_IN_A_STRING_ITERATIVE_AND_RECURSIVE_1": "char first ( string str, int i = 0 ) {\n  if ( str [ i ] == '\\0' ) return 0;\n  if ( isupper ( str [ i ] ) ) return str [ i ];\n  return first ( str, i + 1 );\n}\n", "FIND_PAIRS_B_ARRAY_B_K": "bool printPairs ( int arr [ ], int n, int k ) {\n  bool isPairFound = true;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( i != j && arr [ i ] % arr [ j ] == k ) {\n        cout << \"(\" << arr [ i ] << \", \" << arr [ j ] << \")\" << \" \";\n        isPairFound = true;\n      }\n    }\n  }\n  return isPairFound;\n}\n", "FIND_ARRANGEMENT_QUEUE_GIVEN_TIME": "void solve ( int n, int t, string s ) {\n  for ( int i = 0;\n  i < t;\n  i ++ ) for ( int j = 0;\n  j < n - 1;\n  j ++ ) if ( s [ j ] == 'B' && s [ j + 1 ] == 'G' ) {\n    char temp = s [ j ];\n    s [ j ] = s [ j + 1 ];\n    s [ j + 1 ] = temp;\n    j ++;\n  }\n  cout << s;\n}\n", "SHORTEST_POSSIBLE_COMBINATION_TWO_STRINGS": "void printSuperSeq ( string & a, string & b ) {\n  int m = a . length ( ), n = b . length ( );\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( ! i ) dp [ i ] [ j ] = j;\n      else if ( ! j ) dp [ i ] [ j ] = i;\n      else if ( a [ i - 1 ] == b [ j - 1 ] ) 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    }\n  }\n  int index = dp [ m ] [ n ];\n  string res ( index + 1, '\\0' );\n  int i = m, j = n;\n  while ( i > 0 && j > 0 ) {\n    if ( a [ i - 1 ] == b [ j - 1 ] ) {\n      res [ index - 1 ] = a [ i - 1 ];\n      i --;\n      j --;\n      index --;\n    }\n    else if ( dp [ i - 1 ] [ j ] < dp [ i ] [ j - 1 ] ) {\n      res [ index - 1 ] = a [ i - 1 ];\n      i --;\n      index --;\n    }\n    else {\n      res [ index - 1 ] = b [ j - 1 ];\n      j --;\n      index --;\n    }\n  }\n  while ( i > 0 ) {\n    res [ index - 1 ] = a [ i - 1 ];\n    i --;\n    index --;\n  }\n  while ( j > 0 ) {\n    res [ index - 1 ] = b [ j - 1 ];\n    j --;\n    index --;\n  }\n  cout << res;\n}\n", "COUNT_ROTATIONS_DIVISIBLE_8": "int countRotationsDivBy8 ( string n ) {\n  int len = n . length ( );\n  int count = 0;\n  if ( len == 1 ) {\n    int oneDigit = n [ 0 ] - '0';\n    if ( oneDigit % 8 == 0 ) return 1;\n    return 0;\n  }\n  if ( len == 2 ) {\n    int first = ( n [ 0 ] - '0' ) * 10 + ( n [ 1 ] - '0' );\n    int second = ( n [ 1 ] - '0' ) * 10 + ( n [ 0 ] - '0' );\n    if ( first % 8 == 0 ) count ++;\n    if ( second % 8 == 0 ) count ++;\n    return count;\n  }\n  int threeDigit;\n  for ( int i = 0;\n  i < ( len - 2 );\n  i ++ ) {\n    threeDigit = ( n [ i ] - '0' ) * 100 + ( n [ i + 1 ] - '0' ) * 10 + ( n [ i + 2 ] - '0' );\n    if ( threeDigit % 8 == 0 ) count ++;\n  }\n  threeDigit = ( n [ len - 1 ] - '0' ) * 100 + ( n [ 0 ] - '0' ) * 10 + ( n [ 1 ] - '0' );\n  if ( threeDigit % 8 == 0 ) count ++;\n  threeDigit = ( n [ len - 2 ] - '0' ) * 100 + ( n [ len - 1 ] - '0' ) * 10 + ( n [ 0 ] - '0' );\n  if ( threeDigit % 8 == 0 ) count ++;\n  return count;\n}\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_AT_MOST_K_CHANGES_ALLOWED": "int lcs ( int dp [ MAX ] [ MAX ] [ MAX ], int arr1 [ ], int n, int arr2 [ ], int m, int k ) {\n  if ( k < 0 ) return - 1e7;\n  if ( n < 0 || m < 0 ) return 0;\n  int & ans = dp [ n ] [ m ] [ k ];\n  if ( ans != - 1 ) 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 ] ) ans = max ( ans, 1 + lcs ( dp, arr1, n - 1, arr2, m - 1, k ) );\n  ans = max ( ans, 1 + lcs ( dp, arr1, n - 1, arr2, m - 1, k - 1 ) );\n  return ans;\n}\n", "CHECK_LINE_TOUCHES_INTERSECTS_CIRCLE": "void checkCollision ( int a, int b, int c, int x, int y, int radius ) {\n  int dist = ( abs ( a * x + b * y + c ) ) / sqrt ( a * a + b * b );\n  if ( radius == dist ) cout << \"Touch\" << endl;\n  else if ( radius > dist ) cout << \"Intersect\" << endl;\n  else cout << \"Outside\" << endl;\n}\n", "FIND_THE_MAXIMUM_SUBARRAY_XOR_IN_A_GIVEN_ARRAY": "int maxSubarrayXOR ( int arr [ ], int n ) {\n  int ans = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int curr_xor = 0;\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      curr_xor = curr_xor ^ arr [ j ];\n      ans = max ( ans, curr_xor );\n    }\n  }\n  return ans;\n}\n", "SHORTEST_PATH_EXACTLY_K_EDGES_DIRECTED_WEIGHTED_GRAPH": "INT_MAX int shortestPath ( int graph [ ] [ V ], int u, int v, int k ) {\n  if ( k == 0 && u == v ) return 0;\n  if ( k == 1 && graph [ u ] [ v ] != INF ) return graph [ u ] [ v ];\n  if ( k <= 0 ) return INF;\n  int res = INF;\n  for ( int i = 0;\n  i < V;\n  i ++ ) {\n    if ( graph [ u ] [ i ] != INF && u != i && v != i ) {\n      int rec_res = shortestPath ( graph, i, v, k - 1 );\n      if ( rec_res != INF ) res = min ( res, graph [ u ] [ i ] + rec_res );\n    }\n  }\n  return res;\n}\n", "FIND_SUBARRAY_WITH_GIVEN_SUM": "int subArraySum ( int arr [ ], int n, int sum ) {\n  int curr_sum, i, j;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    curr_sum = arr [ i ];\n    for ( j = i + 1;\n    j <= n;\n    j ++ ) {\n      if ( curr_sum == sum ) {\n        cout << \"Sum found between indexes \" << i << \" and \" << j - 1;\n        return 1;\n      }\n      if ( curr_sum > sum || j == n ) break;\n      curr_sum = curr_sum + arr [ j ];\n    }\n  }\n  cout << \"No subarray found\";\n  return 0;\n}\n", "K_TH_PRIME_FACTOR_GIVEN_NUMBER": "int kPrimeFactor ( int n, int k ) {\n  while ( n % 2 == 0 ) {\n    k --;\n    n = n / 2;\n    if ( k == 0 ) return 2;\n  }\n  for ( int i = 3;\n  i <= sqrt ( n );\n  i = i + 2 ) {\n    while ( n % i == 0 ) {\n      if ( k == 1 ) return i;\n      k --;\n      n = n / i;\n    }\n  }\n  if ( n > 2 && k == 1 ) return n;\n  return - 1;\n}\n", "FIND_ROTATION_COUNT_ROTATED_SORTED_ARRAY_1": "int countRotations ( int arr [ ], int low, int high ) {\n  if ( high < low ) return 0;\n  if ( high == low ) return low;\n  int mid = low + ( high - low ) / 2;\n  if ( mid < high && arr [ mid + 1 ] < arr [ mid ] ) return ( mid + 1 );\n  if ( mid > low && arr [ mid ] < arr [ mid - 1 ] ) return mid;\n  if ( arr [ high ] > arr [ mid ] ) return countRotations ( arr, low, mid - 1 );\n  return countRotations ( arr, mid + 1, high );\n}\n", "COMPUTE_AVERAGE_TWO_NUMBERS_WITHOUT_OVERFLOW_1": "int compute_average ( int a, int b ) {\n  return ( a / 2 ) + ( b / 2 ) + ( ( a % 2 + b % 2 ) / 2 );\n}\n", "SORTING_USING_TRIVIAL_HASH_FUNCTION_1": "void sortUsingHash ( int a [ ], int n ) {\n  int max = * std :: max_element ( a, a + n );\n  int min = abs ( * std :: min_element ( a, a + n ) );\n  int hashpos [ max + 1 ] = {\n    0 };\n    int hashneg [ min + 1 ] = {\n      0 };\n      for ( int i = 0;\n      i < n;\n      i ++ ) {\n        if ( a [ i ] >= 0 ) hashpos [ a [ i ] ] += 1;\n        else hashneg [ abs ( a [ i ] ) ] += 1;\n      }\n      for ( int i = min;\n      i > 0;\n      i -- ) {\n        if ( hashneg [ i ] ) {\n          for ( int j = 0;\n          j < hashneg [ i ];\n          j ++ ) {\n            cout << ( - 1 ) * i << \" \";\n          }\n        }\n      }\n      for ( int i = 0;\n      i <= max;\n      i ++ ) {\n        if ( hashpos [ i ] ) {\n          for ( int j = 0;\n          j < hashpos [ i ];\n          j ++ ) {\n            cout << i << \" \";\n          }\n        }\n      }\n    }\n    ", "FIND_THE_TWO_REPEATING_ELEMENTS_IN_A_GIVEN_ARRAY_1": "void printRepeating ( int arr [ ], int size ) {\n  int * count = new int [ sizeof ( int ) * ( size - 2 ) ];\n  int i;\n  cout << \" Repeating elements are \";\n  for ( i = 0;\n  i < size;\n  i ++ ) {\n    if ( count [ arr [ i ] ] == 1 ) cout << arr [ i ] << \" \";\n    else count [ arr [ i ] ] ++;\n  }\n}\n", "MINIMUM_STEPS_MINIMIZE_N_PER_GIVEN_CONDITION": "int getMinSteps ( int n ) {\n  int table [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) table [ i ] = n - i;\n  for ( int i = n;\n  i >= 1;\n  i -- ) {\n    if ( ! ( i % 2 ) ) table [ i / 2 ] = min ( table [ i ] + 1, table [ i / 2 ] );\n    if ( ! ( i % 3 ) ) table [ i / 3 ] = min ( table [ i ] + 1, table [ i / 3 ] );\n  }\n  return table [ 1 ];\n  ", "COUNT_POSSIBLE_DECODINGS_GIVEN_DIGIT_SEQUENCE_1": "int countDecodingDP ( char * digits, int n ) {\n  int count [ n + 1 ];\n  count [ 0 ] = 1;\n  count [ 1 ] = 1;\n  if ( digits [ 0 ] == '0' ) return 0;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    count [ i ] = 0;\n    if ( digits [ i - 1 ] > '0' ) count [ i ] = count [ i - 1 ];\n    if ( digits [ i - 2 ] == '1' || ( digits [ i - 2 ] == '2' && digits [ i - 1 ] < '7' ) ) count [ i ] += count [ i - 2 ];\n  }\n  return count [ n ];\n}\n", "EULERS_FOUR_SQUARE_IDENTITY_1": "void checkEulerFourSquareIdentity ( int a, int b ) {\n  int ab = a * b;\n  bool flag = false;\n  int i = 0;\n  while ( i * i <= ab ) {\n    int j = i;\n    while ( i * i + j * j <= ab ) {\n      int k = j;\n      while ( i * i + j * j + k * k <= ab ) {\n        double l = sqrt ( ab - ( i * i + j * j + k * k ) );\n        if ( floor ( l ) == ceil ( l ) && l >= k ) {\n          flag = true;\n          cout << \"i = \" << i << \"\\n\";\n          cout << \"j = \" << j << \"\\n\";\n          cout << \"k = \" << k << \"\\n\";\n          cout << \"l = \" << ( int ) l << \"\\n\";\n          cout << \"Product of \" << a << \" and \" << b << \" can be written as sum of squares\" << \" of i, j, k, l \\n\";\n          cout << ab + \" = \" << i << \"*\" << i << \" + \" << j << \"*\" << j << \" + \" << k << \"*\" << k << \" + \" << ( int ) l << \"*\" << ( int ) l << \"\\n\";\n        }\n        k += 1;\n      }\n      j += 1;\n    }\n    i += 1;\n  }\n  if ( flag == false ) {\n    cout << \"Solution doesn't exist!\\n\";\n    return;\n  }\n}\n", "COUNT_NUMBER_INCREASING_SUBSEQUENCES_SIZE_K": "int numOfIncSubseqOfSizeK ( int arr [ ], int n, int k ) {\n  int dp [ k ] [ n ], sum = 0;\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) dp [ 0 ] [ i ] = 1;\n  for ( int l = 1;\n  l < k;\n  l ++ ) {\n    for ( int i = l;\n    i < n;\n    i ++ ) {\n      dp [ l ] [ i ] = 0;\n      for ( int j = l - 1;\n      j < i;\n      j ++ ) {\n        if ( arr [ j ] < arr [ i ] ) dp [ l ] [ i ] += dp [ l - 1 ] [ j ];\n      }\n    }\n  }\n  for ( int i = k - 1;\n  i < n;\n  i ++ ) sum += dp [ k - 1 ] [ i ];\n  return sum;\n}\n", "KNAPSACK_PROBLEM_1": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  int i, w;\n  int K [ n + 1 ] [ W + 1 ];\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( w = 0;\n    w <= W;\n    w ++ ) {\n      if ( i == 0 || w == 0 ) K [ i ] [ w ] = 0;\n      else if ( wt [ i - 1 ] <= w ) K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ], K [ i - 1 ] [ w ] );\n      else K [ i ] [ w ] = K [ i - 1 ] [ w ];\n    }\n  }\n  return K [ n ] [ W ];\n}\n", "PROGRAM_TO_PRINT_DOUBLE_HEADED_ARROW_PATTERN": "void drawPattern ( int N ) {\n  int n = N;\n  int row = 1;\n  int nst = 1;\n  int nsp1 = n - 1;\n  int nsp2 = - 1;\n  int val1 = row;\n  int val2 = 1;\n  while ( row <= n ) {\n    int csp1 = 1;\n    while ( csp1 <= nsp1 ) {\n      cout << \" \" << \" \";\n      csp1 = csp1 + 1;\n    }\n    int cst1 = 1;\n    while ( cst1 <= nst ) {\n      cout << val1 << \" \";\n      val1 = val1 - 1;\n      cst1 = cst1 + 1;\n    }\n    int csp2 = 1;\n    while ( csp2 <= nsp2 ) {\n      cout << \" \" << \" \";\n      csp2 = csp2 + 1;\n    }\n    if ( row != 1 && row != n ) {\n      int cst2 = 1;\n      while ( cst2 <= nst ) {\n        cout << val2 << \" \";\n        val2 = val2 + 1;\n        cst2 = cst2 + 1;\n      }\n    }\n    cout << endl;\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    }\n    else {\n      nst = nst - 1;\n      nsp1 = nsp1 + 2;\n      nsp2 = nsp2 - 2;\n      val1 = n - row;\n      val2 = 1;\n    }\n    row = row + 1;\n  }\n}\n", "INTEGER_POSITIVE_VALUE_POSITIVE_NEGATIVE_VALUE_ARRAY": "int findInteger ( int arr [ ], int n ) {\n  unordered_map < int, int > hash;\n  int maximum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] < 0 ) hash [ abs ( arr [ i ] ) ] -= 1;\n    else hash [ arr [ i ] ] += 1;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( hash [ arr [ i ] ] != 0 ) return arr [ i ];\n  return - 1;\n}\n", "SPACE_OPTIMIZED_SOLUTION_LCS": "int lcs ( string & X, string & Y ) {\n  int m = X . length ( ), n = Y . length ( );\n  int L [ 2 ] [ n + 1 ];\n  bool bi;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    bi = i & 1;\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( i == 0 || j == 0 ) L [ bi ] [ j ] = 0;\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) L [ bi ] [ j ] = L [ 1 - bi ] [ j - 1 ] + 1;\n      else L [ bi ] [ j ] = max ( L [ 1 - bi ] [ j ], L [ bi ] [ j - 1 ] );\n    }\n  }\n  return L [ bi ] [ n ];\n}\n", "REPRESENT_NUMBER_SUM_MINIMUM_POSSIBLE_PSUEDOBINARY_NUMBERS": "void psuedoBinary ( int n ) {\n  while ( n > 0 ) {\n    int temp = n, m = 0, p = 1;\n    while ( temp ) {\n      int rem = temp % 10;\n      temp = temp / 10;\n      if ( rem != 0 ) m += p;\n      p *= 10;\n    }\n    cout << m << \" \";\n    n = n - m;\n  }\n}\n", "FIND_NUMBER_CURRENCY_NOTES_SUM_UPTO_GIVEN_AMOUNT": "void countCurrency ( int amount ) {\n  int notes [ 9 ] = {\n    2000, 500, 200, 100, 50, 20, 10, 5, 1 };\n    int noteCounter [ 9 ] = {\n      0 };\n      for ( int i = 0;\n      i < 9;\n      i ++ ) {\n        if ( amount >= notes [ i ] ) {\n          noteCounter [ i ] = amount / notes [ i ];\n          amount = amount - noteCounter [ i ] * notes [ i ];\n        }\n      }\n      cout << \"Currency Count ->\" << endl;\n      for ( int i = 0;\n      i < 9;\n      i ++ ) {\n        if ( noteCounter [ i ] != 0 ) {\n          cout << notes [ i ] << \" : \" << noteCounter [ i ] << endl;\n        }\n      }\n    }\n    ", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS": "void rearrange ( int a [ ], int size ) {\n  int positive = 0, negative = 1;\n  while ( true ) {\n    while ( positive < size && a [ positive ] >= 0 ) positive += 2;\n    while ( negative < size && a [ negative ] <= 0 ) negative += 2;\n    if ( positive < size && negative < size ) swap ( a [ positive ], a [ negative ] );\n    else break;\n  }\n}\n", "FIND_WHETHER_AN_ARRAY_IS_SUBSET_OF_ANOTHER_ARRAY_SET_1": "bool isSubset ( int arr1 [ ], int arr2 [ ], int m, int n ) {\n  int i = 0;\n  int j = 0;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    for ( j = 0;\n    j < m;\n    j ++ ) {\n      if ( arr2 [ i ] == arr1 [ j ] ) break;\n    }\n    if ( j == m ) return 0;\n  }\n  return 1;\n}\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM": "bool pairInSortedRotated ( int arr [ ], int n, int x ) {\n  int i;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) if ( arr [ i ] > arr [ i + 1 ] ) break;\n  int l = ( i + 1 ) % n;\n  int r = i;\n  while ( l != r ) {\n    if ( arr [ l ] + arr [ r ] == x ) return true;\n    if ( arr [ l ] + arr [ r ] < x ) l = ( l + 1 ) % n;\n    else r = ( n + r - 1 ) % n;\n  }\n  return false;\n}\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR_1": "int getRemainder ( int num, int divisor ) {\n  if ( divisor == 0 ) {\n    cout << \"Error: divisor can't be zero \\n\";\n    return - 1;\n  }\n  if ( divisor < 0 ) divisor = - divisor;\n  if ( num < 0 ) num = - num;\n  int i = 1;\n  int product = 0;\n  while ( product <= num ) {\n    product = divisor * i;\n    i ++;\n  }\n  return num - ( product - divisor );\n}\n", "GNOME_SORT_A_STUPID_ONE": "void gnomeSort ( int arr [ ], int n ) {\n  int index = 0;\n  while ( index < n ) {\n    if ( index == 0 ) index ++;\n    if ( arr [ index ] >= arr [ index - 1 ] ) index ++;\n    else {\n      swap ( arr [ index ], arr [ index - 1 ] );\n      index --;\n    }\n  }\n  return;\n}\n", "NUMBER_WAYS_INSERT_CHARACTER_INCREASE_LCS_ONE": "int numberofways ( string A, string B, int N, int M ) {\n  vector < int > pos [ MAX ];\n  for ( int i = 0;\n  i < M;\n  i ++ ) pos [ B [ i ] ] . push_back ( i + 1 );\n  int dpl [ N + 2 ] [ M + 2 ];\n  memset ( dpl, 0, sizeof ( dpl ) );\n  for ( int i = 1;\n  i <= N;\n  i ++ ) {\n    for ( int j = 1;\n    j <= M;\n    j ++ ) {\n      if ( A [ i - 1 ] == B [ j - 1 ] ) dpl [ i ] [ j ] = dpl [ i - 1 ] [ j - 1 ] + 1;\n      else dpl [ i ] [ j ] = max ( dpl [ i - 1 ] [ j ], dpl [ i ] [ j - 1 ] );\n    }\n  }\n  int LCS = dpl [ N ] [ M ];\n  int dpr [ N + 2 ] [ M + 2 ];\n  memset ( dpr, 0, sizeof ( dpr ) );\n  for ( int i = N;\n  i >= 1;\n  i -- ) {\n    for ( int j = M;\n    j >= 1;\n    j -- ) {\n      if ( A [ i - 1 ] == B [ j - 1 ] ) dpr [ i ] [ j ] = dpr [ i + 1 ] [ j + 1 ] + 1;\n      else dpr [ i ] [ j ] = max ( dpr [ i + 1 ] [ j ], dpr [ i ] [ j + 1 ] );\n    }\n  }\n  int ans = 0;\n  for ( int i = 0;\n  i <= N;\n  i ++ ) {\n    for ( int j = 0;\n    j < MAX;\n    j ++ ) {\n      for ( auto x : pos [ j ] ) {\n        if ( dpl [ i ] [ x - 1 ] + dpr [ i + 1 ] [ x + 1 ] == LCS ) {\n          ans ++;\n          break;\n        }\n      }\n    }\n  }\n  return ans;\n}\n", "MINIMUM_PRODUCT_K_INTEGERS_ARRAY_POSITIVE_INTEGERS": "int minProduct ( int arr [ ], int n, int k ) {\n  priority_queue < int, vector < int >, greater < int > > pq;\n  for ( int i = 0;\n  i < n;\n  i ++ ) pq . push ( arr [ i ] );\n  int count = 0, ans = 1;\n  while ( pq . empty ( ) == false && count < k ) {\n    ans = ans * pq . top ( );\n    pq . pop ( );\n    count ++;\n  }\n  return ans;\n}\n", "FIND_UNIQUE_ELEMENTS_MATRIX": "int unique ( int mat [ R ] [ C ], int n, int m ) {\n  int maximum = 0, flag = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) if ( maximum < mat [ i ] [ j ] ) maximum = mat [ i ] [ j ];\n  int b [ maximum + 1 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) for ( int j = 0;\n    j < m;\n    j ++ ) b [ mat [ i ] [ j ] ] ++;\n    for ( int i = 1;\n    i <= maximum;\n    i ++ ) if ( b [ i ] == 1 ) cout << i << \" \";\n    flag = 1;\n    if ( ! flag ) {\n      cout << \"No unique element in the matrix\";\n    }\n  }\n  ", "LONGEST_SUBSEQUENCE_SUCH_THAT_DIFFERENCE_BETWEEN_ADJACENTS_IS_ONE": "int longestSubseqWithDiffOne ( int arr [ ], int n ) {\n  int dp [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) dp [ i ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < i;\n    j ++ ) {\n      if ( ( arr [ i ] == arr [ j ] + 1 ) || ( arr [ i ] == arr [ j ] - 1 ) ) dp [ i ] = max ( dp [ i ], dp [ j ] + 1 );\n    }\n  }\n  int result = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( result < dp [ i ] ) result = dp [ i ];\n  return result;\n}\n", "C_PROGRAM_CONCATENATE_STRING_GIVEN_NUMBER_TIMES": "string repeat ( string s, int n ) {\n  string s1 = s;\n  for ( int i = 1;\n  i < n;\n  i ++ ) s += s1;\n  return s;\n}\n", "SEARCHING_FOR_PATTERNS_SET_1_NAIVE_PATTERN_SEARCHING": "void search ( char * pat, char * txt ) {\n  int M = strlen ( pat );\n  int N = strlen ( txt );\n  for ( int i = 0;\n  i <= N - M;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < M;\n    j ++ ) if ( txt [ i + j ] != pat [ j ] ) break;\n    if ( j == M ) cout << \"Pattern found at index \" << i << endl;\n  }\n}\n", "COUNT_POSSIBLE_PATHS_SOURCE_DESTINATION_EXACTLY_K_EDGES": "int countwalks ( int graph [ ] [ V ], int u, int v, int k ) {\n  if ( k == 0 && u == v ) return 1;\n  if ( k == 1 && graph [ u ] [ v ] ) return 1;\n  if ( k <= 0 ) return 0;\n  int count = 0;\n  for ( int i = 0;\n  i < V;\n  i ++ ) if ( graph [ u ] [ i ] == 1 ) count += countwalks ( graph, i, v, k - 1 );\n  return count;\n}\n", "COUNT_DIVISIBLE_PAIRS_ARRAY": "int countDivisibles ( int arr [ ], int n ) {\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( arr [ i ] % arr [ j ] == 0 || arr [ j ] % arr [ i ] == 0 ) res ++;\n  return res;\n}\n", "PROGRAM_TO_CHECK_IF_A_MATRIX_IS_SYMMETRIC": "bool isSymmetric ( int mat [ ] [ MAX ], int N ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < N;\n  j ++ ) if ( mat [ i ] [ j ] != mat [ j ] [ i ] ) return false;\n  return true;\n}\n", "COUNT_PALINDROME_SUB_STRINGS_STRING": "int CountPS ( char str [ ], int n ) {\n  int dp [ n ] [ n ];\n  memset ( dp, 0, sizeof ( dp ) );\n  bool P [ n ] [ n ];\n  memset ( P, false, sizeof ( P ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) P [ i ] [ i ] = true;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( str [ i ] == str [ i + 1 ] ) {\n      P [ i ] [ i + 1 ] = true;\n      dp [ i ] [ i + 1 ] = 1;\n    }\n  }\n  for ( int gap = 2;\n  gap < n;\n  gap ++ ) {\n    for ( int i = 0;\n    i < n - gap;\n    i ++ ) {\n      int j = gap + i;\n      if ( str [ i ] == str [ j ] && P [ i + 1 ] [ j - 1 ] ) P [ i ] [ j ] = true;\n      if ( P [ i ] [ j ] == true ) dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i + 1 ] [ j ] + 1 - dp [ i + 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i + 1 ] [ j ] - dp [ i + 1 ] [ j - 1 ];\n    }\n  }\n  return dp [ 0 ] [ n - 1 ];\n}\n", "WAYS_SUM_N_USING_ARRAY_ELEMENTS_REPETITION_ALLOWED": "int countWays ( int arr [ ], int m, int N ) {\n  int count [ N + 1 ];\n  memset ( count, 0, sizeof ( count ) );\n  count [ 0 ] = 1;\n  for ( int i = 1;\n  i <= N;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) if ( i >= arr [ j ] ) count [ i ] += count [ i - arr [ j ] ];\n  return count [ N ];\n}\n", "MINIMUM_NUMBER_OF_OPERATIONS_TO_MOVE_ALL_UPPERCASE_CHARACTERS_BEFORE_ALL_LOWER_CASE_CHARACTERS": "int minOperations ( string str, int n ) {\n  int i, lastUpper = - 1, firstLower = - 1;\n  for ( i = n - 1;\n  i >= 0;\n  i -- ) {\n    if ( isupper ( str [ i ] ) ) {\n      lastUpper = i;\n      break;\n    }\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( islower ( str [ i ] ) ) {\n      firstLower = i;\n      break;\n    }\n  }\n  if ( lastUpper == - 1 || firstLower == - 1 ) return 0;\n  int countUpper = 0;\n  for ( i = firstLower;\n  i < n;\n  i ++ ) {\n    if ( isupper ( str [ i ] ) ) {\n      countUpper ++;\n    }\n  }\n  int countLower = 0;\n  for ( i = 0;\n  i < lastUpper;\n  i ++ ) {\n    if ( islower ( str [ i ] ) ) {\n      countLower ++;\n    }\n  }\n  return min ( countLower, countUpper );\n}\n", "PRINT_A_GIVEN_MATRIX_IN_SPIRAL_FORM": "void spiralPrint ( int m, int n, int a [ R ] [ C ] ) {\n  int i, k = 0, l = 0;\n  while ( k < m && l < n ) {\n    for ( i = l;\n    i < n;\n    ++ i ) {\n      cout << a [ k ] [ i ] << \" \";\n    }\n    k ++;\n    for ( i = k;\n    i < m;\n    ++ i ) {\n      cout << a [ i ] [ n - 1 ] << \" \";\n    }\n    n --;\n    if ( k < m ) {\n      for ( i = n - 1;\n      i >= l;\n      -- i ) {\n        cout << a [ m - 1 ] [ i ] << \" \";\n      }\n      m --;\n    }\n    if ( l < n ) {\n      for ( i = m - 1;\n      i >= k;\n      -- i ) {\n        cout << a [ i ] [ l ] << \" \";\n      }\n      l ++;\n    }\n  }\n}\n", "FIND_DISTINCT_INTEGERS_FOR_A_TRIPLET_WITH_GIVEN_PRODUCT": "void findTriplets ( int x ) {\n  vector < int > fact;\n  unordered_set < int > factors;\n  for ( int i = 2;\n  i <= sqrt ( x );\n  i ++ ) {\n    if ( x % i == 0 ) {\n      fact . push_back ( i );\n      if ( x / i != i ) fact . push_back ( x / i );\n      factors . insert ( i );\n      factors . insert ( x / i );\n    }\n  }\n  bool found = false;\n  int k = fact . size ( );\n  for ( int i = 0;\n  i < k;\n  i ++ ) {\n    int a = fact [ i ];\n    for ( int j = 0;\n    j < k;\n    j ++ ) {\n      int b = fact [ j ];\n      if ( ( a != b ) && ( x % ( a * b ) == 0 ) && ( x / ( a * b ) != a ) && ( x / ( a * b ) != b ) && ( x / ( a * b ) != 1 ) ) {\n        cout << a << \" \" << b << \" \" << ( x / ( a * b ) );\n        found = true;\n        break;\n      }\n    }\n    if ( found ) break;\n  }\n  if ( ! found ) cout << \"-1\";\n}\n", "SUM_TWO_LARGE_NUMBERS_1": "string findSum ( string str1, string str2 ) {\n  if ( str1 . length ( ) > str2 . length ( ) ) swap ( str1, str2 );\n  string str = \"\";\n  int n1 = str1 . length ( ), n2 = str2 . length ( );\n  int diff = n2 - n1;\n  int carry = 0;\n  for ( int i = n1 - 1;\n  i >= 0;\n  i -- ) {\n    int sum = ( ( str1 [ i ] - '0' ) + ( str2 [ i + diff ] - '0' ) + carry );\n    str . push_back ( sum % 10 + '0' );\n    carry = sum / 10;\n  }\n  for ( int i = n2 - n1 - 1;\n  i >= 0;\n  i -- ) {\n    int sum = ( ( str2 [ i ] - '0' ) + carry );\n    str . push_back ( sum % 10 + '0' );\n    carry = sum / 10;\n  }\n  if ( carry ) str . push_back ( carry + '0' );\n  reverse ( str . begin ( ), str . end ( ) );\n  return str;\n}\n", "COCKTAIL_SORT": "void CocktailSort ( int a [ ], int n ) {\n  bool swapped = true;\n  int start = 0;\n  int end = n - 1;\n  while ( swapped ) {\n    swapped = false;\n    for ( int i = start;\n    i < end;\n    ++ i ) {\n      if ( a [ i ] > a [ i + 1 ] ) {\n        swap ( a [ i ], a [ i + 1 ] );\n        swapped = true;\n      }\n    }\n    if ( ! swapped ) break;\n    swapped = false;\n    -- end;\n    for ( int i = end - 1;\n    i >= start;\n    -- i ) {\n      if ( a [ i ] > a [ i + 1 ] ) {\n        swap ( a [ i ], a [ i + 1 ] );\n        swapped = true;\n      }\n    }\n    ++ start;\n  }\n}\n", "COUNT_DERANGEMENTS_PERMUTATION_SUCH_THAT_NO_ELEMENT_APPEARS_IN_ITS_ORIGINAL_POSITION_1": "int countDer ( int n ) {\n  int der [ n + 1 ];\n  der [ 0 ] = 1;\n  der [ 1 ] = 0;\n  der [ 2 ] = 1;\n  for ( int i = 3;\n  i <= n;\n  ++ i ) der [ i ] = ( i - 1 ) * ( der [ i - 1 ] + der [ i - 2 ] );\n  return der [ n ];\n}\n", "MAXIMUM_PRODUCT_SUBARRAY_ADDED_NEGATIVE_PRODUCT_CASE": "int findMaxProduct ( int arr [ ], int n ) {\n  int i;\n  int ans = INT_MIN;\n  int maxval = 1;\n  int minval = 1;\n  int prevMax;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] > 0 ) {\n      maxval = maxval * arr [ i ];\n      minval = min ( 1, minval * arr [ i ] );\n    }\n    else if ( arr [ i ] == 0 ) {\n      minval = 1;\n      maxval = 0;\n    }\n    else if ( arr [ i ] < 0 ) {\n      prevMax = maxval;\n      maxval = minval * arr [ i ];\n      minval = prevMax * arr [ i ];\n    }\n    ans = max ( ans, maxval );\n    if ( maxval <= 0 ) {\n      maxval = 1;\n    }\n  }\n  return ans;\n}\n", "REARRANGE_ARRAY_SUCH_THAT_EVEN_POSITIONED_ARE_GREATER_THAN_ODD": "void assign ( int a [ ], int n ) {\n  sort ( a, a + n );\n  int ans [ n ];\n  int p = 0, q = n - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ( i + 1 ) % 2 == 0 ) ans [ i ] = a [ q -- ];\n    else ans [ i ] = a [ p ++ ];\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << ans [ i ] << \" \";\n}\n", "FRIENDS_PAIRING_PROBLEM": "int countFriendsPairings ( int n ) {\n  int dp [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    if ( i <= 2 ) dp [ i ] = i;\n    else dp [ i ] = dp [ i - 1 ] + ( i - 1 ) * dp [ i - 2 ];\n  }\n  return dp [ n ];\n}\n", "PRIME_NUMBERS": "bool isPrime ( int n ) {\n  if ( n <= 1 ) return false;\n  for ( int i = 2;\n  i < n;\n  i ++ ) if ( n % i == 0 ) return false;\n  return true;\n}\n", "PROBABILITY_REACHING_POINT_2_3_STEPS_TIME": "float find_prob ( int N, float P ) {\n  double dp [ N + 1 ];\n  dp [ 0 ] = 1;\n  dp [ 1 ] = 0;\n  dp [ 2 ] = P;\n  dp [ 3 ] = 1 - P;\n  for ( int i = 4;\n  i <= N;\n  ++ i ) dp [ i ] = ( P ) * dp [ i - 2 ] + ( 1 - P ) * dp [ i - 3 ];\n  return dp [ N ];\n}\n", "SMALLEST_OF_THREE_INTEGERS_WITHOUT_COMPARISON_OPERATORS_1": "int smallest ( int x, int y, int z ) {\n  if ( ! ( y / x ) ) return ( ! ( y / z ) ) ? y : z;\n  return ( ! ( x / z ) ) ? x : z;\n}\n", "COMMON_ELEMENTS_IN_ALL_ROWS_OF_A_GIVEN_MATRIX": "void printCommonElements ( int mat [ M ] [ N ] ) {\n  unordered_map < int, int > mp;\n  for ( int j = 0;\n  j < N;\n  j ++ ) mp [ mat [ 0 ] [ j ] ] = 1;\n  for ( int i = 1;\n  i < M;\n  i ++ ) {\n    for ( int j = 0;\n    j < N;\n    j ++ ) {\n      if ( mp [ mat [ i ] [ j ] ] == i ) {\n        mp [ mat [ i ] [ j ] ] = i + 1;\n        if ( i == M - 1 ) cout << mat [ i ] [ j ] << \" \";\n      }\n    }\n  }\n}\n", "DETECTING_NEGATIVE_CYCLE_USING_FLOYD_WARSHALL": "bool negCyclefloydWarshall ( int graph [ ] [ V ] ) {\n  int dist [ V ] [ V ], i, j, k;\n  for ( i = 0;\n  i < V;\n  i ++ ) for ( j = 0;\n  j < V;\n  j ++ ) dist [ i ] [ j ] = graph [ i ] [ j ];\n  for ( k = 0;\n  k < V;\n  k ++ ) {\n    for ( i = 0;\n    i < V;\n    i ++ ) {\n      for ( j = 0;\n      j < V;\n      j ++ ) {\n        if ( dist [ i ] [ k ] + dist [ k ] [ j ] < dist [ i ] [ j ] ) dist [ i ] [ j ] = dist [ i ] [ k ] + dist [ k ] [ j ];\n      }\n    }\n  }\n  for ( int i = 0;\n  i < V;\n  i ++ ) if ( dist [ i ] [ i ] < 0 ) return true;\n  return false;\n}\n", "PROGRAM_SORT_STRING_DESCENDING_ORDER": "void sortString ( string & str ) {\n  int charCount [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < str . length ( );\n    i ++ ) charCount [ str [ i ] - 'a' ] ++;\n    for ( int i = MAX_CHAR - 1;\n    i >= 0;\n    i -- ) for ( int j = 0;\n    j < charCount [ i ];\n    j ++ ) cout << ( char ) ( 'a' + i );\n  }\n  ", "COUNT_PAIRS_WITH_GIVEN_SUM": "int getPairsCount ( int arr [ ], int n, int sum ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( arr [ i ] + arr [ j ] == sum ) count ++;\n  return count;\n}\n", "SUM_SERIES_12_32_52_2N_12_1": "int sumOfSeries ( int n ) {\n  return ( n * ( 2 * n - 1 ) * ( 2 * n + 1 ) ) / 3;\n}\n", "MAXIMUM_DIFFERENCE_BETWEEN_FREQUENCY_OF_TWO_ELEMENTS_SUCH_THAT_ELEMENT_HAVING_GREATER_FREQUENCY_IS_ALSO_GREATER": "int maxdiff ( int arr [ ], int n ) {\n  unordered_map < int, int > freq;\n  for ( int i = 0;\n  i < n;\n  i ++ ) freq [ arr [ i ] ] ++;\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( freq [ arr [ i ] ] > freq [ arr [ j ] ] && arr [ i ] > arr [ j ] ) ans = max ( ans, freq [ arr [ i ] ] - freq [ arr [ j ] ] );\n      else if ( freq [ arr [ i ] ] < freq [ arr [ j ] ] && arr [ i ] < arr [ j ] ) ans = max ( ans, freq [ arr [ j ] ] - freq [ arr [ i ] ] );\n    }\n  }\n  return ans;\n}\n", "SHIFT_MATRIX_ELEMENTS_K": "void shiftMatrixByK ( int mat [ N ] [ N ], int k ) {\n  if ( k > N ) {\n    cout << \"shifting is not possible\" << endl;\n    return;\n  }\n  int j = 0;\n  while ( j < N ) {\n    for ( int i = k;\n    i < N;\n    i ++ ) cout << mat [ j ] [ i ] << \" \";\n    for ( int i = 0;\n    i < k;\n    i ++ ) cout << mat [ j ] [ i ] << \" \";\n    cout << endl;\n    j ++;\n  }\n}\n", "MAXIMUM_AND_MINIMUM_IN_A_SQUARE_MATRIX": "void maxMin ( int arr [ ] [ MAX ], int n ) {\n  int min = INT_MAX;\n  int max = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n / 2;\n    j ++ ) {\n      if ( arr [ i ] [ j ] > arr [ i ] [ n - j - 1 ] ) {\n        if ( min > arr [ i ] [ n - j - 1 ] ) min = arr [ i ] [ n - j - 1 ];\n        if ( max < arr [ i ] [ j ] ) max = arr [ i ] [ j ];\n      }\n      else {\n        if ( min > arr [ i ] [ j ] ) min = arr [ i ] [ j ];\n        if ( max < arr [ i ] [ n - j - 1 ] ) max = arr [ i ] [ n - j - 1 ];\n      }\n    }\n  }\n  cout << \"Maximum = \" << max;\n  << \", Minimum = \" << min;\n}\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY_1": "int findGreatest ( int arr [ ], int n ) {\n  unordered_map < int, int > m;\n  for ( int i = 0;\n  i < n;\n  i ++ ) m [ arr [ i ] ] ++;\n  sort ( arr, arr + n );\n  for ( int i = n - 1;\n  i > 1;\n  i -- ) {\n    for ( int j = 0;\n    j < i && arr [ j ] <= sqrt ( arr [ i ] );\n    j ++ ) {\n      if ( arr [ i ] % arr [ j ] == 0 ) {\n        int result = arr [ i ] / arr [ j ];\n        if ( result != arr [ j ] && m [ result ] > 0 ) return arr [ i ];\n        else if ( result == arr [ j ] && m [ result ] > 1 ) return arr [ i ];\n      }\n    }\n  }\n  return - 1;\n}\n", "0_1_KNAPSACK_PROBLEM_DP_10_1": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  int i, w;\n  int K [ n + 1 ] [ W + 1 ];\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( w = 0;\n    w <= W;\n    w ++ ) {\n      if ( i == 0 || w == 0 ) K [ i ] [ w ] = 0;\n      else if ( wt [ i - 1 ] <= w ) K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ], K [ i - 1 ] [ w ] );\n      else K [ i ] [ w ] = K [ i - 1 ] [ w ];\n    }\n  }\n  return K [ n ] [ W ];\n}\n", "PROGRAM_DECIMAL_OCTAL_CONVERSION": "void decToOctal ( int n ) {\n  int octalNum [ 100 ];\n  int i = 0;\n  while ( n != 0 ) {\n    octalNum [ i ] = n % 8;\n    n = n / 8;\n    i ++;\n  }\n  for ( int j = i - 1;\n  j >= 0;\n  j -- ) cout << octalNum [ j ];\n}\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M_1": "int countSubSeq ( int A [ ], int N, int M ) {\n  int ans = 0;\n  int h [ M ] = {\n    0 };\n    for ( int i = 0;\n    i < N;\n    i ++ ) {\n      A [ i ] = A [ i ] % M;\n      h [ A [ i ] ] ++;\n    }\n    for ( int i = 0;\n    i < M;\n    i ++ ) {\n      for ( int j = i;\n      j < M;\n      j ++ ) {\n        int rem = ( M - ( i + j ) % M ) % M;\n        if ( rem < j ) continue;\n        if ( i == j && rem == j ) ans += h [ i ] * ( h [ i ] - 1 ) * ( h [ i ] - 2 ) / 6;\n        else if ( i == j ) ans += h [ i ] * ( h [ i ] - 1 ) * h [ rem ] / 2;\n        else if ( i == rem ) ans += h [ i ] * ( h [ i ] - 1 ) * h [ j ] / 2;\n        else if ( rem == j ) ans += h [ j ] * ( h [ j ] - 1 ) * h [ i ] / 2;\n        else ans = ans + h [ i ] * h [ j ] * h [ rem ];\n      }\n    }\n    return ans;\n  }\n  ", "COUNT_FIBONACCI_NUMBERS_GIVEN_RANGE_LOG_TIME": "int countFibs ( int low, int high ) {\n  int f1 = 0, f2 = 1, f3 = 1;\n  int result = 0;\n  while ( f1 <= high ) {\n    if ( f1 >= low ) result ++;\n    f1 = f2;\n    f2 = f3;\n    f3 = f1 + f2;\n  }\n  return result;\n}\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT_1": "bool isPowerOfFour ( unsigned int n ) {\n  int count = 0;\n  if ( n && ! ( n & ( n - 1 ) ) ) {\n    while ( n > 1 ) {\n      n >>= 1;\n      count += 1;\n    }\n    return ( count % 2 == 0 ) ? 1 : 0;\n  }\n  return 0;\n}\n", "FIND_SUM_EVEN_FACTORS_NUMBER": "int sumofFactors ( int n ) {\n  if ( n % 2 != 0 ) return 0;\n  int res = 1;\n  for ( int i = 2;\n  i <= sqrt ( n );\n  i ++ ) {\n    int count = 0, curr_sum = 1, curr_term = 1;\n    while ( n % i == 0 ) {\n      count ++;\n      n = n / i;\n      if ( i == 2 && count == 1 ) curr_sum = 0;\n      curr_term *= i;\n      curr_sum += curr_term;\n    }\n    res *= curr_sum;\n  }\n  if ( n >= 2 ) res *= ( 1 + n );\n  return res;\n}\n", "FIND_SUM_NON_REPEATING_DISTINCT_ELEMENTS_ARRAY": "int findSum ( int arr [ ], int n ) {\n  int sum = 0;\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s . find ( arr [ i ] ) == s . end ( ) ) {\n      sum += arr [ i ];\n      s . insert ( arr [ i ] );\n    }\n  }\n  return sum;\n}\n", "DYNAMIC_PROGRAMMING_SET_17_PALINDROME_PARTITIONING_1": "int minPalPartion ( char * str ) {\n  int n = strlen ( str );\n  int C [ n ];\n  bool P [ n ] [ n ];\n  int i, j, k, L;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    P [ i ] [ i ] = true;\n  }\n  for ( L = 2;\n  L <= n;\n  L ++ ) {\n    for ( i = 0;\n    i < n - L + 1;\n    i ++ ) {\n      j = i + L - 1;\n      if ( L == 2 ) P [ i ] [ j ] = ( str [ i ] == str [ j ] );\n      else P [ i ] [ j ] = ( str [ i ] == str [ j ] ) && P [ i + 1 ] [ j - 1 ];\n    }\n  }\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( P [ 0 ] [ i ] == true ) C [ i ] = 0;\n    else {\n      C [ i ] = INT_MAX;\n      for ( j = 0;\n      j < i;\n      j ++ ) {\n        if ( P [ j + 1 ] [ i ] == true && 1 + C [ j ] < C [ i ] ) C [ i ] = 1 + C [ j ];\n      }\n    }\n  }\n  return C [ n - 1 ];\n}\n", "MINIMUM_POSITIVE_POINTS_TO_REACH_DESTINATION": "int minInitialPoints ( int points [ ] [ C ] ) {\n  int dp [ R ] [ C ];\n  int m = R, n = C;\n  dp [ m - 1 ] [ n - 1 ] = points [ m - 1 ] [ n - 1 ] > 0 ? 1 : abs ( points [ m - 1 ] [ n - 1 ] ) + 1;\n  for ( int i = m - 2;\n  i >= 0;\n  i -- ) dp [ i ] [ n - 1 ] = max ( dp [ i + 1 ] [ n - 1 ] - points [ i ] [ n - 1 ], 1 );\n  for ( int j = n - 2;\n  j >= 0;\n  j -- ) dp [ m - 1 ] [ j ] = max ( dp [ m - 1 ] [ j + 1 ] - points [ m - 1 ] [ j ], 1 );\n  for ( int i = m - 2;\n  i >= 0;\n  i -- ) {\n    for ( int j = n - 2;\n    j >= 0;\n    j -- ) {\n      int 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    }\n  }\n  return dp [ 0 ] [ 0 ];\n}\n", "COUNT_OF_PAIRS_SATISFYING_THE_GIVEN_CONDITION": "int countPair ( int a, int b ) {\n  string s = to_string ( b );\n  int i;\n  for ( i = 0;\n  i < s . length ( );\n  i ++ ) {\n    if ( s [ i ] != '9' ) break;\n  }\n  int result;\n  if ( i == s . length ( ) ) result = a * s . length ( );\n  else result = a * ( s . length ( ) - 1 );\n  return result;\n}\n", "SURVIVAL": "void survival ( int S, int N, int M ) {\n  if ( ( ( N * 6 ) < ( M * 7 ) && S > 6 ) || M > N ) cout << \"No\\n\";\n  else {\n    int days = ( M * S ) / N;\n    if ( ( ( M * S ) % N ) != 0 ) days ++;\n    cout << \"Yes \" << days << endl;\n  }\n}\n", "INTERLEAVE_FIRST_HALF_QUEUE_SECOND_HALF": "void interLeaveQueue ( queue < int > & q ) {\n  if ( q . size ( ) % 2 != 0 ) cout << \"Input even number of integers.\" << endl;\n  stack < int > s;\n  int halfSize = q . size ( ) / 2;\n  for ( int i = 0;\n  i < halfSize;\n  i ++ ) {\n    s . push ( q . front ( ) );\n    q . pop ( );\n  }\n  while ( ! s . empty ( ) ) {\n    q . push ( s . top ( ) );\n    s . pop ( );\n  }\n  for ( int i = 0;\n  i < halfSize;\n  i ++ ) {\n    q . push ( q . front ( ) );\n    q . pop ( );\n  }\n  for ( int i = 0;\n  i < halfSize;\n  i ++ ) {\n    s . push ( q . front ( ) );\n    q . pop ( );\n  }\n  while ( ! s . empty ( ) ) {\n    q . push ( s . top ( ) );\n    s . pop ( );\n    q . push ( q . front ( ) );\n    q . pop ( );\n  }\n}\n", "INTEGER_POSITIVE_VALUE_POSITIVE_NEGATIVE_VALUE_ARRAY_1": "int findInteger ( int arr [ ], int n ) {\n  int neg = 0, pos = 0;\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ];\n    if ( arr [ i ] < 0 ) neg ++;\n    else pos ++;\n  }\n  return ( sum / abs ( neg - pos ) );\n}\n", "FIND_SUM_EVEN_INDEX_BINOMIAL_COEFFICIENTS": "int evenSum ( int n ) {\n  int C [ n + 1 ] [ n + 1 ];\n  int i, j;\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( j = 0;\n    j <= min ( i, n );\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ];\n    }\n  }\n  int sum = 0;\n  for ( int i = 0;\n  i <= n;\n  i += 2 ) sum += C [ n ] [ i ];\n  return sum;\n}\n", "DELANNOY_NUMBER": "int dealnnoy ( int n, int m ) {\n  if ( m == 0 || n == 0 ) return 1;\n  return dealnnoy ( m - 1, n ) + dealnnoy ( m - 1, n - 1 ) + dealnnoy ( m, n - 1 );\n}\n", "FIND_THE_LARGEST_SUBARRAY_WITH_0_SUM": "int maxLen ( int arr [ ], int n ) {\n  int max_len = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int curr_sum = 0;\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      curr_sum += arr [ j ];\n      if ( curr_sum == 0 ) max_len = max ( max_len, j - i + 1 );\n    }\n  }\n  return max_len;\n}\n", "NEXT_POWER_OF_2": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  unsigned count = 0;\n  if ( n && ! ( n & ( n - 1 ) ) ) return n;\n  while ( n != 0 ) {\n    n >>= 1;\n    count += 1;\n  }\n  return 1 << count;\n}\n", "LONGEST_GEOMETRIC_PROGRESSION": "int lenOfLongestGP ( int set [ ], int n ) {\n  if ( n < 2 ) return n;\n  if ( n == 2 ) return ( set [ 1 ] % set [ 0 ] == 0 );\n  sort ( set, set + n );\n  int L [ n ] [ n ];\n  int llgp = 1;\n  for ( int i = 0;\n  i < n;\n  ++ i ) if ( set [ n - 1 ] % set [ i ] == 0 ) L [ i ] [ n - 1 ] = 2;\n  else L [ i ] [ n - 1 ] = 1;\n  for ( int j = n - 2;\n  j >= 1;\n  -- j ) {\n    int i = j - 1, k = j + 1;\n    while ( i >= 0 && k <= n - 1 ) {\n      if ( set [ i ] * set [ k ] < set [ j ] * set [ j ] ) ++ k;\n      else if ( set [ i ] * set [ k ] > set [ j ] * set [ j ] ) {\n        if ( set [ j ] % set [ i ] == 0 ) L [ i ] [ j ] = 2;\n        else L [ i ] [ j ] = 1;\n        -- i;\n      }\n      else {\n        L [ i ] [ j ] = L [ j ] [ k ] + 1;\n        if ( L [ i ] [ j ] > llgp ) llgp = L [ i ] [ j ];\n        -- i;\n        ++ k;\n      }\n    }\n    while ( i >= 0 ) {\n      if ( set [ j ] % set [ i ] == 0 ) L [ i ] [ j ] = 2;\n      else L [ i ] [ j ] = 1;\n      -- i;\n    }\n  }\n  return llgp;\n}\n", "DYNAMIC_PROGRAMMING_SET_6_MIN_COST_PATH": "int minCost ( int cost [ R ] [ C ], int m, int n ) {\n  int i, j;\n  int tc [ R ] [ C ];\n  tc [ 0 ] [ 0 ] = cost [ 0 ] [ 0 ];\n  for ( i = 1;\n  i <= m;\n  i ++ ) tc [ i ] [ 0 ] = tc [ i - 1 ] [ 0 ] + cost [ i ] [ 0 ];\n  for ( j = 1;\n  j <= n;\n  j ++ ) tc [ 0 ] [ j ] = tc [ 0 ] [ j - 1 ] + cost [ 0 ] [ j ];\n  for ( i = 1;\n  i <= m;\n  i ++ ) for ( j = 1;\n  j <= n;\n  j ++ ) 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}\n", "PROGRAM_DISTANCE_TWO_POINTS_EARTH": "long double distance ( long double lat1, long double long1, long double lat2, long double long2 ) {\n  lat1 = toRadians ( lat1 );\n  long1 = toRadians ( long1 );\n  lat2 = toRadians ( lat2 );\n  long2 = toRadians ( long2 );\n  long double dlong = long2 - long1;\n  long double dlat = lat2 - lat1;\n  long double ans = pow ( sin ( dlat / 2 ), 2 ) + cos ( lat1 ) * cos ( lat2 ) * pow ( sin ( dlong / 2 ), 2 );\n  ans = 2 * asin ( sqrt ( ans ) );\n  long double R = 6371;\n  ans = ans * R;\n  return ans;\n}\n", "BIN_PACKING_PROBLEM_MINIMIZE_NUMBER_OF_USED_BINS": "int nextFit ( int weight [ ], int n, int c ) {\n  int res = 0, bin_rem = c;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( weight [ i ] > bin_rem ) {\n      res ++;\n      bin_rem = c - weight [ i ];\n    }\n    else bin_rem -= weight [ i ];\n  }\n  return res;\n}\n", "FIND_SUBARRAY_WITH_GIVEN_SUM_1": "int subArraySum ( int arr [ ], int n, int sum ) {\n  int curr_sum = arr [ 0 ], start = 0, i;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    while ( curr_sum > sum && start < i - 1 ) {\n      curr_sum = curr_sum - arr [ start ];\n      start ++;\n    }\n    if ( curr_sum == sum ) {\n      cout << \"Sum found between indexes \" << start << \" and \" << i - 1;\n      return 1;\n    }\n    if ( i < n ) curr_sum = curr_sum + arr [ i ];\n  }\n  cout << \"No subarray found\";\n  return 0;\n}\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM_1": "int KnapSack ( int val [ ], int wt [ ], int n, int W ) {\n  int dp [ W + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = W;\n  j >= wt [ i ];\n  j -- ) dp [ j ] = max ( dp [ j ], val [ i ] + dp [ j - wt [ i ] ] );\n  return dp [ W ];\n}\n", "FIND_VALUE_OF_Y_MOD_2_RAISED_TO_POWER_X": "long long int yMod ( long long int y, long long int x ) {\n  if ( log2 ( y ) < x ) return y;\n  if ( x > 63 ) return y;\n  return ( y % ( 1 << x ) );\n}\n", "SUM_SERIES_23_45_67_89_UPTO_N_TERMS": "double seriesSum ( int n ) {\n  int i = 1;\n  double res = 0.0;\n  bool sign = true;\n  while ( n > 0 ) {\n    n --;\n    if ( sign ) {\n      sign = ! sign;\n      res = res + ( double ) ++ i / ++ i;\n    }\n    else {\n      sign = ! sign;\n      res = res - ( double ) ++ i / ++ i;\n    }\n  }\n  return res;\n}\n", "LENGTH_LONGEST_STRICT_BITONIC_SUBSEQUENCE": "int longLenStrictBitonicSub ( int arr [ ], int n ) {\n  unordered_map < int, int > inc, dcr;\n  int len_inc [ n ], len_dcr [ n ];\n  int longLen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int len = 0;\n    if ( inc . find ( arr [ i ] - 1 ) != inc . end ( ) ) len = inc [ arr [ i ] - 1 ];\n    inc [ arr [ i ] ] = len_inc [ i ] = len + 1;\n  }\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    int len = 0;\n    if ( dcr . find ( arr [ i ] - 1 ) != dcr . end ( ) ) len = dcr [ arr [ i ] - 1 ];\n    dcr [ arr [ i ] ] = len_dcr [ i ] = len + 1;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( longLen < ( len_inc [ i ] + len_dcr [ i ] - 1 ) ) longLen = len_inc [ i ] + len_dcr [ i ] - 1;\n  return longLen;\n}\n", "MAXIMUM_DISTANCE_TWO_OCCURRENCES_ELEMENT_ARRAY": "int maxDistance ( int arr [ ], int n ) {\n  unordered_map < int, int > mp;\n  int max_dist = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( mp . find ( arr [ i ] ) == mp . end ( ) ) mp [ arr [ i ] ] = i;\n    else max_dist = max ( max_dist, i - mp [ arr [ i ] ] );\n  }\n  return max_dist;\n}\n", "FIND_RECTANGLE_BINARY_MATRIX_CORNERS_1_1": "bool isRectangle ( const vector < vector < int > > & matrix ) {\n  int rows = matrix . size ( );\n  if ( rows == 0 ) return false;\n  int columns = matrix [ 0 ] . size ( );\n  unordered_map < int, unordered_set < int > > table;\n  for ( int i = 0;\n  i < rows;\n  ++ i ) {\n    for ( int j = 0;\n    j < columns - 1;\n    ++ j ) {\n      for ( int k = j + 1;\n      k < columns;\n      ++ k ) {\n        if ( matrix [ i ] [ j ] == 1 && matrix [ i ] [ k ] == 1 ) {\n          if ( table . find ( j ) != table . end ( ) && table [ j ] . find ( k ) != table [ j ] . end ( ) ) return true;\n          table [ j ] . insert ( k );\n        }\n      }\n    }\n  }\n  return false;\n}\n", "COUNT_MINIMUM_NUMBER_SUBSETS_SUBSEQUENCES_CONSECUTIVE_NUMBERS": "int numofsubset ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int count = 1;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( arr [ i ] + 1 != arr [ i + 1 ] ) count ++;\n  }\n  return count;\n}\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY": "int maxSubArraySum ( int a [ ], int size ) {\n  int max_so_far = INT_MIN, max_ending_here = 0;\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\n    max_ending_here = max_ending_here + a [ i ];\n    if ( max_so_far < max_ending_here ) max_so_far = max_ending_here;\n    if ( max_ending_here < 0 ) max_ending_here = 0;\n  }\n  return max_so_far;\n}\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR_2": "int getRemainder ( int num, int divisor ) {\n  while ( num >= divisor ) num -= divisor;\n  return num;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_4_NOT": "bool check ( string str ) {\n  int n = str . length ( );\n  if ( n == 0 ) return false;\n  if ( n == 1 ) return ( ( str [ 0 ] - '0' ) % 4 == 0 );\n  int last = str [ n - 1 ] - '0';\n  int second_last = str [ n - 2 ] - '0';\n  return ( ( second_last * 10 + last ) % 4 == 0 );\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_1": "int getSingle ( int arr [ ], int n ) {\n  int result = 0;\n  int x, sum;\n  for ( int i = 0;\n  i < INT_SIZE;\n  i ++ ) {\n    sum = 0;\n    x = ( 1 << i );\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( arr [ j ] & x ) sum ++;\n    }\n    if ( sum % 3 ) result |= x;\n  }\n  return result;\n}\n", "NUMBER_RECTANGLES_NM_GRID": "int rectCount ( int n, int m ) {\n  return ( m * n * ( n + 1 ) * ( m + 1 ) ) / 4;\n}\n", "MAXIMUM_POINTS_INTERSECTION_N_CIRCLES": "int intersection ( int n ) {\n  return n * ( n - 1 );\n}\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY_2": "void printDistinct ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s . find ( arr [ i ] ) == s . end ( ) ) {\n      s . insert ( arr [ i ] );\n      cout << arr [ i ] << \" \";\n    }\n  }\n}\n", "CHECK_ROWS_MATRIX_CIRCULAR_ROTATIONS": "bool isPermutedMatrix ( int mat [ MAX ] [ MAX ], int n ) {\n  string str_cat = \"\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) str_cat = str_cat + \"-\" + to_string ( mat [ 0 ] [ i ] );\n  str_cat = str_cat + str_cat;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    string curr_str = \"\";\n    for ( int j = 0;\n    j < n;\n    j ++ ) curr_str = curr_str + \"-\" + to_string ( mat [ i ] [ j ] );\n    if ( str_cat . find ( curr_str ) == string :: npos ) return false;\n  }\n  return true;\n}\n", "SUM_PAIRWISE_PRODUCTS": "long long int findSum ( int n ) {\n  long long int sum = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = i;\n  j <= n;\n  j ++ ) sum = sum + i * j;\n  return sum;\n}\n", "SORT_3_INTEGERS_WITHOUT_USING_CONDITION_USING_MAX_FUNCTION": "void printSorted ( int a, int b, int c ) {\n  int get_max = max ( a, max ( b, c ) );\n  int get_min = - max ( - a, max ( - b, - c ) );\n  int get_mid = ( a + b + c ) - ( get_max + get_min );\n  cout << get_min << \" \" << get_mid << \" \" << get_max;\n}\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER_2": "int factorial ( int n ) {\n  return ( n == 1 || n == 0 ) ? 1 : n * factorial ( n - 1 );\n}\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY_2": "int find_extra_element_index ( int arrA [ ], int arrB [ ], int n, int m ) {\n  int extra_element = sum ( arrA, n ) - sum ( arrB, m );\n  return indexOf ( arrA, extra_element, n );\n}\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM_1": "void printSubsequences ( int arr [ ], int n ) {\n  unsigned int opsize = pow ( 2, n );\n  for ( int counter = 1;\n  counter < opsize;\n  counter ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( counter & ( 1 << j ) ) cout << arr [ j ] << \" \";\n    }\n    cout << endl;\n  }\n}\n", "N_BONACCI_NUMBERS": "void bonacciseries ( long n, int m ) {\n  int a [ m ] = {\n    0 };\n    a [ n - 1 ] = 1;\n    for ( int i = n;\n    i < m;\n    i ++ ) for ( int j = i - n;\n    j < i;\n    j ++ ) a [ i ] += a [ j ];\n    for ( int i = 0;\n    i < m;\n    i ++ ) cout << a [ i ] << \"  \";\n  }\n  ", "LOWER_CASE_UPPER_CASE_INTERESTING_FACT": "string to_upper ( string & in ) {\n  for ( int i = 0;\n  i < in . length ( );\n  i ++ ) if ( 'a' <= in [ i ] <= 'z' ) in [ i ] = in [ i ] - 'a' + 'A';\n  return in;\n}\n", "PRINT_BRACKET_NUMBER": "void printBracketNumber ( string exp, int n ) {\n  int left_bnum = 1;\n  stack < int > right_bnum;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( exp [ i ] == '(' ) {\n      cout << left_bnum << \" \";\n      right_bnum . push ( left_bnum );\n      left_bnum ++;\n    }\n    else if ( exp [ i ] == ')' ) {\n      cout << right_bnum . top ( ) << \" \";\n      right_bnum . pop ( );\n    }\n  }\n}\n", "MAXIMUM_PRODUCT_OF_4_ADJACENT_ELEMENTS_IN_MATRIX": "int FindMaxProduct ( int arr [ ] [ n ], int n ) {\n  int max = 0, result;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\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 ) max = result;\n      }\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 ) max = result;\n      }\n      if ( ( i - 3 ) >= 0 && ( 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 ) max = result;\n      }\n    }\n  }\n  return max;\n}\n", "LONGEST_SUBARRAY_SUM_DIVISIBLE_K": "int longSubarrWthSumDivByK ( int arr [ ], int n, int k ) {\n  unordered_map < int, int > um;\n  int mod_arr [ n ], max = 0;\n  int curr_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    curr_sum += arr [ i ];\n    mod_arr [ i ] = ( ( curr_sum % k ) + k ) % k;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( mod_arr [ i ] == 0 ) max = i + 1;\n    else if ( um . find ( mod_arr [ i ] ) == um . end ( ) ) um [ mod_arr [ i ] ] = i;\n    else if ( max < ( i - um [ mod_arr [ i ] ] ) ) max = i - um [ mod_arr [ i ] ];\n  }\n  return max;\n}\n", "CAESAR_CIPHER": "string encrypt ( string text, int s ) {\n  string result = \"\";\n  for ( int i = 0;\n  i < text . length ( );\n  i ++ ) {\n    if ( isupper ( text [ i ] ) ) result += char ( int ( text [ i ] + s - 65 ) % 26 + 65 );\n    else result += char ( int ( text [ i ] + s - 97 ) % 26 + 97 );\n  }\n  return result;\n}\n", "SUBARRAYS_DISTINCT_ELEMENTS": "int sumoflength ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  int j = 0, ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( j < n && s . find ( arr [ j ] ) == s . end ( ) ) {\n      s . insert ( arr [ j ] );\n      j ++;\n    }\n    ans += ( ( j - i ) * ( j - i + 1 ) ) / 2;\n    s . erase ( arr [ i ] );\n  }\n  return ans;\n}\n", "K_TH_ELEMENT_TWO_SORTED_ARRAYS": "int kth ( int arr1 [ ], int arr2 [ ], int m, int n, int k ) {\n  int sorted1 [ m + n ];\n  int i = 0, j = 0, d = 0;\n  while ( i < m && j < n ) {\n    if ( arr1 [ i ] < arr2 [ j ] ) sorted1 [ d ++ ] = arr1 [ i ++ ];\n    else sorted1 [ d ++ ] = arr2 [ j ++ ];\n  }\n  while ( i < m ) sorted1 [ d ++ ] = arr1 [ i ++ ];\n  while ( j < n ) sorted1 [ d ++ ] = arr2 [ j ++ ];\n  return sorted1 [ k - 1 ];\n}\n", "REMOVE_CONSECUTIVE_DUPLICATES_STRING": "void removeDuplicates ( char S [ ] ) {\n  int n = strlen ( S );\n  if ( n < 2 ) return;\n  int j = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( S [ j ] != S [ i ] ) {\n      j ++;\n      S [ j ] = S [ i ];\n    }\n  }\n  j ++;\n  S [ j ] = '\\0';\n}\n", "MAJORITY_ELEMENT": "void findMajority ( int arr [ ], int n ) {\n  int maxCount = 0;\n  int index = - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int count = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( arr [ i ] == arr [ j ] ) count ++;\n    }\n    if ( count > maxCount ) {\n      maxCount = count;\n      index = i;\n    }\n  }\n  if ( maxCount > n / 2 ) cout << arr [ index ] << endl;\n  else cout << \"No Majority Element\" << endl;\n}\n", "FUNCTION_COPY_STRING_ITERATIVE_RECURSIVE_1": "void myCopy ( char s1 [ ], char s2 [ ], int index = 0 ) {\n  s2 [ index ] = s1 [ index ];\n  if ( s1 [ index ] == '\\0' ) return;\n  myCopy ( s1, s2, index + 1 );\n}\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE_1": "int printCountDP ( int dist ) {\n  int count [ dist + 1 ];\n  count [ 0 ] = 1, count [ 1 ] = 1, count [ 2 ] = 2;\n  for ( int i = 3;\n  i <= dist;\n  i ++ ) count [ i ] = count [ i - 1 ] + count [ i - 2 ] + count [ i - 3 ];\n  return count [ dist ];\n}\n", "DISCRETE_LOGARITHM_FIND_INTEGER_K_AK_CONGRUENT_MODULO_B": "int discreteLogarithm ( int a, int b, int m ) {\n  int n = ( int ) sqrt ( m ) + 1;\n  int an = 1;\n  for ( int i = 0;\n  i < n;\n  ++ i ) an = ( an * a ) % m;\n  unordered_map < int, int > value;\n  for ( int i = 1, cur = an;\n  i <= n;\n  ++ i ) {\n    if ( ! value [ cur ] ) value [ cur ] = i;\n    cur = ( cur * an ) % m;\n  }\n  for ( int i = 0, cur = b;\n  i <= n;\n  ++ i ) {\n    if ( value [ cur ] ) {\n      int ans = value [ cur ] * n - i;\n      if ( ans < m ) return ans;\n    }\n    cur = ( cur * a ) % m;\n  }\n  return - 1;\n}\n", "CHANGE_BITS_CAN_MADE_ONE_FLIP_1": "bool isOneFlip ( string str ) {\n  int sum = 0;\n  int n = str . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += str [ i ] - '0';\n  return ( sum == n - 1 || sum == 1 );\n}\n", "FIND_PAIRS_IN_ARRAY_WHOSE_SUMS_ALREADY_EXIST_IN_ARRAY": "void findPair ( int arr [ ], int n ) {\n  bool found = false;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) {\n      for ( int k = 0;\n      k < n;\n      k ++ ) {\n        if ( arr [ i ] + arr [ j ] == arr [ k ] ) {\n          cout << arr [ i ] << \" \" << arr [ j ] << endl;\n          found = true;\n        }\n      }\n    }\n  }\n  if ( found == false ) cout << \"Not exist\" << endl;\n}\n", "MODULAR_MULTIPLICATIVE_INVERSE_1_N": "void modularInverse ( int n, int prime ) {\n  int dp [ n + 1 ];\n  dp [ 0 ] = dp [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) dp [ i ] = dp [ prime % i ] * ( prime - prime / i ) % prime;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) cout << dp [ i ] << ' ';\n}\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE_1": "void shufleArray ( int a [ ], int f, int l ) {\n  if ( l > f ) {\n    return;\n  }\n  if ( l - f == 1 ) return;\n  int mid = ( f + l ) / 2;\n  int temp = mid + 1;\n  int mmid = ( f + mid ) / 2;\n  for ( int i = mmid + 1;\n  i <= mid;\n  i ++ ) swap ( a [ i ], a [ temp ++ ] );\n  shufleArray ( a, f, mid );\n  shufleArray ( a, mid + 1, l );\n}\n", "N_TH_ROOT_NUMBER": "double nthRoot ( int A, int N ) {\n  double xPre = rand ( ) % 10;\n  double eps = 1e - 3;\n  double delX = INT_MAX;\n  double xK;\n  while ( delX > eps ) {\n    xK = ( ( N - 1.0 ) * xPre + ( double ) A / pow ( xPre, N - 1 ) ) / ( double ) N;\n    delX = abs ( xK - xPre );\n    xPre = xK;\n  }\n  return xK;\n}\n", "NUMBER_OF_WAYS_TO_ARRANGE_N_ITEMS_UNDER_GIVEN_CONSTRAINTS": "int waysToArrange ( int N, int K, int k [ ] ) {\n  int C [ N + 1 ] [ N + 1 ];\n  int i, j;\n  for ( i = 0;\n  i <= N;\n  i ++ ) {\n    for ( j = 0;\n    j <= i;\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] );\n    }\n  }\n  int dp [ K ];\n  int count = 0;\n  dp [ 0 ] = 1;\n  for ( int i = 0;\n  i < K;\n  i ++ ) {\n    dp [ i + 1 ] = ( dp [ i ] * C [ count + k [ i ] - 1 ] [ k [ i ] - 1 ] );\n    count += k [ i ];\n  }\n  return dp [ K ];\n}\n", "TEMPLE_OFFERINGS": "int offeringNumber ( int n, int templeHeight [ ] ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    int left = 0, right = 0;\n    for ( int j = i - 1;\n    j >= 0;\n    -- j ) {\n      if ( templeHeight [ j ] < templeHeight [ j + 1 ] ) ++ left;\n      else break;\n    }\n    for ( int j = i + 1;\n    j < n;\n    ++ j ) {\n      if ( templeHeight [ j ] < templeHeight [ j - 1 ] ) ++ right;\n      else break;\n    }\n    sum += max ( right, left ) + 1;\n  }\n  return sum;\n}\n", "CENTER_ELEMENT_OF_MATRIX_EQUALS_SUMS_OF_HALF_DIAGONALS": "bool HalfDiagonalSums ( int mat [ ] [ MAX ], int n ) {\n  int diag1_left = 0, diag1_right = 0;\n  int diag2_left = 0, diag2_right = 0;\n  for ( int i = 0, j = n - 1;\n  i < n;\n  i ++, j -- ) {\n    if ( i < n / 2 ) {\n      diag1_left += mat [ i ] [ i ];\n      diag2_left += mat [ j ] [ i ];\n    }\n    else if ( i > n / 2 ) {\n      diag1_right += mat [ i ] [ i ];\n      diag2_right += mat [ j ] [ i ];\n    }\n  }\n  return ( diag1_left == diag2_right && diag2_right == diag2_left && diag1_right == diag2_left && diag2_right == mat [ n / 2 ] [ n / 2 ] );\n}\n", "COUNT_FACTORIAL_NUMBERS_IN_A_GIVEN_RANGE": "int countFact ( int low, int high ) {\n  int fact = 1, x = 1;\n  while ( fact < low ) {\n    fact = fact * x;\n    x ++;\n  }\n  int res = 0;\n  while ( fact <= high ) {\n    res ++;\n    fact = fact * x;\n    x ++;\n  }\n  return res;\n}\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE_1": "void reverseStr ( string & str ) {\n  int n = str . length ( );\n  for ( int i = 0, j = n - 1;\n  i < j;\n  i ++, j -- ) swap ( str [ i ], str [ j ] );\n}\n", "FIND_MINIMUM_ADJUSTMENT_COST_OF_AN_ARRAY": "int minAdjustmentCost ( int A [ ], int n, int target ) {\n  int dp [ n ] [ M + 1 ];\n  for ( int j = 0;\n  j <= M;\n  j ++ ) dp [ 0 ] [ j ] = abs ( j - A [ 0 ] );\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= M;\n    j ++ ) {\n      dp [ i ] [ j ] = INT_MAX;\n      for ( int k = max ( j - target, 0 );\n      k <= min ( M, j + target );\n      k ++ ) dp [ i ] [ j ] = min ( dp [ i ] [ j ], dp [ i - 1 ] [ k ] + abs ( A [ i ] - j ) );\n    }\n  }\n  int res = INT_MAX;\n  for ( int j = 0;\n  j <= M;\n  j ++ ) res = min ( res, dp [ n - 1 ] [ j ] );\n  return res;\n}\n", "COUNT_FREQUENCY_K_MATRIX_SIZE_N_MATRIXI_J_IJ": "int find ( int n, int k ) {\n  if ( n + 1 >= k ) return ( k - 1 );\n  else return ( 2 * n + 1 - k );\n}\n", "MINIMUM_FLIP_REQUIRED_MAKE_BINARY_MATRIX_SYMMETRIC_1": "int minimumflip ( int mat [ ] [ N ], int n ) {\n  int flip = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < i;\n  j ++ ) if ( mat [ i ] [ j ] != mat [ j ] [ i ] ) flip ++;\n  return flip;\n}\n", "NTH_PALINDROME_K_DIGITS": "void nthPalindrome ( int n, int k ) {\n  int temp = ( k & 1 ) ? ( k / 2 ) : ( k / 2 - 1 );\n  int palindrome = ( int ) pow ( 10, temp );\n  palindrome += n - 1;\n  printf ( \"%d\", palindrome );\n  if ( k & 1 ) palindrome /= 10;\n  while ( palindrome ) {\n    printf ( \"%d\", palindrome % 10 );\n    palindrome /= 10;\n  }\n  printf ( \"\\n\" );\n}\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE_1": "int lis ( int arr [ ], int n ) {\n  int lis [ n ];\n  lis [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    lis [ i ] = 1;\n    for ( int j = 0;\n    j < i;\n    j ++ ) if ( arr [ i ] > arr [ j ] && lis [ i ] < lis [ j ] + 1 ) lis [ i ] = lis [ j ] + 1;\n  }\n  return * max_element ( lis, lis + n );\n}\n", "PATH_MAXIMUM_AVERAGE_VALUE": "double maxAverageOfPath ( int cost [ M ] [ M ], int N ) {\n  int dp [ N + 1 ] [ N + 1 ];\n  dp [ 0 ] [ 0 ] = cost [ 0 ] [ 0 ];\n  for ( int i = 1;\n  i < N;\n  i ++ ) dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ] + cost [ i ] [ 0 ];\n  for ( int j = 1;\n  j < N;\n  j ++ ) dp [ 0 ] [ j ] = dp [ 0 ] [ j - 1 ] + cost [ 0 ] [ j ];\n  for ( int i = 1;\n  i < N;\n  i ++ ) for ( int j = 1;\n  j <= N;\n  j ++ ) dp [ i ] [ j ] = max ( dp [ i - 1 ] [ j ], dp [ i ] [ j - 1 ] ) + cost [ i ] [ j ];\n  return ( double ) dp [ N - 1 ] [ N - 1 ] / ( 2 * N - 1 );\n}\n", "PROGRAM_COUNT_OCCURRENCE_GIVEN_CHARACTER_STRING": "int count ( string s, char c ) {\n  int res = 0;\n  for ( int i = 0;\n  i < s . length ( );\n  i ++ ) if ( s [ i ] == c ) res ++;\n  return res;\n}\n", "KTH_SMALLESTLARGEST_ELEMENT_UNSORTED_ARRAY": "int kthSmallest ( int arr [ ], int n, int k ) {\n  sort ( arr, arr + n );\n  return arr [ k - 1 ];\n}\n", "CONVERT_ALTERNATE_CHARACTERS_STRING_UPPER_CASE": "void convertOpposite ( string & str ) {\n  int ln = str . length ( );\n  for ( int i = 0;\n  i < ln;\n  i ++ ) {\n    if ( str [ i ] >= 'a' && str [ i ] <= 'z' ) str [ i ] = str [ i ] - 32;\n    else if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) str [ i ] = str [ i ] + 32;\n  }\n}\n", "SUM_SERIES_555555_N_TERMS": "int sumOfSeries ( int n ) {\n  return 0.6172 * ( pow ( 10, n ) - 1 ) - 0.55 * n;\n}\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION": "int MatrixChainOrder ( int p [ ], int i, int j ) {\n  if ( i == j ) return 0;\n  int k;\n  int min = INT_MAX;\n  int count;\n  for ( k = i;\n  k < j;\n  k ++ ) {\n    count = MatrixChainOrder ( p, i, k ) + MatrixChainOrder ( p, k + 1, j ) + p [ i - 1 ] * p [ k ] * p [ j ];\n    if ( count < min ) min = count;\n  }\n  return min;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_3": "int countSetBits ( int n ) {\n  if ( n == 0 ) return 0;\n  else return 1 + countSetBits ( n & ( n - 1 ) );\n}\n", "MINIMUM_LENGTH_UNSORTED_SUBARRAY_SORTING_WHICH_MAKES_THE_COMPLETE_ARRAY_SORTED": "void printUnsorted ( int arr [ ], int n ) {\n  int s = 0, e = n - 1, i, max, min;\n  for ( s = 0;\n  s < n - 1;\n  s ++ ) {\n    if ( arr [ s ] > arr [ s + 1 ] ) break;\n  }\n  if ( s == n - 1 ) {\n    cout << \"The complete array is sorted\";\n    return;\n  }\n  for ( e = n - 1;\n  e > 0;\n  e -- ) {\n    if ( arr [ e ] < arr [ e - 1 ] ) break;\n  }\n  max = arr [ s ];\n  min = arr [ s ];\n  for ( i = s + 1;\n  i <= e;\n  i ++ ) {\n    if ( arr [ i ] > max ) max = arr [ i ];\n    if ( arr [ i ] < min ) min = arr [ i ];\n  }\n  for ( i = 0;\n  i < s;\n  i ++ ) {\n    if ( arr [ i ] > min ) {\n      s = i;\n      break;\n    }\n  }\n  for ( i = n - 1;\n  i >= e + 1;\n  i -- ) {\n    if ( arr [ i ] < max ) {\n      e = i;\n      break;\n    }\n  }\n  cout << \"The unsorted subarray which\" << \" makes the given array\" << endl << \"sorted lies between the indees \" << s << \" and \" << e;\n  return;\n}\n", "STEINS_ALGORITHM_FOR_FINDING_GCD": "int gcd ( int a, int b ) {\n  if ( a == 0 ) return b;\n  if ( b == 0 ) return a;\n  int k;\n  for ( k = 0;\n  ( ( a | b ) && 1 ) == 0;\n  ++ k ) {\n    a >>= 1;\n    b >>= 1;\n  }\n  while ( ( a > 1 ) == 0 ) a >>= 1;\n  do {\n    while ( ( b > 1 ) == 0 ) b >>= 1;\n    if ( a > b ) swap ( a, b );\n    b = ( b - a );\n  }\n  while ( b != 0 );\n  return a << k;\n}\n", "HEXAGONAL_NUMBER": "int hexagonalNum ( int n ) {\n  return n * ( 2 * n - 1 );\n}\n", "GOOGLE_CASE_GIVEN_SENTENCE": "string convert ( string s ) {\n  int n = s . length ( );\n  s [ 0 ] = tolower ( s [ 0 ] );\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( s [ i ] == ' ' && i < n ) {\n      s [ i + 1 ] = tolower ( s [ i + 1 ] );\n      i ++;\n    }\n    else s [ i ] = toupper ( s [ i ] );\n  }\n  return s;\n}\n", "FIND_A_ROTATION_WITH_MAXIMUM_HAMMING_DISTANCE": "int maxHamming ( int arr [ ], int n ) {\n  int brr [ 2 * n + 1 ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) brr [ i ] = arr [ i ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) brr [ n + i ] = arr [ i ];\n  int maxHam = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int currHam = 0;\n    for ( int j = i, k = 0;\n    j < ( i + n );\n    j ++, k ++ ) if ( brr [ j ] != arr [ k ] ) currHam ++;\n    if ( currHam == n ) return n;\n    maxHam = max ( maxHam, currHam );\n  }\n  return maxHam;\n}\n", "GIVEN_A_NUMBER_N_GENERATE_BIT_PATTERNS_FROM_0_TO_2N_1_SO_THAT_SUCCESSIVE_PATTERNS_DIFFER_BY_ONE_BIT": "void generateGrayarr ( int n ) {\n  if ( n <= 0 ) return;\n  vector < string > arr;\n  arr . push_back ( \"0\" );\n  arr . push_back ( \"1\" );\n  int i, j;\n  for ( i = 2;\n  i < ( 1 << n );\n  i = i << 1 ) {\n    for ( j = i - 1;\n    j >= 0;\n    j -- ) arr . push_back ( arr [ j ] );\n    for ( j = 0;\n    j < i;\n    j ++ ) arr [ j ] = \"0\" + arr [ j ];\n    for ( j = i;\n    j < 2 * i;\n    j ++ ) arr [ j ] = \"1\" + arr [ j ];\n  }\n  for ( i = 0;\n  i < arr . size ( );\n  i ++ ) cout << arr [ i ] << endl;\n}\n", "MINIMUM_SWAPS_REQUIRED_BRING_ELEMENTS_LESS_EQUAL_K_TOGETHER": "int minSwap ( int * arr, int n, int k ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) if ( arr [ i ] <= k ) ++ count;\n  int bad = 0;\n  for ( int i = 0;\n  i < count;\n  ++ i ) if ( arr [ i ] > k ) ++ bad;\n  int ans = bad;\n  for ( int i = 0, j = count;\n  j < n;\n  ++ i, ++ j ) {\n    if ( arr [ i ] > k ) -- bad;\n    if ( arr [ j ] > k ) ++ bad;\n    ans = min ( ans, bad );\n  }\n  return ans;\n}\n", "FIND_NTH_FIBONACCI_NUMBER_USING_GOLDEN_RATIO": "int fib ( int n ) {\n  if ( n < 6 ) return f [ n ];\n  int t = 5, fn = 5;\n  while ( t < n ) {\n    fn = round ( fn * PHI );\n    t ++;\n  }\n  return fn;\n}\n", "SORTING_ARRAY_REVERSE_AROUND_MIDDLE": "bool ifPossible ( int arr [ ], int n ) {\n  int cp [ n ];\n  copy ( arr, arr + n, cp );\n  sort ( cp, cp + n );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ! ( arr [ i ] == cp [ i ] ) && ! ( arr [ n - 1 - i ] == cp [ i ] ) ) return false;\n  }\n  return true;\n}\n", "COUNT_ROTATIONS_DIVISIBLE_4": "int countRotations ( string n ) {\n  int len = n . length ( );\n  if ( len == 1 ) {\n    int oneDigit = n . at ( 0 ) - '0';\n    if ( oneDigit % 4 == 0 ) return 1;\n    return 0;\n  }\n  int twoDigit, count = 0;\n  for ( int i = 0;\n  i < ( len - 1 );\n  i ++ ) {\n    twoDigit = ( n . at ( i ) - '0' ) * 10 + ( n . at ( i + 1 ) - '0' );\n    if ( twoDigit % 4 == 0 ) count ++;\n  }\n  twoDigit = ( n . at ( len - 1 ) - '0' ) * 10 + ( n . at ( 0 ) - '0' );\n  if ( twoDigit % 4 == 0 ) count ++;\n  return count;\n}\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN_2": "int findNth ( int n ) {\n  int nthElement = 19 + ( n - 1 ) * 9;\n  int outliersCount = ( int ) log10 ( nthElement ) - 1;\n  nthElement += 9 * outliersCount;\n  return nthElement;\n}\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD_1": "bool isPrime ( int n ) {\n  if ( n <= 1 ) return false;\n  if ( n <= 3 ) return true;\n  if ( n % 2 == 0 || n % 3 == 0 ) return false;\n  for ( int i = 5;\n  i * i <= n;\n  i = i + 6 ) if ( n % i == 0 || n % ( i + 2 ) == 0 ) return false;\n  return true;\n}\n", "MINIMUM_NUMBER_SUBSETS_DISTINCT_ELEMENTS_1": "int subset ( int arr [ ], int n ) {\n  unordered_map < int, int > mp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mp [ arr [ i ] ] ++;\n  int res = 0;\n  for ( auto x : mp ) res = max ( res, x . second );\n  return res;\n}\n", "RECAMANS_SEQUENCE_1": "void recaman ( int n ) {\n  if ( n <= 0 ) return;\n  printf ( \"%d, \", 0 );\n  unordered_set < int > s;\n  s . insert ( 0 );\n  int prev = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int curr = prev - i;\n    if ( curr < 0 || s . find ( curr ) != s . end ( ) ) curr = prev + i;\n    s . insert ( curr );\n    printf ( \"%d, \", curr );\n    prev = curr;\n  }\n}\n", "GENERATE_ROTATIONS_GIVEN_STRING_1": "void printRotatedString ( char str [ ] ) {\n  int n = strlen ( str );\n  char temp [ 2 * n + 1 ];\n  strcpy ( temp, str );\n  strcat ( temp, str );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = 0;\n    j != n;\n    j ++ ) printf ( \"%c\", temp [ i + j ] );\n    printf ( \"\\n\" );\n  }\n}\n", "FITTING_SHELVES_PROBLEM": "void minSpacePreferLarge ( int wall, int m, int n ) {\n  int num_m = 0, num_n = 0, min_empty = wall;\n  int p = 0, q = 0, rem;\n  while ( wall >= n ) {\n    p = wall / m;\n    rem = wall % m;\n    if ( rem <= min_empty ) {\n      num_m = p;\n      num_n = q;\n      min_empty = rem;\n    }\n    q += 1;\n    wall = wall - n;\n  }\n  cout << num_m << \" \" << num_n << \" \" << min_empty << endl;\n}\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS_1": "int countStr ( int n ) {\n  return 1 + ( n * 2 ) + ( n * ( ( n * n ) - 1 ) / 2 );\n}\n", "DIVISIBILITY_BY_12_FOR_A_LARGE_NUMBER": "bool isDvisibleBy12 ( string num ) {\n  if ( num . length ( ) >= 3 ) {\n    int d1 = ( int ) num [ num . length ( ) - 1 ];\n    if ( d1 % 2 != 0 ) return ( 0 );\n    int d2 = ( int ) num [ num . length ( ) - 2 ];\n    int sum = 0;\n    for ( int i = 0;\n    i < num . length ( );\n    i ++ ) sum += num [ i ];\n    return ( sum % 3 == 0 && ( d2 * 10 + d1 ) % 4 == 0 );\n  }\n  else {\n    int number = stoi ( num );\n    return ( number % 12 == 0 );\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_36_CUT_A_ROPE_TO_MAXIMIZE_PRODUCT_1": "int maxProd ( int n ) {\n  if ( n == 2 || n == 3 ) return ( n - 1 );\n  int res = 1;\n  while ( n > 4 ) {\n    n -= 3;\n    res *= 3;\n  }\n  return ( n * res );\n}\n", "RETURN_A_PAIR_WITH_MAXIMUM_PRODUCT_IN_ARRAY_OF_INTEGERS": "void maxProduct ( int arr [ ], int n ) {\n  if ( n < 2 ) {\n    cout << \"No pairs exists\\n\";\n    return;\n  }\n  int a = arr [ 0 ], b = arr [ 1 ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( arr [ i ] * arr [ j ] > a * b ) a = arr [ i ], b = arr [ j ];\n  cout << \"Max product pair is {\" << a << \", \" << b << \"}\";\n}\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS_2": "int findSum ( int n ) {\n  n --;\n  int sum = 0;\n  sum += ( n * ( n + 1 ) ) / 2;\n  sum += ( n * ( n + 1 ) * ( 2 * n + 1 ) ) / 6;\n  return sum;\n}\n", "PRINT_MATRIX_ANTISPIRAL_FORM": "void antiSpiralTraversal ( int m, int n, int a [ R ] [ C ] ) {\n  int i, k = 0, l = 0;\n  stack < int > stk;\n  while ( k <= m && l <= n ) {\n    for ( i = l;\n    i <= n;\n    ++ i ) stk . push ( a [ k ] [ i ] );\n    k ++;\n    for ( i = k;\n    i <= m;\n    ++ i ) stk . push ( a [ i ] [ n ] );\n    n --;\n    if ( k <= m ) {\n      for ( i = n;\n      i >= l;\n      -- i ) stk . push ( a [ m ] [ i ] );\n      m --;\n    }\n    if ( l <= n ) {\n      for ( i = m;\n      i >= k;\n      -- i ) stk . push ( a [ i ] [ l ] );\n      l ++;\n    }\n  }\n  while ( ! stk . empty ( ) ) {\n    cout << stk . top ( ) << \" \";\n    stk . pop ( );\n  }\n}\n", "DICE_THROW_PROBLEM_1": "long findWays ( int f, int d, int s ) {\n  long mem [ d + 1 ] [ s + 1 ];\n  memset ( mem, 0, sizeof mem );\n  mem [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i <= d;\n  i ++ ) {\n    for ( int j = i;\n    j <= s;\n    j ++ ) {\n      mem [ i ] [ j ] = mem [ i ] [ j - 1 ] + mem [ i - 1 ] [ j - 1 ];\n      if ( j - f - 1 >= 0 ) mem [ i ] [ j ] -= mem [ i - 1 ] [ j - f - 1 ];\n    }\n  }\n  return mem [ d ] [ s ];\n}\n", "WRITE_A_C_PROGRAM_TO_CALCULATE_POWXN": "public : int power ( int x, unsigned int y ) {\n  if ( y == 0 ) return 1;\n  else if ( y % 2 == 0 ) return power ( x, y / 2 ) * power ( x, y / 2 );\n  else return x * power ( x, y / 2 ) * power ( x, y / 2 );\n}\n", "SMALLEST_WINDOW_CONTAINS_CHARACTERS_STRING": "string findSubString ( string str ) {\n  int n = str . length ( );\n  int dist_count = 0;\n  bool visited [ MAX_CHARS ] = {\n    false };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      if ( visited [ str [ i ] ] == false ) {\n        visited [ str [ i ] ] = true;\n        dist_count ++;\n      }\n    }\n    int start = 0, start_index = - 1, min_len = INT_MAX;\n    int count = 0;\n    int curr_count [ MAX_CHARS ] = {\n      0 };\n      for ( int j = 0;\n      j < n;\n      j ++ ) {\n        curr_count [ str [ j ] ] ++;\n        if ( curr_count [ str [ j ] ] == 1 ) count ++;\n        if ( count == dist_count ) {\n          while ( curr_count [ str [ start ] ] > 1 ) {\n            if ( curr_count [ str [ start ] ] > 1 ) curr_count [ str [ start ] ] --;\n            start ++;\n          }\n          int len_window = j - start + 1;\n          if ( min_len > len_window ) {\n            min_len = len_window;\n            start_index = start;\n          }\n        }\n      }\n      return str . substr ( start_index, min_len );\n    }\n    ", "CLUSTERINGPARTITIONING_AN_ARRAY_SUCH_THAT_SUM_OF_SQUARE_DIFFERENCES_IS_MINIMUM": "void solve ( int i, int par, int a [ ], int n, int k, int current_ans ) {\n  if ( par > k ) return;\n  if ( par == k && i == n - 1 ) {\n    ans = min ( ans, current_ans );\n    return;\n  }\n  for ( int j = i + 1;\n  j < n;\n  j ++ ) solve ( j, par + 1, a, n, k, current_ans + ( a [ j ] - a [ i + 1 ] ) * ( a [ j ] - a [ i + 1 ] ) );\n}\n", "PROGRAM_FIND_SMALLEST_LARGEST_WORD_STRING": "void minMaxLengthWords ( string input, string & minWord, string & maxWord ) {\n  int len = input . length ( );\n  int si = 0, ei = 0;\n  int min_length = len, min_start_index = 0, max_length = 0, max_start_index = 0;\n  while ( ei <= len ) {\n    if ( ei < len && input [ ei ] != ' ' ) ei ++;\n    else {\n      int curr_length = ei - si;\n      if ( curr_length < min_length ) {\n        min_length = curr_length;\n        min_start_index = si;\n      }\n      if ( curr_length > max_length ) {\n        max_length = curr_length;\n        max_start_index = si;\n      }\n      ei ++;\n      si = ei;\n    }\n  }\n  minWord = input . substr ( min_start_index, min_length );\n  maxWord = input . substr ( max_start_index, max_length );\n}\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M_1": "int isPossible ( int n, int index, int modulo, int M, int arr [ ], int dp [ ] [ MAX ] ) {\n  modulo = ( ( modulo % M ) + M ) % M;\n  if ( index == n ) {\n    if ( modulo == 0 ) return 1;\n    return 0;\n  }\n  if ( dp [ index ] [ modulo ] != - 1 ) return dp [ index ] [ modulo ];\n  int placeAdd = isPossible ( n, index + 1, modulo + arr [ index ], M, arr, dp );\n  int placeMinus = isPossible ( n, index + 1, modulo - arr [ index ], M, arr, dp );\n  bool res = ( placeAdd || placeMinus );\n  dp [ index ] [ modulo ] = res;\n  return res;\n}\n", "MINIMUM_OPERATION_MAKE_ELEMENTS_EQUAL_ARRAY": "int minOperation ( int arr [ ], int n ) {\n  unordered_map < int, int > hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hash [ arr [ i ] ] ++;\n  int max_count = 0;\n  for ( auto i : hash ) if ( max_count < i . second ) max_count = i . second;\n  return ( n - max_count );\n}\n", "HYPERCUBE_GRAPH": "int power ( int n ) {\n  if ( n == 1 ) return 2;\n  return 2 * power ( n - 1 );\n}\n", "PROGRAM_FIND_CORRELATION_COEFFICIENT": "float correlationCoefficient ( int X [ ], int Y [ ], int n ) {\n  int sum_X = 0, sum_Y = 0, sum_XY = 0;\n  int squareSum_X = 0, squareSum_Y = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\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  }\n  float corr = ( float ) ( n * sum_XY - sum_X * sum_Y ) / sqrt ( ( n * squareSum_X - sum_X * sum_X ) * ( n * squareSum_Y - sum_Y * sum_Y ) );\n  return corr;\n}\n", "COUNT_PALINDROMIC_SUBSEQUENCE_GIVEN_STRING": "int countPS ( string str ) {\n  int N = str . length ( );\n  int cps [ N + 1 ] [ N + 1 ];\n  memset ( cps, 0, sizeof ( cps ) );\n  for ( int i = 0;\n  i < N;\n  i ++ ) cps [ i ] [ i ] = 1;\n  for ( int L = 2;\n  L <= N;\n  L ++ ) {\n    for ( int i = 0;\n    i < N;\n    i ++ ) {\n      int k = L + i - 1;\n      if ( str [ i ] == str [ k ] ) cps [ i ] [ k ] = cps [ i ] [ k - 1 ] + cps [ i + 1 ] [ k ] + 1;\n      else cps [ i ] [ k ] = cps [ i ] [ k - 1 ] + cps [ i + 1 ] [ k ] - cps [ i + 1 ] [ k - 1 ];\n    }\n  }\n  return cps [ 0 ] [ N - 1 ];\n}\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N_1": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  unsigned int p = 1;\n  if ( n && ! ( n & ( n - 1 ) ) ) return n;\n  while ( p < n ) p <<= 1;\n  return p;\n}\n", "FIND_LAST_DIGIT_FACTORIAL_DIVIDES_FACTORIAL_B": "int computeLastDigit ( long long int A, long long int B ) {\n  int variable = 1;\n  if ( A == B ) return 1;\n  else if ( ( B - A ) >= 5 ) return 0;\n  else {\n    for ( long long int i = A + 1;\n    i <= B;\n    i ++ ) variable = ( variable * ( i % 10 ) ) % 10;\n    return variable % 10;\n  }\n}\n", "NUMBER_SUBSTRINGS_DIVISIBLE_4_STRING_INTEGERS": "int countDivisbleby4 ( char s [ ] ) {\n  int n = strlen ( s );\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) if ( s [ i ] == '4' || s [ i ] == '8' || s [ i ] == '0' ) count ++;\n  for ( int i = 0;\n  i < n - 1;\n  ++ i ) {\n    int h = ( s [ i ] - '0' ) * 10 + ( s [ i + 1 ] - '0' );\n    if ( h % 4 == 0 ) count = count + i + 1;\n  }\n  return count;\n}\n", "DECODE_MEDIAN_STRING_ORIGINAL_STRING": "string decodeMedianString ( string s ) {\n  int l = s . length ( );\n  string s1 = \"\";\n  bool isEven = ( l % 2 == 0 ) ? true : false;\n  for ( int i = 0;\n  i < l;\n  i += 2 ) {\n    if ( isEven ) {\n      s1 = s [ i ] + s1;\n      s1 += s [ i + 1 ];\n    }\n    else {\n      if ( l - i > 1 ) {\n        s1 += s [ i ];\n        s1 = s [ i + 1 ] + s1;\n      }\n      else {\n        s1 += s [ i ];\n      }\n    }\n  }\n  return s1;\n}\n", "NUMBER_WHICH_HAS_THE_MAXIMUM_NUMBER_OF_DISTINCT_PRIME_FACTORS_IN_RANGE_M_TO_N": "int maximumNumberDistinctPrimeRange ( int m, int n ) {\n  long long factorCount [ n + 1 ];\n  bool prime [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    factorCount [ i ] = 0;\n    prime [ i ] = true;\n  }\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    if ( prime [ i ] == true ) {\n      factorCount [ i ] = 1;\n      for ( int j = i * 2;\n      j <= n;\n      j += i ) {\n        factorCount [ j ] ++;\n        prime [ j ] = false;\n      }\n    }\n  }\n  int max = factorCount [ m ];\n  int num = m;\n  for ( int i = m;\n  i <= n;\n  i ++ ) {\n    if ( factorCount [ i ] > max ) {\n      max = factorCount [ i ];\n      num = i;\n    }\n  }\n  return num;\n}\n", "NUMBER_EQUAL_PAIRS_STRING": "int countPairs ( string s ) {\n  int cnt [ MAX ] = {\n    0 };\n    for ( int i = 0;\n    i < s . length ( );\n    i ++ ) cnt [ s [ i ] ] ++;\n    int ans = 0;\n    for ( int i = 0;\n    i < MAX;\n    i ++ ) ans += cnt [ i ] * cnt [ i ];\n    return ans;\n  }\n  ", "COUNT_NUMBER_WAYS_REACH_DESTINATION_MAZE": "int countPaths ( int maze [ ] [ C ] ) {\n  if ( maze [ 0 ] [ 0 ] == - 1 ) return 0;\n  for ( int i = 0;\n  i < R;\n  i ++ ) {\n    if ( maze [ i ] [ 0 ] == 0 ) maze [ i ] [ 0 ] = 1;\n    else break;\n  }\n  for ( int i = 1;\n  i < C;\n  i ++ ) {\n    if ( maze [ 0 ] [ i ] == 0 ) maze [ 0 ] [ i ] = 1;\n    else break;\n  }\n  for ( int i = 1;\n  i < R;\n  i ++ ) {\n    for ( int j = 1;\n    j < C;\n    j ++ ) {\n      if ( maze [ i ] [ j ] == - 1 ) continue;\n      if ( maze [ i - 1 ] [ j ] > 0 ) maze [ i ] [ j ] = ( maze [ i ] [ j ] + maze [ i - 1 ] [ j ] );\n      if ( maze [ i ] [ j - 1 ] > 0 ) maze [ i ] [ j ] = ( maze [ i ] [ j ] + maze [ i ] [ j - 1 ] );\n    }\n  }\n  return ( maze [ R - 1 ] [ C - 1 ] > 0 ) ? maze [ R - 1 ] [ C - 1 ] : 0;\n}\n", "FIND_MAXIMUM_SUM_POSSIBLE_EQUAL_SUM_THREE_STACKS": "int maxSum ( int stack1 [ ], int stack2 [ ], int stack3 [ ], int n1, int n2, int n3 ) {\n  int sum1 = 0, sum2 = 0, sum3 = 0;\n  for ( int i = 0;\n  i < n1;\n  i ++ ) sum1 += stack1 [ i ];\n  for ( int i = 0;\n  i < n2;\n  i ++ ) sum2 += stack2 [ i ];\n  for ( int i = 0;\n  i < n3;\n  i ++ ) sum3 += stack3 [ i ];\n  int top1 = 0, top2 = 0, top3 = 0;\n  int ans = 0;\n  while ( 1 ) {\n    if ( top1 == n1 || top2 == n2 || top3 == n3 ) return 0;\n    if ( sum1 == sum2 && sum2 == sum3 ) return sum1;\n    if ( sum1 >= sum2 && sum1 >= sum3 ) sum1 -= stack1 [ top1 ++ ];\n    else if ( sum2 >= sum3 && sum2 >= sum3 ) sum2 -= stack2 [ top2 ++ ];\n    else if ( sum3 >= sum2 && sum3 >= sum1 ) sum3 -= stack3 [ top3 ++ ];\n  }\n}\n", "MAXIMUM_SUM_SUBSEQUENCE_LEAST_K_DISTANT_ELEMENTS": "int maxSum ( int arr [ ], int N, int k ) {\n  int MS [ N ];\n  MS [ N - 1 ] = arr [ N - 1 ];\n  for ( int i = N - 2;\n  i >= 0;\n  i -- ) {\n    if ( i + k + 1 >= N ) MS [ i ] = max ( arr [ i ], MS [ i + 1 ] );\n    else MS [ i ] = max ( arr [ i ] + MS [ i + k + 1 ], MS [ i + 1 ] );\n  }\n  return MS [ 0 ];\n}\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD_1": "bool isEven ( int n ) {\n  return ( ! ( n & 1 ) );\n}\n", "SORT_ARRAY_TWO_HALVES_SORTED": "void mergeTwoHalf ( int A [ ], int n ) {\n  sort ( A, A + n );\n}\n", "PYTHAGOREAN_QUADRUPLE": "bool pythagorean_quadruple ( int a, int b, int c, int d ) {\n  int sum = a * a + b * b + c * c;\n  if ( d * d == sum ) return true;\n  else return false;\n}\n", "FIND_THE_MAXIMUM_OF_MINIMUMS_FOR_EVERY_WINDOW_SIZE_IN_A_GIVEN_ARRAY": "void printMaxOfMin ( int arr [ ], int n ) {\n  for ( int k = 1;\n  k <= n;\n  k ++ ) {\n    int maxOfMin = INT_MIN;\n    for ( int i = 0;\n    i <= n - k;\n    i ++ ) {\n      int min = arr [ i ];\n      for ( int j = 1;\n      j < k;\n      j ++ ) {\n        if ( arr [ i + j ] < min ) min = arr [ i + j ];\n      }\n      if ( min > maxOfMin ) maxOfMin = min;\n    }\n    cout << maxOfMin << \" \";\n  }\n}\n", "COUNT_SUM_OF_DIGITS_IN_NUMBERS_FROM_1_TO_N": "int sumOfDigitsFrom1ToN ( int n ) {\n  if ( n < 10 ) return n * ( n + 1 ) / 2;\n  int d = log10 ( n );\n  int * a = new int [ d + 1 ];\n  a [ 0 ] = 0, a [ 1 ] = 45;\n  for ( int i = 2;\n  i <= d;\n  i ++ ) a [ i ] = a [ i - 1 ] * 10 + 45 * ceil ( pow ( 10, i - 1 ) );\n  int p = ceil ( pow ( 10, d ) );\n  int msd = n / p;\n  return msd * a [ d ] + ( msd * ( msd - 1 ) / 2 ) * p + msd * ( 1 + n % p ) + sumOfDigitsFrom1ToN ( n % p );\n}\n", "RECURSIVELY_BREAK_NUMBER_3_PARTS_GET_MAXIMUM_SUM_1": "int breakSum ( int n ) {\n  int dp [ n + 1 ];\n  dp [ 0 ] = 0, dp [ 1 ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) dp [ i ] = max ( dp [ i / 2 ] + dp [ i / 3 ] + dp [ i / 4 ], i );\n  return dp [ n ];\n}\n", "FIND_REPEATING_ELEMENT_SORTED_ARRAY_SIZE_N": "int findRepeatingElement ( int arr [ ], int low, int high ) {\n  if ( low > high ) return - 1;\n  int mid = ( low + high ) / 2;\n  if ( arr [ mid ] != mid + 1 ) {\n    if ( mid > 0 && arr [ mid ] == arr [ mid - 1 ] ) return mid;\n    return findRepeatingElement ( arr, low, mid - 1 );\n  }\n  return findRepeatingElement ( arr, mid + 1, high );\n}\n", "COUNT_SUBARRAYS_EQUAL_NUMBER_1S_0S_1": "int countSubarrWithEqualZeroAndOne ( int arr [ ], int n ) {\n  map < int, int > mp;\n  int sum = 0;\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == 0 ) arr [ i ] = - 1;\n    sum += arr [ i ];\n    if ( sum == 0 ) count ++;\n    if ( mp [ sum ] ) count += mp [ sum ];\n    if ( mp [ sum ] == 0 ) mp [ sum ] = 1;\n    else mp [ sum ] ++;\n  }\n  return count;\n}\n", "UNION_AND_INTERSECTION_OF_TWO_SORTED_ARRAYS_2_1": "int printIntersection ( int arr1 [ ], int arr2 [ ], int m, int n ) {\n  int i = 0, j = 0;\n  while ( i < m && j < n ) {\n    if ( arr1 [ i ] < arr2 [ j ] ) i ++;\n    else if ( arr2 [ j ] < arr1 [ i ] ) j ++;\n    else {\n      cout << arr2 [ j ] << \" \";\n      i ++;\n      j ++;\n    }\n  }\n}\n", "COUNT_ALL_INCREASING_SUBSEQUENCES": "int countSub ( int arr [ ], int n ) {\n  int count [ 10 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      for ( int j = arr [ i ] - 1;\n      j >= 0;\n      j -- ) count [ arr [ i ] ] += count [ j ];\n      count [ arr [ i ] ] ++;\n    }\n    int result = 0;\n    for ( int i = 0;\n    i < 10;\n    i ++ ) result += count [ i ];\n    return result;\n  }\n  ", "SMALLEST_NUMBER_SUM_DIGITS_N_DIVISIBLE_10N": "void digitsNum ( int N ) {\n  if ( N == 0 ) cout << \"0\\n\";\n  if ( N % 9 != 0 ) cout << ( N % 9 );\n  for ( int i = 1;\n  i <= ( N / 9 );\n  ++ i ) cout << \"9\";\n  for ( int i = 1;\n  i <= N;\n  ++ i ) cout << \"0\";\n  cout << \"\\n\";\n}\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES_1": "int getOddOccurrence ( int arr [ ], int size ) {\n  unordered_map < int, int > hash;\n  for ( int i = 0;\n  i < size;\n  i ++ ) {\n    hash [ arr [ i ] ] ++;\n  }\n  for ( auto i : hash ) {\n    if ( i . second % 2 != 0 ) {\n      return i . first;\n    }\n  }\n  return - 1;\n}\n", "CHECK_IF_X_CAN_GIVE_CHANGE_TO_EVERY_PERSON_IN_THE_QUEUE": "int isChangeable ( int notes [ ], int n ) {\n  int fiveCount = 0;\n  int tenCount = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( notes [ i ] == 5 ) fiveCount ++;\n    else if ( notes [ i ] == 10 ) {\n      if ( fiveCount > 0 ) {\n        fiveCount --;\n        tenCount ++;\n      }\n      else return 0;\n    }\n    else {\n      if ( fiveCount > 0 && tenCount > 0 ) {\n        fiveCount --;\n        tenCount --;\n      }\n      else if ( fiveCount >= 3 ) {\n        fiveCount -= 3;\n      }\n      else return 0;\n    }\n  }\n  return 1;\n}\n", "MAXIMUM_MINIMUM_VALUES_ALGEBRAIC_EXPRESSION": "e9 int minMaxValues ( int arr [ ], int n, int m ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < ( n + m );\n  i ++ ) {\n    sum += arr [ i ];\n    arr [ i ] += 50;\n  }\n  bool dp [ MAX + 1 ] [ MAX * MAX + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 0;\n  i < ( n + m );\n  i ++ ) {\n    for ( int k = min ( n, i + 1 );\n    k >= 1;\n    k -- ) {\n      for ( int j = 0;\n      j < MAX * MAX + 1;\n      j ++ ) {\n        if ( dp [ k - 1 ] [ j ] ) dp [ k ] [ j + arr [ i ] ] = 1;\n      }\n    }\n  }\n  int max_value = - INF, min_value = INF;\n  for ( int i = 0;\n  i < MAX * MAX + 1;\n  i ++ ) {\n    if ( dp [ n ] [ i ] ) {\n      int temp = i - 50 * n;\n      max_value = max ( max_value, temp * ( sum - temp ) );\n      min_value = min ( min_value, temp * ( sum - temp ) );\n    }\n  }\n  cout << \"Maximum Value: \" << max_value << \"\\n\" << \"Minimum Value: \" << min_value << endl;\n}\n", "MULTIPLY_AN_INTEGER_WITH_3_5": "int multiplyWith3Point5 ( int x ) {\n  return ( x << 1 ) + x + ( x >> 1 );\n}\n", "MINIMUM_CELLS_REQUIRED_REACH_DESTINATION_JUMPS_EQUAL_CELL_VALUES": "int minCells ( int mat [ SIZE ] [ SIZE ], int m, int n ) {\n  int dp [ m ] [ n ];\n  for ( int i = 0;\n  i < m;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) dp [ i ] [ j ] = INT_MAX;\n  dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 0;\n  i < m;\n  i ++ ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( dp [ i ] [ j ] != INT_MAX && ( j + mat [ i ] [ j ] ) < n && ( dp [ i ] [ j ] + 1 ) < dp [ i ] [ j + mat [ i ] [ j ] ] ) dp [ i ] [ j + mat [ i ] [ j ] ] = dp [ i ] [ j ] + 1;\n      if ( dp [ i ] [ j ] != INT_MAX && ( i + mat [ i ] [ j ] ) < m && ( dp [ i ] [ j ] + 1 ) < dp [ i + mat [ i ] [ j ] ] [ j ] ) dp [ i + mat [ i ] [ j ] ] [ j ] = dp [ i ] [ j ] + 1;\n    }\n  }\n  if ( dp [ m - 1 ] [ n - 1 ] != INT_MAX ) return dp [ m - 1 ] [ n - 1 ];\n  return - 1;\n}\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY": "int findExtra ( int arr1 [ ], int arr2 [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr1 [ i ] != arr2 [ i ] ) return i;\n  return n;\n}\n", "CALCULATE_SUM_OF_ALL_NUMBERS_PRESENT_IN_A_STRING": "int findSum ( string str ) {\n  string temp = \"\";\n  int sum = 0;\n  for ( char ch : str ) {\n    if ( isdigit ( ch ) ) temp += ch;\n    else {\n      sum += atoi ( temp . c_str ( ) );\n      temp = \"\";\n    }\n  }\n  return sum + atoi ( temp . c_str ( ) );\n}\n", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED": "bool checkReverse ( int arr [ ], int n ) {\n  int temp [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) temp [ i ] = arr [ i ];\n  sort ( temp, temp + n );\n  int front;\n  for ( front = 0;\n  front < n;\n  front ++ ) if ( temp [ front ] != arr [ front ] ) break;\n  int back;\n  for ( back = n - 1;\n  back >= 0;\n  back -- ) if ( temp [ back ] != arr [ back ] ) break;\n  if ( front >= back ) return true;\n  do {\n    front ++;\n    if ( arr [ front - 1 ] < arr [ front ] ) return false;\n  }\n  while ( front != back );\n  return true;\n}\n", "GENERATE_PYTHAGORAS_TRIPLET_SINGLE_INTEGER": "void evaluate ( long long int n ) {\n  if ( n == 1 || n == 2 ) printf ( \"No Pythagoras Triplet exists\" );\n  else if ( n % 2 == 0 ) {\n    long long int var = 1LL * n * n / 4;\n    printf ( \"Pythagoras Triplets exist i.e. \" );\n    printf ( \"%lld %lld %lld\", n, var - 1, var + 1 );\n  }\n  else if ( n % 2 != 0 ) {\n    long long int var = 1LL * n * n + 1;\n    printf ( \"Pythagoras Triplets exist i.e. \" );\n    printf ( \"%lld %lld %lld\", n, var / 2 - 1, var / 2 );\n  }\n}\n", "PETERSON_GRAPH": "bool findthepath ( char * S, int v ) {\n  result [ 0 ] = v + '0';\n  for ( int i = 1;\n  S [ i ];\n  i ++ ) {\n    if ( adj [ v ] [ S [ i ] - 'A' ] || adj [ S [ i ] - 'A' ] [ v ] ) {\n      v = S [ i ] - 'A';\n    }\n    else if ( adj [ v ] [ S [ i ] - 'A' + 5 ] || adj [ S [ i ] - 'A' + 5 ] [ v ] ) {\n      v = S [ i ] - 'A' + 5;\n    }\n    else return false;\n    result [ i ] = v + '0';\n  }\n  return true;\n}\n", "COUNT_NUMBER_OF_SOLUTIONS_OF_X2_1_MOD_P_IN_GIVEN_RANGE": "int findCountOfSolutions ( int n, int p ) {\n  ll ans = 0;\n  for ( ll x = 1;\n  x < p;\n  x ++ ) {\n    if ( ( x * x ) % p == 1 ) {\n      ll last = x + p * ( n / p );\n      if ( last > n ) last -= p;\n      ans += ( ( last - x ) / p + 1 );\n    }\n  }\n  return ans;\n}\n", "JUMP_SEARCH": "int jumpSearch ( int arr [ ], int x, int n ) {\n  int step = sqrt ( n );\n  int prev = 0;\n  while ( arr [ min ( step, n ) - 1 ] < x ) {\n    prev = step;\n    step += sqrt ( n );\n    if ( prev >= n ) return - 1;\n  }\n  while ( arr [ prev ] < x ) {\n    prev ++;\n    if ( prev == min ( step, n ) ) return - 1;\n  }\n  if ( arr [ prev ] == x ) return prev;\n  return - 1;\n}\n", "FORM_MINIMUM_NUMBER_FROM_GIVEN_SEQUENCE": "void PrintMinNumberForPattern ( string arr ) {\n  int curr_max = 0;\n  int last_entry = 0;\n  int j;\n  for ( int i = 0;\n  i < arr . length ( );\n  i ++ ) {\n    int noOfNextD = 0;\n    switch ( arr [ i ] ) {\n      case 'I' : j = i + 1;\n      while ( arr [ j ] == 'D' && j < arr . length ( ) ) {\n        noOfNextD ++;\n        j ++;\n      }\n      if ( i == 0 ) {\n        curr_max = noOfNextD + 2;\n        cout << \" \" << ++ last_entry;\n        cout << \" \" << curr_max;\n        last_entry = curr_max;\n      }\n      else {\n        curr_max = curr_max + noOfNextD + 1;\n        last_entry = curr_max;\n        cout << \" \" << last_entry;\n      }\n      for ( int k = 0;\n      k < noOfNextD;\n      k ++ ) {\n        cout << \" \" << -- last_entry;\n        i ++;\n      }\n      break;\n      case 'D' : if ( i == 0 ) {\n        j = i + 1;\n        while ( arr [ j ] == 'D' && j < arr . length ( ) ) {\n          noOfNextD ++;\n          j ++;\n        }\n        curr_max = noOfNextD + 2;\n        cout << \" \" << curr_max << \" \" << curr_max - 1;\n        last_entry = curr_max - 1;\n      }\n      else {\n        cout << \" \" << last_entry - 1;\n        last_entry --;\n      }\n      break;\n    }\n  }\n  cout << endl;\n}\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8": "bool isSubSeqDivisible ( string str ) {\n  for ( int i = 0;\n  i < l;\n  i ++ ) {\n    for ( int j = i;\n    j < l;\n    j ++ ) {\n      for ( int k = j;\n      k < l;\n      k ++ ) {\n        if ( arr [ i ] % 8 == 0 ) return true;\n        else if ( ( arr [ i ] * 10 + arr [ j ] ) % 8 == 0 && i != j ) return true;\n        else if ( ( arr [ i ] * 100 + arr [ j ] * 10 + arr [ k ] ) % 8 == 0 && i != j && j != k && i != k ) return true;\n      }\n    }\n  }\n  return false;\n}\n", "PRINT_FIBONACCI_SEQUENCE_USING_2_VARIABLES": "void fib ( int n ) {\n  int a = 0, b = 1, c;\n  if ( n >= 0 ) cout << a << \" \";\n  if ( n >= 1 ) cout << b << \" \";\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    c = a + b;\n    cout << c << \" \";\n    a = b;\n    b = c;\n  }\n}\n", "INTERCHANGE_ELEMENTS_OF_FIRST_AND_LAST_ROWS_IN_MATRIX": "void interchangeFirstLast ( int m [ ] [ n ] ) {\n  int rows = n;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int t = m [ 0 ] [ i ];\n    m [ 0 ] [ i ] = m [ rows - 1 ] [ i ];\n    m [ rows - 1 ] [ i ] = t;\n  }\n}\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS": "int findSum ( int n ) {\n  int arr [ n ] [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) arr [ i ] [ j ] = abs ( i - j );\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) sum += arr [ i ] [ j ];\n  return sum;\n}\n", "FIND_THE_MAXIMUM_ELEMENT_IN_AN_ARRAY_WHICH_IS_FIRST_INCREASING_AND_THEN_DECREASING": "int findMaximum ( int arr [ ], int low, int high ) {\n  int max = arr [ low ];\n  int i;\n  for ( i = low + 1;\n  i <= high;\n  i ++ ) {\n    if ( arr [ i ] > max ) max = arr [ i ];\n    else break;\n  }\n  return max;\n}\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX_1": "bool isScalarMatrix ( int mat [ N ] [ N ] ) {\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < N;\n  j ++ ) if ( ( i != j ) && ( mat [ i ] [ j ] != 0 ) ) return false;\n  for ( int i = 0;\n  i < N - 1;\n  i ++ ) if ( mat [ i ] [ i ] != mat [ i + 1 ] [ i + 1 ] ) return false;\n  return true;\n}\n", "STOOGE_SORT": "void stoogesort ( int arr [ ], int l, int h ) {\n  if ( l >= h ) return;\n  if ( arr [ l ] > arr [ h ] ) swap ( arr [ l ], arr [ h ] );\n  if ( h - l + 1 > 2 ) {\n    int t = ( h - l + 1 ) / 3;\n    stoogesort ( arr, l, h - t );\n    stoogesort ( arr, l + t, h );\n    stoogesort ( arr, l, h - t );\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_11_EGG_DROPPING_PUZZLE": "int eggDrop ( int n, int k ) {\n  if ( k == 1 || k == 0 ) return k;\n  if ( n == 1 ) return k;\n  int min = INT_MAX, x, res;\n  for ( x = 1;\n  x <= k;\n  x ++ ) {\n    res = max ( eggDrop ( n - 1, x - 1 ), eggDrop ( n, k - x ) );\n    if ( res < min ) min = res;\n  }\n  return min + 1;\n}\n", "DIFFERENT_WAYS_SUM_N_USING_NUMBERS_GREATER_EQUAL_M": "int numberofways ( int n, int m ) {\n  int dp [ n + 2 ] [ n + 2 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ n + 1 ] = 1;\n  for ( int k = n;\n  k >= m;\n  k -- ) {\n    for ( int i = 0;\n    i <= n;\n    i ++ ) {\n      dp [ i ] [ k ] = dp [ i ] [ k + 1 ];\n      if ( i - k >= 0 ) dp [ i ] [ k ] = ( dp [ i ] [ k ] + dp [ i - k ] [ k ] );\n    }\n  }\n  return dp [ n ] [ m ];\n}\n", "BUBBLE_SORT": "void bubbleSort ( int arr [ ], int n ) {\n  int i, j;\n  for ( i = 0;\n  i < n - 1;\n  i ++ ) for ( j = 0;\n  j < n - i - 1;\n  j ++ ) if ( arr [ j ] > arr [ j + 1 ] ) swap ( & arr [ j ], & arr [ j + 1 ] );\n}\n", "GENERATE_ROTATIONS_GIVEN_STRING": "void printRotatedString ( char str [ ] ) {\n  int len = strlen ( str );\n  char temp [ len ];\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    int j = i;\n    int k = 0;\n    while ( str [ j ] != '\\0' ) {\n      temp [ k ] = str [ j ];\n      k ++;\n      j ++;\n    }\n    j = 0;\n    while ( j < i ) {\n      temp [ k ] = str [ j ];\n      j ++;\n      k ++;\n    }\n    printf ( \"%s\\n\", temp );\n  }\n}\n", "MID_POINT_LINE_GENERATION_ALGORITHM": "void midPoint ( int X1, int Y1, int X2, int Y2 ) {\n  int dx = X2 - X1;\n  int dy = Y2 - Y1;\n  int d = dy - ( dx / 2 );\n  int x = X1, y = Y1;\n  cout << x << \",\" << y << \"\\n\";\n  while ( x < X2 ) {\n    x ++;\n    if ( d < 0 ) d = d + dy;\n    else {\n      d += ( dy - dx );\n      y ++;\n    }\n    cout << x << \",\" << y << \"\\n\";\n  }\n}\n", "FINDING_VERTEX_FOCUS_DIRECTRIX_PARABOLA": "void parabola ( float a, float b, float c ) {\n  cout << \"Vertex: (\" << ( - b / ( 2 * a ) ) << \", \" << ( ( ( 4 * a * c ) - ( b * b ) ) / ( 4 * a ) ) << \")\" << endl;\n  cout << \"Focus: (\" << ( - b / ( 2 * a ) ) << \", \" << ( ( ( 4 * a * c ) - ( b * b ) + 1 ) / ( 4 * a ) ) << \")\" << endl;\n  cout << \"Directrix: y=\" << c - ( ( b * b ) + 1 ) * 4 * a << endl;\n}\n", "TRIANGULAR_NUMBERS": "bool isTriangular ( int num ) {\n  if ( num < 0 ) return false;\n  int sum = 0;\n  for ( int n = 1;\n  sum <= num;\n  n ++ ) {\n    sum = sum + n;\n    if ( sum == num ) return true;\n  }\n  return false;\n}\n", "PIZZA_CUT_PROBLEM_CIRCLE_DIVISION_LINES": "int findMaximumPieces ( int n ) {\n  return 1 + n * ( n + 1 ) / 2;\n}\n", "MINIMUM_TIME_WRITE_CHARACTERS_USING_INSERT_DELETE_COPY_OPERATION": "int minTimeForWritingChars ( int N, int insert, int remove, int copy ) {\n  if ( N == 0 ) return 0;\n  if ( N == 1 ) return insert;\n  int dp [ N + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 1;\n  i <= N;\n  i ++ ) {\n    if ( i % 2 == 0 ) dp [ i ] = min ( dp [ i - 1 ] + insert, dp [ i / 2 ] + copy );\n    else dp [ i ] = min ( dp [ i - 1 ] + insert, dp [ ( i + 1 ) / 2 ] + copy + remove );\n  }\n  return dp [ N ];\n}\n", "SEARCHING_ARRAY_ADJACENT_DIFFER_K": "int search ( int arr [ ], int n, int x, int k ) {\n  int i = 0;\n  while ( i < n ) {\n    if ( arr [ i ] == x ) return i;\n    i = i + max ( 1, abs ( arr [ i ] - x ) / k );\n  }\n  cout << \"number is not present!\";\n  return - 1;\n}\n", "FIND_MAXIMUM_PRODUCT_OF_A_TRIPLET_IN_ARRAY": "int maxProduct ( int arr [ ], int n ) {\n  if ( n < 3 ) return - 1;\n  int max_product = INT_MIN;\n  for ( int i = 0;\n  i < n - 2;\n  i ++ ) for ( int j = i + 1;\n  j < n - 1;\n  j ++ ) for ( int k = j + 1;\n  k < n;\n  k ++ ) max_product = max ( max_product, arr [ i ] * arr [ j ] * arr [ k ] );\n  return max_product;\n}\n", "LONGEST_PALINDROME_SUBSEQUENCE_SPACE": "int lps ( string & s ) {\n  int n = s . length ( );\n  int a [ n ];\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    int back_up = 0;\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      if ( j == i ) a [ j ] = 1;\n      else if ( s [ i ] == s [ j ] ) {\n        int temp = a [ j ];\n        a [ j ] = back_up + 2;\n        back_up = temp;\n      }\n      else {\n        back_up = a [ j ];\n        a [ j ] = max ( a [ j - 1 ], a [ j ] );\n      }\n    }\n  }\n  return a [ n - 1 ];\n}\n", "CHECK_HALF_STRING_CHARACTER_FREQUENCY_CHARACTER_1": "bool checkCorrectOrNot ( string s ) {\n  int count [ MAX_CHAR ] = {\n    0 };\n    int n = s . length ( );\n    if ( n == 1 ) return true;\n    for ( int i = 0, j = n - 1;\n    i < j;\n    i ++, j -- ) {\n      count [ s [ i ] - 'a' ] ++;\n      count [ s [ j ] - 'a' ] --;\n    }\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) if ( count [ i ] != 0 ) return false;\n    return true;\n  }\n  ", "EXPONENTIAL_SQUARING_FAST_MODULO_MULTIPLICATION": "long int exponentiation ( long int base, long int exp ) {\n  if ( exp == 0 ) return 1;\n  if ( exp == 1 ) return base % N;\n  long int t = exponentiation ( base, exp / 2 );\n  t = ( t * t ) % N;\n  if ( exp % 2 == 0 ) return t;\n  else return ( ( base % N ) * t ) % N;\n}\n", "REMOVE_MINIMUM_NUMBER_ELEMENTS_NO_COMMON_ELEMENT_EXIST_ARRAY": "int minRemove ( int a [ ], int b [ ], int n, int m ) {\n  unordered_map < int, int > countA, countB;\n  for ( int i = 0;\n  i < n;\n  i ++ ) countA [ a [ i ] ] ++;\n  for ( int i = 0;\n  i < m;\n  i ++ ) countB [ b [ i ] ] ++;\n  int res = 0;\n  for ( auto x : countA ) if ( countB . find ( x . first ) != countB . end ( ) ) res += min ( x . second, countB [ x . first ] );\n  return res;\n}\n", "FIND_A_FIXED_POINT_IN_A_GIVEN_ARRAY": "int linearSearch ( int arr [ ], int n ) {\n  int i;\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] == i ) return i;\n  }\n  return - 1;\n}\n", "ADD_1_TO_A_GIVEN_NUMBER": "int addOne ( int x ) {\n  int m = 1;\n  while ( x & m ) {\n    x = x ^ m;\n    m <<= 1;\n  }\n  x = x ^ m;\n  return x;\n}\n", "HEIGHT_COMPLETE_BINARY_TREE_HEAP_N_NODES": "int height ( int N ) {\n  return ceil ( log2 ( N + 1 ) ) - 1;\n}\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY": "int minJumps ( int arr [ ], int n ) {\n  if ( n == 1 ) return 0;\n  int res = INT_MAX;\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( i + arr [ i ] >= n - 1 ) {\n      int sub_res = minJumps ( arr, i + 1 );\n      if ( sub_res != INT_MAX ) res = min ( res, sub_res + 1 );\n    }\n  }\n  return res;\n}\n", "PROGRAM_FOR_NTH_FIBONACCI_NUMBER_2": "int fib ( int n ) {\n  if ( n == 0 ) return 0;\n  if ( n == 1 || n == 2 ) return ( f [ n ] = 1 );\n  if ( f [ n ] ) return f [ n ];\n  int k = ( n & 1 ) ? ( n + 1 ) / 2 : n / 2;\n  f [ n ] = ( n & 1 ) ? ( fib ( k ) * fib ( k ) + fib ( k - 1 ) * fib ( k - 1 ) ) : ( 2 * fib ( k - 1 ) + fib ( k ) ) * fib ( k );\n  return f [ n ];\n}\n", "DECODE_STRING_RECURSIVELY_ENCODED_COUNT_FOLLOWED_SUBSTRING": "string decode ( string str ) {\n  stack < int > integerstack;\n  stack < char > stringstack;\n  string temp = \"\", result = \"\";\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    int count = 0;\n    if ( str [ i ] >= '0' && str [ i ] <= '9' ) {\n      while ( str [ i ] >= '0' && str [ i ] <= '9' ) {\n        count = count * 10 + str [ i ] - '0';\n        i ++;\n      }\n      i --;\n      integerstack . push ( count );\n    }\n    else if ( str [ i ] == ']' ) {\n      temp = \"\";\n      count = 0;\n      if ( ! integerstack . empty ( ) ) {\n        count = integerstack . top ( );\n        integerstack . pop ( );\n      }\n      while ( ! stringstack . empty ( ) && stringstack . top ( ) != '[' ) {\n        temp = stringstack . top ( ) + temp;\n        stringstack . pop ( );\n      }\n      if ( ! stringstack . empty ( ) && stringstack . top ( ) == '[' ) stringstack . pop ( );\n      for ( int j = 0;\n      j < count;\n      j ++ ) result = result + temp;\n      for ( int j = 0;\n      j < result . length ( );\n      j ++ ) stringstack . push ( result [ j ] );\n      result = \"\";\n    }\n    else if ( str [ i ] == '[' ) {\n      if ( str [ i - 1 ] >= '0' && str [ i - 1 ] <= '9' ) stringstack . push ( str [ i ] );\n      else {\n        stringstack . push ( str [ i ] );\n        integerstack . push ( 1 );\n      }\n    }\n    else stringstack . push ( str [ i ] );\n  }\n  while ( ! stringstack . empty ( ) ) {\n    result = stringstack . top ( ) + result;\n    stringstack . pop ( );\n  }\n  return result;\n}\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP": "bool isHeap ( int arr [ ], int i, int n ) {\n  if ( i > ( n - 2 ) / 2 ) return true;\n  if ( arr [ i ] >= arr [ 2 * i + 1 ] && arr [ i ] >= arr [ 2 * i + 2 ] && isHeap ( arr, 2 * i + 1, n ) && isHeap ( arr, 2 * i + 2, n ) ) return true;\n  return false;\n}\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP_1": "bool isHeap ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i <= ( n - 2 ) / 2;\n  i ++ ) {\n    if ( arr [ 2 * i + 1 ] > arr [ i ] ) return false;\n    if ( 2 * i + 2 < n && arr [ 2 * i + 2 ] > arr [ i ] ) return false;\n  }\n  return true;\n}\n", "CALCULATE_ANGLE_HOUR_HAND_MINUTE_HAND": "int calcAngle ( double h, double m ) {\n  if ( h < 0 || m < 0 || h > 12 || m > 60 ) printf ( \"Wrong input\" );\n  if ( h == 12 ) h = 0;\n  if ( m == 60 ) m = 0;\n  int hour_angle = 0.5 * ( h * 60 + m );\n  int minute_angle = 6 * m;\n  int angle = abs ( hour_angle - minute_angle );\n  angle = min ( 360 - angle, angle );\n  return angle;\n}\n", "CONVERTING_DECIMAL_NUMBER_LYING_BETWEEN_1_TO_3999_TO_ROMAN_NUMERALS": "int printRoman ( int number ) {\n  int num [ ] = {\n    1, 4, 5, 9, 10, 40, 50, 90, 100, 400, 500, 900, 1000 };\n    string sym [ ] = {\n      \"I\", \"IV\", \"V\", \"IX\", \"X\", \"XL\", \"L\", \"XC\", \"C\", \"CD\", \"D\", \"CM\", \"M\" };\n      int i = 12;\n      while ( number > 0 ) {\n        int div = number / num [ i ];\n        number = number % num [ i ];\n        while ( div -- ) {\n          cout << sym [ i ];\n        }\n        i --;\n      }\n    }\n    ", "SORTING_USING_TRIVIAL_HASH_FUNCTION": "void sortUsingHash ( int a [ ], int n ) {\n  int max = * std :: max_element ( a, a + n );\n  int hash [ max + 1 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) hash [ a [ i ] ] += 1;\n    for ( int i = 0;\n    i <= max;\n    i ++ ) {\n      if ( hash [ i ] ) {\n        for ( int j = 0;\n        j < hash [ i ];\n        j ++ ) {\n          cout << i << \" \";\n        }\n      }\n    }\n  }\n  ", "SUM_PAIRWISE_PRODUCTS_2": "long long int findSum ( int n ) {\n  return n * ( n + 1 ) * ( n + 2 ) * ( 3 * n + 1 ) / 24;\n}\n", "ENTRINGER_NUMBER": "int zigzag ( int n, int k ) {\n  if ( n == 0 && k == 0 ) return 1;\n  if ( k == 0 ) return 0;\n  return zigzag ( n, k - 1 ) + zigzag ( n - 1, n - k );\n}\n", "MINIMUM_SUM_TWO_NUMBERS_FORMED_DIGITS_ARRAY_2": "int minSum ( int a [ ], int n ) {\n  sort ( a, a + n );\n  int num1 = 0;\n  int num2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i % 2 == 0 ) num1 = num1 * 10 + a [ i ];\n    else num2 = num2 * 10 + a [ i ];\n  }\n  return num2 + num1;\n}\n", "SUBARRAY_NO_PAIR_SUM_DIVISIBLE_K": "void subarrayDivisibleByK ( int arr [ ], int n, int k ) {\n  map < int, int > mp;\n  int s = 0, e = 0, maxs = 0, maxe = 0;\n  mp [ arr [ 0 ] % k ] ++;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int mod = arr [ i ] % k;\n    while ( mp [ k - mod ] != 0 || ( mod == 0 && mp [ mod ] != 0 ) ) {\n      mp [ arr [ s ] % k ] --;\n      s ++;\n    }\n    mp [ mod ] ++;\n    e ++;\n    if ( ( e - s ) > ( maxe - maxs ) ) {\n      maxe = e;\n      maxs = s;\n    }\n  }\n  cout << \"The maximum size is \" << maxe - maxs + 1 << \" and \" \"the subarray is as follows\\n\";\n  for ( int i = maxs;\n  i <= maxe;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_K_TIMES": "int maxProfit ( int price [ ], int n, int k ) {\n  int profit [ k + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= k;\n  i ++ ) profit [ i ] [ 0 ] = 0;\n  for ( int j = 0;\n  j <= n;\n  j ++ ) profit [ 0 ] [ j ] = 0;\n  for ( int i = 1;\n  i <= k;\n  i ++ ) {\n    for ( int j = 1;\n    j < n;\n    j ++ ) {\n      int max_so_far = INT_MIN;\n      for ( int m = 0;\n      m < j;\n      m ++ ) max_so_far = max ( max_so_far, price [ j ] - price [ m ] + profit [ i - 1 ] [ m ] );\n      profit [ i ] [ j ] = max ( profit [ i ] [ j - 1 ], max_so_far );\n    }\n  }\n  return profit [ k ] [ n - 1 ];\n}\n", "MINIMIZE_SUM_PRODUCT_TWO_ARRAYS_PERMUTATIONS_ALLOWED": "int minValue ( int A [ ], int B [ ], int n ) {\n  sort ( A, A + n );\n  sort ( B, B + n );\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) result += ( A [ i ] * B [ n - i - 1 ] );\n  return result;\n}\n", "FIND_MAXIMUM_ELEMENT_ROW_MATRIX": "void maxelement ( int no_of_rows, int arr [ ] [ N ] ) {\n  int i = 0;\n  int max = 0;\n  int result [ no_of_rows ];\n  while ( i < no_of_rows ) {\n    for ( int j = 0;\n    j < N;\n    j ++ ) {\n      if ( arr [ i ] [ j ] > max ) {\n        max = arr [ i ] [ j ];\n      }\n    }\n    result [ i ] = max;\n    max = 0;\n    i ++;\n  }\n  printArray ( result, no_of_rows );\n}\n", "ROUND_OFF_NUMBER_GIVEN_NUMBER_SIGNIFICANT_DIGITS": "void Round_off ( double N, double n ) {\n  int h;\n  double l, a, b, c, d, e, i, j, m, f, g;\n  b = N;\n  c = floor ( N );\n  for ( i = 0;\n  b >= 1;\n  ++ i ) b = b / 10;\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    }\n  }\n  j = floor ( e );\n  m = pow ( 10, d );\n  j = j / m;\n  cout << \"The number after rounding-off is \" << j;\n}\n", "CHECK_WHETHER_POINT_EXISTS_CIRCLE_SECTOR_NOT": "void checkPoint ( int radius, int x, int y, float percent, float startAngle ) {\n  float endAngle = 360 / percent + startAngle;\n  float polarradius = sqrt ( x * x + y * y );\n  float Angle = atan ( y / x );\n  if ( Angle >= startAngle && Angle <= endAngle && polarradius < radius ) printf ( \"Point (%d, %d) exist in the circle sector\\n\", x, y );\n  else printf ( \"Point (%d, %d) does not exist in the circle sector\\n\", x, y );\n}\n", "NUMBER_IS_DIVISIBLE_BY_29_OR_NOT": "bool isDivisible ( long long int n ) {\n  while ( n / 100 ) {\n    int last_digit = n % 10;\n    n /= 10;\n    n += last_digit * 3;\n  }\n  return ( n % 29 == 0 );\n}\n", "PRINT_ALL_DISTINCT_CHARACTERS_OF_A_STRING_IN_ORDER_3_METHODS": "void printDistinct ( char * str ) {\n  int count [ NO_OF_CHARS ];\n  int i;\n  for ( i = 0;\n  * ( str + i );\n  i ++ ) if ( * ( str + i ) != ' ' ) count [ * ( str + i ) ] ++;\n  int n = i;\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( count [ * ( str + i ) ] == 1 ) cout << str [ i ];\n}\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE": "void recursiveReverse ( string & str ) {\n  stack < char > st;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) st . push ( str [ i ] );\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    str [ i ] = st . top ( );\n    st . pop ( );\n  }\n}\n", "PAINTING_FENCE_ALGORITHM": "long countWays ( int n, int k ) {\n  long total = k;\n  int mod = 1000000007;\n  int same = 0, diff = k;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    same = diff;\n    diff = total * ( k - 1 );\n    diff = diff % mod;\n    total = ( same + diff ) % mod;\n  }\n  return total;\n}\n", "COUNT_OF_SUB_STRINGS_THAT_DO_NOT_CONTAIN_ALL_THE_CHARACTERS_FROM_THE_SET_A_B_C_AT_THE_SAME_TIME": "int CountSubstring ( char str [ ], int n ) {\n  int ans = ( n * ( n + 1 ) ) / 2;\n  int a_index = 0;\n  int b_index = 0;\n  int c_index = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( str [ i ] == 'a' ) {\n      a_index = i + 1;\n      ans -= min ( b_index, c_index );\n    }\n    else if ( str [ i ] == 'b' ) {\n      b_index = i + 1;\n      ans -= min ( a_index, c_index );\n    }\n    else {\n      c_index = i + 1;\n      ans -= min ( a_index, b_index );\n    }\n  }\n  return ans;\n}\n", "CALCULATING_FACTORIALS_USING_STIRLING_APPROXIMATION": "long int stirlingFactorial ( int n ) {\n  if ( n == 1 ) return 1;\n  long int z;\n  float e = 2.71;\n  z = sqrt ( 2 * 3.14 * n ) * pow ( ( n / e ), n );\n  return z;\n}\n", "LEXICOGRAPHICALLY_SMALLEST_STRING_OBTAINED_CONCATENATING_ARRAY": "string lexSmallest ( string a [ ], int n ) {\n  sort ( a, a + n, compare );\n  string answer = \"\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) answer += a [ i ];\n  return answer;\n}\n", "PRODUCT_MAXIMUM_FIRST_ARRAY_MINIMUM_SECOND": "int minMaxProduct ( int arr1 [ ], int arr2 [ ], int n1, int n2 ) {\n  sort ( arr1, arr1 + n1 );\n  sort ( arr2, arr2 + n2 );\n  return arr1 [ n1 - 1 ] * arr2 [ 0 ];\n}\n", "FIND_IF_THERE_IS_A_SUBARRAY_WITH_0_SUM": "bool subArrayExists ( int arr [ ], int n ) {\n  unordered_set < int > sumSet;\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ];\n    if ( sum == 0 || sumSet . find ( sum ) != sumSet . end ( ) ) return true;\n    sumSet . insert ( sum );\n  }\n  return false;\n}\n", "MINIMUM_PRODUCT_SUBSET_ARRAY": "int minProductSubset ( int a [ ], int n ) {\n  if ( n == 1 ) return a [ 0 ];\n  int max_neg = INT_MIN;\n  int min_pos = INT_MAX;\n  int count_neg = 0, count_zero = 0;\n  int prod = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] == 0 ) {\n      count_zero ++;\n      continue;\n    }\n    if ( a [ i ] < 0 ) {\n      count_neg ++;\n      max_neg = max ( max_neg, a [ i ] );\n    }\n    if ( a [ i ] > 0 ) min_pos = min ( min_pos, a [ i ] );\n    prod = prod * a [ i ];\n  }\n  if ( count_zero == n || ( count_neg == 0 && count_zero > 0 ) ) return 0;\n  if ( count_neg == 0 ) return min_pos;\n  if ( ! ( count_neg & 1 ) && count_neg != 0 ) {\n    prod = prod / max_neg;\n  }\n  return prod;\n}\n", "NUMBER_NODES_TWO_VERTICES_ACYCLIC_GRAPH_DISJOINT_UNION_METHOD": "int totalNodes ( vector < int > adjac [ ], int n, int x, int y ) {\n  bool visited [ n + 1 ] = {\n    0 };\n    int p [ n ];\n    queue < int > q;\n    q . push ( x );\n    visited [ x ] = true;\n    int m;\n    while ( ! q . empty ( ) ) {\n      m = q . front ( );\n      q . pop ( );\n      for ( int i = 0;\n      i < adjac [ m ] . size ( );\n      ++ i ) {\n        int h = adjac [ m ] [ i ];\n        if ( ! visited [ h ] ) {\n          visited [ h ] = true;\n          p [ h ] = m;\n          q . push ( h );\n        }\n      }\n    }\n    int count = 0;\n    int i = p [ y ];\n    while ( i != x ) {\n      count ++;\n      i = p [ i ];\n    }\n    return count;\n  }\n  ", "PRINTING_STRING_PLUS_PATTERN_MATRIX": "void carveCross ( string str ) {\n  int n = str . length ( );\n  if ( n % 2 == 0 ) {\n    cout << \"Not possible. Please enter \" << \"odd length string.\\n\";\n  }\n  else {\n    char arr [ max ] [ max ];\n    int m = n / 2;\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      for ( int j = 0;\n      j < n;\n      j ++ ) {\n        arr [ i ] [ j ] = 'X';\n      }\n    }\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      arr [ i ] [ m ] = str [ i ];\n    }\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      arr [ m ] [ i ] = str [ i ];\n    }\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      for ( int j = 0;\n      j < n;\n      j ++ ) {\n        cout << arr [ i ] [ j ] << \" \";\n      }\n      cout << \"\\n\";\n    }\n  }\n}\n", "NEXT_GREATER_FREQUENCY_ELEMENT": "void NFG ( int a [ ], int n, int freq [ ] ) {\n  stack < int > s;\n  s . push ( 0 );\n  int res [ n ] = {\n    0 };\n    for ( int i = 1;\n    i < n;\n    i ++ ) {\n      if ( freq [ a [ s . top ( ) ] ] > freq [ a [ i ] ] ) s . push ( i );\n      else {\n        while ( freq [ a [ s . top ( ) ] ] < freq [ a [ i ] ] && ! s . empty ( ) ) {\n          res [ s . top ( ) ] = a [ i ];\n          s . pop ( );\n        }\n        s . push ( i );\n      }\n    }\n    while ( ! s . empty ( ) ) {\n      res [ s . top ( ) ] = - 1;\n      s . pop ( );\n    }\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      cout << res [ i ] << \" \";\n    }\n  }\n  ", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED_1": "bool checkReverse ( int arr [ ], int n ) {\n  if ( n == 1 ) return true;\n  int i;\n  for ( i = 1;\n  i < n && arr [ i - 1 ] < arr [ i ];\n  i ++ );\n  if ( i == n ) return true;\n  int j = i;\n  while ( arr [ j ] < arr [ j - 1 ] ) {\n    if ( i > 1 && arr [ j ] < arr [ i - 2 ] ) return false;\n    j ++;\n  }\n  if ( j == n ) return true;\n  int k = j;\n  if ( arr [ k ] < arr [ i - 1 ] ) return false;\n  while ( k > 1 && k < n ) {\n    if ( arr [ k ] < arr [ k - 1 ] ) return false;\n    k ++;\n  }\n  return true;\n}\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_2": "void findTriplets ( int arr [ ], int n ) {\n  bool found = false;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    int l = i + 1;\n    int r = n - 1;\n    int x = arr [ i ];\n    while ( l < r ) {\n      if ( x + arr [ l ] + arr [ r ] == 0 ) {\n        printf ( \"%d %d %d\\n\", x, arr [ l ], arr [ r ] );\n        l ++;\n        r --;\n        found = true;\n      }\n      else if ( x + arr [ l ] + arr [ r ] < 0 ) l ++;\n      else r --;\n    }\n  }\n  if ( found == false ) cout << \" No Triplet Found\" << endl;\n}\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS": "void findElements ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int count = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) if ( arr [ j ] > arr [ i ] ) count ++;\n    if ( count >= 2 ) cout << arr [ i ] << \" \";\n  }\n}\n", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS_1": "void printArray ( int * a, int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << a [ i ] << \" \";\n  cout << endl;\n  return;\n}\n", "FIND_MINIMUM_RADIUS_ATLEAST_K_POINT_LIE_INSIDE_CIRCLE": "int minRadius ( int k, int x [ ], int y [ ], int n ) {\n  int dis [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) dis [ i ] = x [ i ] * x [ i ] + y [ i ] * y [ i ];\n  sort ( dis, dis + n );\n  return dis [ k - 1 ];\n}\n", "COUNT_SUBARRAYS_EQUAL_NUMBER_1S_0S": "int countSubarrWithEqualZeroAndOne ( int arr [ ], int n ) {\n  unordered_map < int, int > um;\n  int curr_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    curr_sum += ( arr [ i ] == 0 ) ? - 1 : arr [ i ];\n    um [ curr_sum ] ++;\n  }\n  int count = 0;\n  for ( auto itr = um . begin ( );\n  itr != um . end ( );\n  itr ++ ) {\n    if ( itr -> second > 1 ) count += ( ( itr -> second * ( itr -> second - 1 ) ) / 2 );\n  }\n  if ( um . find ( 0 ) != um . end ( ) ) count += um [ 0 ];\n  return count;\n}\n", "MINIMUM_INDEX_SUM_COMMON_ELEMENTS_TWO_LISTS": "void find ( vector < string > list1, vector < string > list2 ) {\n  vector < string > res;\n  int max_possible_sum = list1 . size ( ) + list2 . size ( ) - 2;\n  for ( int sum = 0;\n  sum <= max_possible_sum;\n  sum ++ ) {\n    for ( int i = 0;\n    i <= sum;\n    i ++ ) if ( i < list1 . size ( ) && ( sum - i ) < list2 . size ( ) && list1 [ i ] == list2 [ sum - i ] ) res . push_back ( list1 [ i ] );\n    if ( res . size ( ) > 0 ) break;\n  }\n  for ( int i = 0;\n  i < res . size ( );\n  i ++ ) cout << res [ i ] << \" \";\n}\n", "CHECK_IF_A_NUMBER_IS_JUMBLED_OR_NOT": "bool checkJumbled ( int num ) {\n  if ( num / 10 == 0 ) return true;\n  while ( num != 0 ) {\n    if ( num / 10 == 0 ) return true;\n    int digit1 = num % 10;\n    int digit2 = ( num / 10 ) % 10;\n    if ( abs ( digit2 - digit1 ) > 1 ) return false;\n    num = num / 10;\n  }\n  return true;\n}\n", "CEILING_IN_A_SORTED_ARRAY_1": "int ceilSearch ( int arr [ ], int low, int high, int x ) {\n  int mid;\n  if ( x <= arr [ low ] ) return low;\n  if ( x > arr [ high ] ) return - 1;\n  mid = ( low + high ) / 2;\n  if ( arr [ mid ] == x ) return mid;\n  else if ( arr [ mid ] < x ) {\n    if ( mid + 1 <= high && x <= arr [ mid + 1 ] ) return mid + 1;\n    else return ceilSearch ( arr, mid + 1, high, x );\n  }\n  else {\n    if ( mid - 1 >= low && x > arr [ mid - 1 ] ) return mid;\n    else return ceilSearch ( arr, low, mid - 1, x );\n  }\n}\n", "GIVEN_P_AND_N_FIND_THE_LARGEST_X_SUCH_THAT_PX_DIVIDES_N_2": "int largestPower ( int n, int p ) {\n  int x = 0;\n  while ( n ) {\n    n /= p;\n    x += n;\n  }\n  return x;\n}\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY": "int maxSum ( int arr [ ], int n ) {\n  int res = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int curr_sum = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      int index = ( i + j ) % n;\n      curr_sum += j * arr [ index ];\n    }\n    res = max ( res, curr_sum );\n  }\n  return res;\n}\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE_1": "int smallestSubWithSum ( int arr [ ], int n, int x ) {\n  int curr_sum = 0, min_len = n + 1;\n  int start = 0, end = 0;\n  while ( end < n ) {\n    while ( curr_sum <= x && end < n ) {\n      if ( curr_sum <= 0 && x > 0 ) {\n        start = end;\n        curr_sum = 0;\n      }\n      curr_sum += arr [ end ++ ];\n    }\n    while ( curr_sum > x && start < n ) {\n      if ( end - start < min_len ) min_len = end - start;\n      curr_sum -= arr [ start ++ ];\n    }\n  }\n  return min_len;\n}\n", "LEXICOGRAPHICALLY_SMALLEST_STRING_WHOSE_HAMMING_DISTANCE_GIVEN_STRING_EXACTLY_K": "void findString ( string str, int n, int k ) {\n  if ( k == 0 ) {\n    cout << str << endl;\n    return;\n  }\n  string str2 = str;\n  int p = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( str2 [ i ] != 'a' ) {\n      str2 [ i ] = 'a';\n      p ++;\n      if ( p == k ) break;\n    }\n  }\n  if ( p < k ) {\n    for ( int i = n - 1;\n    i >= 0;\n    i -- ) if ( str [ i ] == 'a' ) {\n      str2 [ i ] = 'b';\n      p ++;\n      if ( p == k ) break;\n    }\n  }\n  cout << str2 << endl;\n}\n", "SUBSET_SUM_DIVISIBLE_M": "bool modularSum ( int arr [ ], int n, int m ) {\n  if ( n > m ) return true;\n  bool DP [ m ];\n  memset ( DP, false, m );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( DP [ 0 ] ) return true;\n    bool temp [ m ];\n    memset ( temp, false, m );\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( DP [ j ] == true ) {\n        if ( DP [ ( j + arr [ i ] ) % m ] == false ) temp [ ( j + arr [ i ] ) % m ] = true;\n      }\n    }\n    for ( int j = 0;\n    j < m;\n    j ++ ) if ( temp [ j ] ) DP [ j ] = true;\n    DP [ arr [ i ] % m ] = true;\n  }\n  return DP [ 0 ];\n}\n", "FIND_SUM_EVEN_INDEX_BINOMIAL_COEFFICIENTS_1": "int evenbinomialCoeffSum ( int n ) {\n  return ( 1 << ( n - 1 ) );\n}\n", "EVEN_FIBONACCI_NUMBERS_SUM": "int evenFibSum ( int limit ) {\n  if ( limit < 2 ) return 0;\n  long long int ef1 = 0, ef2 = 2;\n  long long int sum = ef1 + ef2;\n  while ( ef2 <= limit ) {\n    long long int ef3 = 4 * ef2 + ef1;\n    if ( ef3 > limit ) break;\n    ef1 = ef2;\n    ef2 = ef3;\n    sum += ef2;\n  }\n  return sum;\n}\n", "MAKING_ELEMENTS_OF_TWO_ARRAYS_SAME_WITH_MINIMUM_INCREMENTDECREMENT": "int MinOperation ( int a [ ], int b [ ], int n ) {\n  sort ( a, a + n );\n  sort ( b, b + n );\n  int result = 0;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    result = result + abs ( a [ i ] - b [ i ] );\n  }\n  return result;\n}\n", "REQUIRED_MINIMUM_DIGITS_REMOVE_NUMBER_MAKE_PERFECT_SQUARE": "int perfectSquare ( string s ) {\n  int n = s . size ( );\n  int ans = - 1;\n  string num;\n  for ( int i = 1;\n  i < ( 1 << n );\n  i ++ ) {\n    string str = \"\";\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      if ( ( i >> j ) & 1 ) {\n        str += s [ j ];\n      }\n    }\n    if ( str [ 0 ] != '0' ) {\n      int temp = 0;\n      for ( int j = 0;\n      j < str . size ( );\n      j ++ ) temp = temp * 10 + ( int ) ( str [ j ] - '0' );\n      int k = sqrt ( temp );\n      if ( k * k == temp ) {\n        if ( ans < ( int ) str . size ( ) ) {\n          ans = ( int ) str . size ( );\n          num = str;\n        }\n      }\n    }\n  }\n  if ( ans == - 1 ) return ans;\n  else {\n    cout << num << \" \";\n    return n - ans;\n  }\n}\n", "COUNT_WORDS_APPEAR_EXACTLY_TWO_TIMES_ARRAY_WORDS": "int countWords ( string str [ ], int n ) {\n  unordered_map < string, int > m;\n  for ( int i = 0;\n  i < n;\n  i ++ ) m [ str [ i ] ] += 1;\n  int res = 0;\n  for ( auto it = m . begin ( );\n  it != m . end ( );\n  it ++ ) if ( ( it -> second == 2 ) ) res ++;\n  return res;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_4": "unsigned int countSetBitsRec ( unsigned int num ) {\n  int nibble = 0;\n  if ( 0 == num ) return num_to_bits [ 0 ];\n  nibble = num & 0xf;\n  return num_to_bits [ nibble ] + countSetBitsRec ( num >> 4 );\n}\n", "MAXIMUM_WEIGHT_PATH_ENDING_ELEMENT_LAST_ROW_MATRIX": "int maxCost ( int mat [ ] [ MAX ], int N ) {\n  int dp [ N ] [ N ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ 0 ] = mat [ 0 ] [ 0 ];\n  for ( int i = 1;\n  i < N;\n  i ++ ) dp [ i ] [ 0 ] = mat [ i ] [ 0 ] + dp [ i - 1 ] [ 0 ];\n  for ( int i = 1;\n  i < N;\n  i ++ ) for ( int j = 1;\n  j < i + 1 && j < N;\n  j ++ ) dp [ i ] [ j ] = mat [ i ] [ j ] + max ( dp [ i - 1 ] [ j - 1 ], dp [ i - 1 ] [ j ] );\n  int result = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) if ( result < dp [ N - 1 ] [ i ] ) result = dp [ N - 1 ] [ i ];\n  return result;\n}\n", "PERFECT_REVERSIBLE_STRING": "bool isReversible ( string str ) {\n  int i = 0, j = str . length ( ) - 1;\n  while ( i < j ) {\n    if ( str [ i ] != str [ j ] ) return false;\n    i ++;\n    j --;\n  }\n  return true;\n}\n", "FIND_SUM_ODD_FACTORS_NUMBER": "int sumofoddFactors ( int n ) {\n  int res = 1;\n  while ( n % 2 == 0 ) n = n / 2;\n  for ( int i = 3;\n  i <= sqrt ( n );\n  i ++ ) {\n    int count = 0, curr_sum = 1;\n    int curr_term = 1;\n    while ( n % i == 0 ) {\n      count ++;\n      n = n / i;\n      curr_term *= i;\n      curr_sum += curr_term;\n    }\n    res *= curr_sum;\n  }\n  if ( n >= 2 ) res *= ( 1 + n );\n  return res;\n}\n", "MAXIMUM_SUM_PATH_MATRIX_TOP_BOTTOM": "int maxSum ( int mat [ SIZE ] [ SIZE ], int n ) {\n  if ( n == 1 ) return mat [ 0 ] [ 0 ];\n  int dp [ n ] [ n ];\n  int maxSum = INT_MIN, max;\n  for ( int j = 0;\n  j < n;\n  j ++ ) dp [ n - 1 ] [ j ] = mat [ n - 1 ] [ j ];\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    for ( int j = 0;\n    j < n;\n    j ++ ) {\n      max = INT_MIN;\n      if ( ( ( j - 1 ) >= 0 ) && ( max < dp [ i + 1 ] [ j - 1 ] ) ) max = dp [ i + 1 ] [ j - 1 ];\n      if ( ( ( j + 1 ) < n ) && ( max < dp [ i + 1 ] [ j + 1 ] ) ) max = dp [ i + 1 ] [ j + 1 ];\n      dp [ i ] [ j ] = mat [ i ] [ j ] + max;\n    }\n  }\n  for ( int j = 0;\n  j < n;\n  j ++ ) if ( maxSum < dp [ 0 ] [ j ] ) maxSum = dp [ 0 ] [ j ];\n  return maxSum;\n}\n", "COUNT_DIGITS_FACTORIAL_SET_1": "int findDigits ( int n ) {\n  if ( n < 0 ) return 0;\n  if ( n <= 1 ) return 1;\n  double digits = 0;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) digits += log10 ( i );\n  return floor ( digits ) + 1;\n}\n", "FIND_UNCOMMON_CHARACTERS_TWO_STRINGS": "void findAndPrintUncommonChars ( string str1, string str2 ) {\n  int present [ MAX_CHAR ];\n  for ( int i = 0;\n  i < MAX_CHAR;\n  i ++ ) present [ i ] = 0;\n  int l1 = str1 . size ( );\n  int l2 = str2 . size ( );\n  for ( int i = 0;\n  i < l1;\n  i ++ ) present [ str1 [ i ] - 'a' ] = 1;\n  for ( int i = 0;\n  i < l2;\n  i ++ ) {\n    if ( present [ str2 [ i ] - 'a' ] == 1 || present [ str2 [ i ] - 'a' ] == - 1 ) present [ str2 [ i ] - 'a' ] = - 1;\n    else present [ str2 [ i ] - 'a' ] = 2;\n  }\n  for ( int i = 0;\n  i < MAX_CHAR;\n  i ++ ) if ( present [ i ] == 1 || present [ i ] == 2 ) cout << ( char ( i + 'a' ) ) << \" \";\n}\n", "SQUARE_ROOT_OF_AN_INTEGER_1": "int floorSqrt ( int x ) {\n  if ( x == 0 || x == 1 ) return x;\n  int start = 1, end = x, ans;\n  while ( start <= end ) {\n    int mid = ( start + end ) / 2;\n    if ( mid * mid == x ) return mid;\n    if ( mid * mid < x ) {\n      start = mid + 1;\n      ans = mid;\n    }\n    else end = mid - 1;\n  }\n  return ans;\n}\n", "CHECK_POSSIBLE_PATH_2D_MATRIX": "bool isPath ( int arr [ row ] [ col ] ) {\n  arr [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i < row;\n  i ++ ) if ( arr [ i ] [ 0 ] != - 1 ) arr [ i ] [ 0 ] = arr [ i - 1 ] [ 0 ];\n  for ( int j = 1;\n  j < col;\n  j ++ ) if ( arr [ 0 ] [ j ] != - 1 ) arr [ 0 ] [ j ] = arr [ 0 ] [ j - 1 ];\n  for ( int i = 1;\n  i < row;\n  i ++ ) for ( int j = 1;\n  j < col;\n  j ++ ) if ( arr [ i ] [ j ] != - 1 ) arr [ i ] [ j ] = max ( arr [ i ] [ j - 1 ], arr [ i - 1 ] [ j ] );\n  return ( arr [ row - 1 ] [ col - 1 ] == 1 );\n}\n", "NEWMAN_CONWAY_SEQUENCE_1": "int sequence ( int n ) {\n  int f [ n + 1 ];\n  int i;\n  f [ 0 ] = 0;\n  f [ 1 ] = 1;\n  f [ 2 ] = 1;\n  for ( i = 3;\n  i <= n;\n  i ++ ) f [ i ] = f [ f [ i - 1 ] ] + f [ i - f [ i - 1 ] ];\n  return f [ n ];\n}\n", "PRINT_WORDS_STRING_REVERSE_ORDER": "string wordReverse ( string str ) {\n  int i = str . length ( ) - 1;\n  int start, end = i + 1;\n  string result = \"\";\n  while ( i >= 0 ) {\n    if ( str [ i ] == ' ' ) {\n      start = i + 1;\n      while ( start != end ) result += str [ start ++ ];\n      result += ' ';\n      end = i;\n    }\n    i --;\n  }\n  start = 0;\n  while ( start != end ) result += str [ start ++ ];\n  return result;\n}\n", "FIND_NUMBER_ENDLESS_POINTS": "int countEndless ( bool input [ ] [ MAX ], int n ) {\n  bool row [ n ] [ n ], col [ n ] [ n ];\n  for ( int j = 0;\n  j < n;\n  j ++ ) {\n    bool isEndless = 1;\n    for ( int i = n - 1;\n    i >= 0;\n    i -- ) {\n      if ( input [ i ] [ j ] == 0 ) isEndless = 0;\n      col [ i ] [ j ] = isEndless;\n    }\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    bool isEndless = 1;\n    for ( int j = n - 1;\n    j >= 0;\n    j -- ) {\n      if ( input [ i ] [ j ] == 0 ) isEndless = 0;\n      row [ i ] [ j ] = isEndless;\n    }\n  }\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 1;\n  j < n;\n  j ++ ) if ( row [ i ] [ j ] && col [ i ] [ j ] ) ans ++;\n  return ans;\n}\n", "CHECK_POSSIBLE_TRANSFORM_ONE_STRING_ANOTHER": "bool check ( string s1, string s2 ) {\n  int n = s1 . length ( );\n  int m = s2 . length ( );\n  bool dp [ n + 1 ] [ m + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= m;\n    j ++ ) {\n      dp [ i ] [ j ] = false;\n    }\n  }\n  dp [ 0 ] [ 0 ] = true;\n  for ( int i = 0;\n  i < s1 . length ( );\n  i ++ ) {\n    for ( int j = 0;\n    j <= s2 . length ( );\n    j ++ ) {\n      if ( dp [ i ] [ j ] ) {\n        if ( j < s2 . length ( ) && ( toupper ( s1 [ i ] ) == s2 [ j ] ) ) dp [ i + 1 ] [ j + 1 ] = true;\n        if ( ! isupper ( s1 [ i ] ) ) dp [ i + 1 ] [ j ] = true;\n      }\n    }\n  }\n  return ( dp [ n ] [ m ] );\n}\n", "CALCULATE_VOLUME_DODECAHEDRON": "double vol_of_dodecahedron ( int side ) {\n  return ( ( ( 15 + ( 7 * ( sqrt ( 5 ) ) ) ) / 4 ) * ( pow ( side, 3 ) ) );\n}\n", "PROGRAM_FIND_REMAINDER_LARGE_NUMBER_DIVIDED_11": "int remainder ( string str ) {\n  int len = str . length ( );\n  int num, rem = 0;\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    num = rem * 10 + ( str [ i ] - '0' );\n    rem = num % 11;\n  }\n  return rem;\n}\n", "SORT_STRING_CHARACTERS": "void sortString ( string & str ) {\n  sort ( str . begin ( ), str . end ( ) );\n  cout << str;\n}\n", "BIRTHDAY_PARADOX": "int find ( double p ) {\n  return ceil ( sqrt ( 2 * 365 * log ( 1 / ( 1 - p ) ) ) );\n}\n", "CHECK_LINE_PASSES_ORIGIN": "bool checkOrigin ( int x1, int y1, int x2, int y2 ) {\n  return ( x1 * ( y2 - y1 ) == y1 * ( x2 - x1 ) );\n}\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS_2": "void findElements ( int arr [ ], int n ) {\n  int first = INT_MIN, second = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] > first ) {\n      second = first;\n      first = arr [ i ];\n    }\n    else if ( arr [ i ] > second ) second = arr [ i ];\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] < second ) cout << arr [ i ] << \" \";\n}\n", "MINIMUM_SUM_SUBSEQUENCE_LEAST_ONE_EVERY_FOUR_CONSECUTIVE_ELEMENTS_PICKED_1": "int minSum ( int ar [ ], int n ) {\n  if ( n <= 4 ) return * min_element ( ar, ar + n );\n  int sum [ n ];\n  sum [ 0 ] = ar [ 0 ];\n  sum [ 1 ] = ar [ 1 ];\n  sum [ 2 ] = ar [ 2 ];\n  sum [ 3 ] = ar [ 3 ];\n  for ( int i = 4;\n  i < n;\n  i ++ ) sum [ i ] = ar [ i ] + ( * min_element ( sum + i - 4, sum + i ) );\n  return * min_element ( sum + n - 4, sum + n );\n}\n", "CEILING_IN_A_SORTED_ARRAY": "int ceilSearch ( int arr [ ], int low, int high, int x ) {\n  int i;\n  if ( x <= arr [ low ] ) return low;\n  for ( i = low;\n  i < high;\n  i ++ ) {\n    if ( arr [ i ] == x ) return i;\n    if ( arr [ i ] < x && arr [ i + 1 ] >= x ) return i + 1;\n  }\n  return - 1;\n}\n", "SWAP_TWO_NUMBERS_WITHOUT_USING_TEMPORARY_VARIABLE_1": "void swap ( int * xp, int * yp ) {\n  if ( xp == yp ) return;\n  * xp = * xp + * yp;\n  * yp = * xp - * yp;\n  * xp = * xp - * yp;\n}\n", "MINIMUM_NUMBER_OF_MANIPULATIONS_REQUIRED_TO_MAKE_TWO_STRINGS_ANAGRAM_WITHOUT_DELETION_OF_CHARACTER": "int countManipulations ( string s1, string s2 ) {\n  int count = 0;\n  int char_count [ 26 ];\n  for ( int i = 0;\n  i < 26;\n  i ++ ) {\n    char_count [ i ] = 0;\n  }\n  for ( int i = 0;\n  i < s1 . length ( );\n  i ++ ) char_count [ s1 [ i ] - 'a' ] ++;\n  for ( int i = 0;\n  i < s2 . length ( );\n  i ++ ) {\n    char_count [ s2 [ i ] - 'a' ] --;\n    if ( char_count [ s2 [ i ] - 'a' ] < 0 ) count ++;\n  }\n  return count;\n}\n", "CHECK_IF_ALL_THE_ELEMENTS_CAN_BE_MADE_OF_SAME_PARITY_BY_INVERTING_ADJACENT_ELEMENTS": "bool flipsPossible ( int a [ ], int n ) {\n  int count_odd = 0, count_even = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] & 1 ) count_odd ++;\n    else count_even ++;\n  }\n  if ( count_odd % 2 && count_even % 2 ) return false;\n  else return true;\n}\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL": "int substringConversions ( string str, int k, int b ) {\n  for ( int i = 0;\n  i + k <= str . size ( );\n  i ++ ) {\n    string sub = str . substr ( i, k );\n    int sum = 0, counter = 0;\n    for ( int i = sub . size ( ) - 1;\n    i >= 0;\n    i -- ) {\n      sum = sum + ( ( sub . at ( i ) - '0' ) * pow ( b, counter ) );\n      counter ++;\n    }\n    cout << sum << \" \";\n  }\n}\n", "FIND_K_SUCH_THAT_ALL_ELEMENTS_IN_KTH_ROW_ARE_0_AND_KTH_COLUMN_ARE_1_IN_A_BOOLEAN_MATRIX": "int find ( bool arr [ n ] [ n ] ) {\n  int i = 0, j = n - 1;\n  int res = - 1;\n  while ( i < n && j >= 0 ) {\n    if ( arr [ i ] [ j ] == 0 ) {\n      while ( j >= 0 && ( arr [ i ] [ j ] == 0 || i == j ) ) j --;\n      if ( j == - 1 ) {\n        res = i;\n        break;\n      }\n      else i ++;\n    }\n    else {\n      while ( i < n && ( arr [ i ] [ j ] == 1 || i == j ) ) i ++;\n      if ( i == n ) {\n        res = j;\n        break;\n      }\n      else j --;\n    }\n  }\n  if ( res == - 1 ) return res;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( res != i && arr [ i ] [ res ] != 1 ) return - 1;\n  for ( int j = 0;\n  j < n;\n  j ++ ) if ( res != j && arr [ res ] [ j ] != 0 ) return - 1;\n  return res;\n}\n", "NUMBER_ORDERED_PAIRS_AI_AJ_0": "int countPairs ( int a [ ], int n ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) if ( ( a [ i ] & a [ j ] ) == 0 ) count += 2;\n  }\n  return count;\n}\n", "CIRCLE_LATTICE_POINTS": "int countLattice ( int r ) {\n  if ( r <= 0 ) return 0;\n  int result = 4;\n  for ( int x = 1;\n  x < r;\n  x ++ ) {\n    int ySquare = r * r - x * x;\n    int y = sqrt ( ySquare );\n    if ( y * y == ySquare ) result += 4;\n  }\n  return result;\n}\n", "MINIMUM_CHARACTERS_ADDED_FRONT_MAKE_STRING_PALINDROME": "bool ispalindrome ( string s ) {\n  int l = s . length ( );\n  int j;\n  for ( int i = 0, j = l - 1;\n  i <= j;\n  i ++, j -- ) {\n    if ( s [ i ] != s [ j ] ) return false;\n  }\n  return true;\n}\n", "K_TH_MISSING_ELEMENT_INCREASING_SEQUENCE_NOT_PRESENT_GIVEN_SEQUENCE": "int find ( int a [ ], int b [ ], int k, int n1, int n2 ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n2;\n  i ++ ) s . insert ( b [ i ] );\n  int missing = 0;\n  for ( int i = 0;\n  i < n1;\n  i ++ ) {\n    if ( s . find ( a [ i ] ) == s . end ( ) ) missing ++;\n    if ( missing == k ) return a [ i ];\n  }\n  return - 1;\n}\n", "PROGRAM_CHECK_ISBN": "bool isValidISBN ( string & isbn ) {\n  int n = isbn . length ( );\n  if ( n != 10 ) return false;\n  int sum = 0;\n  for ( int i = 0;\n  i < 9;\n  i ++ ) {\n    int digit = isbn [ i ] - '0';\n    if ( 0 > digit || 9 < digit ) return false;\n    sum += ( digit * ( 10 - i ) );\n  }\n  char last = isbn [ 9 ];\n  if ( last != 'X' && ( last < '0' || last > '9' ) ) return false;\n  sum += ( ( last == 'X' ) ? 10 : ( last - '0' ) );\n  return ( sum % 11 == 0 );\n}\n", "COUNT_WAYS_INCREASE_LCS_LENGTH_TWO_STRINGS_ONE": "int waysToIncreaseLCSBy1 ( string str1, string str2 ) {\n  int m = str1 . length ( ), n = str2 . length ( );\n  vector < int > position [ M ];\n  for ( int i = 1;\n  i <= n;\n  i ++ ) position [ toInt ( str2 [ i - 1 ] ) ] . push_back ( i );\n  int lcsl [ m + 2 ] [ n + 2 ];\n  int lcsr [ m + 2 ] [ n + 2 ];\n  for ( int i = 0;\n  i <= m + 1;\n  i ++ ) for ( int j = 0;\n  j <= n + 1;\n  j ++ ) lcsl [ i ] [ j ] = lcsr [ i ] [ j ] = 0;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      if ( str1 [ i - 1 ] == str2 [ j - 1 ] ) lcsl [ i ] [ j ] = 1 + lcsl [ i - 1 ] [ j - 1 ];\n      else lcsl [ i ] [ j ] = max ( lcsl [ i - 1 ] [ j ], lcsl [ i ] [ j - 1 ] );\n    }\n  }\n  for ( int i = m;\n  i >= 1;\n  i -- ) {\n    for ( int j = n;\n    j >= 1;\n    j -- ) {\n      if ( str1 [ i - 1 ] == str2 [ j - 1 ] ) lcsr [ i ] [ j ] = 1 + lcsr [ i + 1 ] [ j + 1 ];\n      else lcsr [ i ] [ j ] = max ( lcsr [ i + 1 ] [ j ], lcsr [ i ] [ j + 1 ] );\n    }\n  }\n  int ways = 0;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( char c = 'a';\n    c <= 'z';\n    c ++ ) {\n      for ( int j = 0;\n      j < position [ toInt ( c ) ] . size ( );\n      j ++ ) {\n        int p = position [ toInt ( c ) ] [ j ];\n        if ( lcsl [ i ] [ p - 1 ] + lcsr [ i + 1 ] [ p + 1 ] == lcsl [ m ] [ n ] ) ways ++;\n      }\n    }\n  }\n  return ways;\n}\n", "DYNAMIC_PROGRAMMING_SET_11_EGG_DROPPING_PUZZLE_1": "int eggDrop ( int n, int k ) {\n  int eggFloor [ n + 1 ] [ k + 1 ];\n  int res;\n  int i, j, x;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    eggFloor [ i ] [ 1 ] = 1;\n    eggFloor [ i ] [ 0 ] = 0;\n  }\n  for ( j = 1;\n  j <= k;\n  j ++ ) eggFloor [ 1 ] [ j ] = j;\n  for ( i = 2;\n  i <= n;\n  i ++ ) {\n    for ( j = 2;\n    j <= k;\n    j ++ ) {\n      eggFloor [ i ] [ j ] = INT_MAX;\n      for ( x = 1;\n      x <= j;\n      x ++ ) {\n        res = 1 + max ( eggFloor [ i - 1 ] [ x - 1 ], eggFloor [ i ] [ j - x ] );\n        if ( res < eggFloor [ i ] [ j ] ) eggFloor [ i ] [ j ] = res;\n      }\n    }\n  }\n  return eggFloor [ n ] [ k ];\n}\n", "WAYS_TO_WRITE_N_AS_SUM_OF_TWO_OR_MORE_POSITIVE_INTEGERS": "int countWays ( int n ) {\n  int table [ n + 1 ];\n  memset ( table, 0, sizeof ( table ) );\n  table [ 0 ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) for ( int j = i;\n  j <= n;\n  j ++ ) table [ j ] += table [ j - i ];\n  return table [ n ];\n}\n", "PROGRAM_SUM_COSX_SERIES": "double cosXSertiesSum ( double x, int n ) {\n  x = x * ( PI / 180.0 );\n  double res = 1;\n  double sign = 1, fact = 1, pow = 1;\n  for ( int i = 1;\n  i < 5;\n  i ++ ) {\n    sign = sign * - 1;\n    fact = fact * ( 2 * i - 1 ) * ( 2 * i );\n    pow = pow * x * x;\n    res = res + sign * pow / fact;\n  }\n  return res;\n}\n", "UNIQUE_CELLS_BINARY_MATRIX": "int countUnique ( int mat [ ] [ MAX ], int n, int m ) {\n  int rowsum [ n ], colsum [ m ];\n  memset ( colsum, 0, sizeof ( colsum ) );\n  memset ( rowsum, 0, sizeof ( rowsum ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) if ( mat [ i ] [ j ] ) {\n    rowsum [ i ] ++;\n    colsum [ j ] ++;\n  }\n  int uniquecount = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < m;\n  j ++ ) if ( mat [ i ] [ j ] && rowsum [ i ] == 1 && colsum [ j ] == 1 ) uniquecount ++;\n  return uniquecount;\n}\n", "GREEDY_ALGORITHM_TO_FIND_MINIMUM_NUMBER_OF_COINS": "void findMin ( int V ) {\n  vector < int > ans;\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    while ( V >= deno [ i ] ) {\n      V -= deno [ i ];\n      ans . push_back ( deno [ i ] );\n    }\n  }\n  for ( int i = 0;\n  i < ans . size ( );\n  i ++ ) cout << ans [ i ] << \"  \";\n}\n", "CHECK_INTEGER_OVERFLOW_MULTIPLICATION": "bool isOverflow ( long long a, long long b ) {\n  if ( a == 0 || b == 0 ) return false;\n  long long result = a * b;\n  if ( a == result / b ) return false;\n  else return true;\n}\n", "DIFFERENCE_BETWEEN_HIGHEST_AND_LEAST_FREQUENCIES_IN_AN_ARRAY_1": "int findDiff ( int arr [ ], int n ) {\n  unordered_map < int, int > hm;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hm [ arr [ i ] ] ++;\n  int max_count = 0, min_count = n;\n  for ( auto x : hm ) {\n    max_count = max ( max_count, x . second );\n    min_count = min ( min_count, x . second );\n  }\n  return ( max_count - min_count );\n}\n", "COMPOSITE_NUMBER": "bool isComposite ( int n ) {\n  if ( n <= 1 ) return false;\n  if ( n <= 3 ) return false;\n  if ( n % 2 == 0 || n % 3 == 0 ) return true;\n  for ( int i = 5;\n  i * i <= n;\n  i = i + 6 ) if ( n % i == 0 || n % ( i + 2 ) == 0 ) return true;\n  return false;\n}\n", "LARGEST_INCREASING_SUBSEQUENCE_OF_CONSECUTIVE_INTEGERS": "int findLIS ( int A [ ], int n ) {\n  unordered_map < int, int > hash;\n  int LIS_size = 1;\n  int LIS_index = 0;\n  hash [ A [ 0 ] ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\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    }\n  }\n  cout << \"LIS_size = \" << LIS_size << \"\\n\";\n  cout << \"LIS : \";\n  int start = LIS_index - LIS_size + 1;\n  while ( start <= LIS_index ) {\n    cout << start << \" \";\n    start ++;\n  }\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_2": "public : unsigned int countSetBits ( int n ) {\n  unsigned int count = 0;\n  while ( n ) {\n    n &= ( n - 1 );\n    count ++;\n  }\n  return count;\n}\n", "FIND_FOUR_ELEMENTS_A_B_C_AND_D_IN_AN_ARRAY_SUCH_THAT_AB_CD": "bool findPairs ( int arr [ ], int n ) {\n  map < int, pair < int, int > > Hash;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    for ( int j = i + 1;\n    j < n;\n    ++ j ) {\n      int sum = arr [ i ] + arr [ j ];\n      if ( Hash . find ( sum ) == Hash . end ( ) ) Hash [ sum ] = make_pair ( i, j );\n      else {\n        pair < int, int > pp = Hash [ sum ];\n        cout << \"(\" << arr [ pp . first ] << \", \" << arr [ pp . second ] << \") and (\" << arr [ i ] << \", \" << arr [ j ] << \")n\";\n        return true;\n      }\n    }\n  }\n  cout << \"No pairs found\";\n  return false;\n}\n", "COUNT_OBTUSE_ANGLES_CIRCLE_K_EQUIDISTANT_POINTS_2_GIVEN_POINTS": "int countObtuseAngles ( int a, int b, int k ) {\n  int c1 = ( b - a ) - 1;\n  int c2 = ( k - b ) + ( a - 1 );\n  if ( c1 == c2 ) return 0;\n  return min ( c1, c2 );\n}\n", "NUMBER_TRIANGLES_N_MOVES_1": "int numberOfTriangles ( int n ) {\n  int ans = 2 * ( pow ( 3, n ) ) - 1;\n  return ans;\n}\n", "FIND_A_REPEATING_AND_A_MISSING_NUMBER": "void printTwoElements ( int arr [ ], int size ) {\n  int i;\n  cout << \" The repeating element is \";\n  for ( i = 0;\n  i < size;\n  i ++ ) {\n    if ( arr [ abs ( arr [ i ] ) - 1 ] > 0 ) arr [ abs ( arr [ i ] ) - 1 ] = - arr [ abs ( arr [ i ] ) - 1 ];\n    else cout << abs ( arr [ i ] ) << \"\\n\";\n  }\n  cout << \"and the missing element is \";\n  for ( i = 0;\n  i < size;\n  i ++ ) {\n    if ( arr [ i ] > 0 ) cout << ( i + 1 );\n  }\n}\n", "MINIMUM_DIFFERENCE_BETWEEN_GROUPS_OF_SIZE_TWO": "ll calculate ( ll a [ ], ll n ) {\n  sort ( a, a + n );\n  vector < ll > s;\n  for ( int i = 0, j = n - 1;\n  i < j;\n  i ++, j -- ) s . push_back ( a [ i ] + a [ j ] );\n  ll mini = * min_element ( s . begin ( ), s . end ( ) );\n  ll maxi = * max_element ( s . begin ( ), s . end ( ) );\n  return abs ( maxi - mini );\n}\n", "FIND_PERIMETER_CYLINDER": "int perimeter ( int diameter, int height ) {\n  return 2 * ( diameter + height );\n}\n", "MAGICAL_INDICES_ARRAY": "make_pair push_back int solve ( int A [ ], int n ) {\n  int i, cnt = 0, j;\n  int parent [ n + 1 ];\n  int vis [ n + 1 ];\n  memset ( parent, - 1, sizeof ( parent ) );\n  memset ( vis, 0, sizeof ( vis ) );\n  for ( i = 0;\n  i < n;\n  i ++ ) {\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      }\n      if ( parent [ j ] == i ) {\n        while ( ! vis [ j ] ) {\n          vis [ j ] = 1;\n          cnt ++;\n          j = ( j + A [ j ] + 1 ) % n;\n        }\n      }\n    }\n  }\n  return cnt;\n}\n", "FIND_A_FIXED_POINT_IN_A_GIVEN_ARRAY_1": "int binarySearch ( int arr [ ], int low, int high ) {\n  if ( high >= low ) {\n    int mid = ( low + high ) / 2;\n    if ( mid == arr [ mid ] ) return mid;\n    if ( mid > arr [ mid ] ) return binarySearch ( arr, ( mid + 1 ), high );\n    else return binarySearch ( arr, low, ( mid - 1 ) );\n  }\n  return - 1;\n}\n", "FIND_SIZE_OF_THE_LARGEST_FORMED_BY_ALL_ONES_IN_A_BINARY_MATRIX": "int findLargestPlus ( int mat [ N ] [ N ] ) {\n  int left [ N ] [ N ], right [ N ] [ N ], top [ N ] [ N ], bottom [ N ] [ N ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\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  }\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    for ( int j = 1;\n    j < N;\n    j ++ ) {\n      if ( mat [ i ] [ j ] == 1 ) left [ i ] [ j ] = left [ i ] [ j - 1 ] + 1;\n      else left [ i ] [ j ] = 0;\n      if ( mat [ j ] [ i ] == 1 ) top [ j ] [ i ] = top [ j - 1 ] [ i ] + 1;\n      else top [ j ] [ i ] = 0;\n      j = N - 1 - j;\n      if ( mat [ j ] [ i ] == 1 ) bottom [ j ] [ i ] = bottom [ j + 1 ] [ i ] + 1;\n      else bottom [ j ] [ i ] = 0;\n      if ( mat [ i ] [ j ] == 1 ) right [ i ] [ j ] = right [ i ] [ j + 1 ] + 1;\n      else right [ i ] [ j ] = 0;\n      j = N - 1 - j;\n    }\n  }\n  int n = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    for ( int j = 0;\n    j < N;\n    j ++ ) {\n      int len = min ( min ( top [ i ] [ j ], bottom [ i ] [ j ] ), min ( left [ i ] [ j ], right [ i ] [ j ] ) );\n      if ( len > n ) n = len;\n    }\n  }\n  if ( n ) return 4 * ( n - 1 ) + 1;\n  return 0;\n}\n", "LEVEL_NODE_TREE_SOURCE_NODE_USING_BFS": "void printLevels ( vector < int > graph [ ], int V, int x ) {\n  int level [ V ];\n  bool marked [ V ];\n  queue < int > que;\n  que . push ( x );\n  level [ x ] = 0;\n  marked [ x ] = true;\n  while ( ! que . empty ( ) ) {\n    x = que . front ( );\n    que . pop ( );\n    for ( int i = 0;\n    i < graph [ x ] . size ( );\n    i ++ ) {\n      int b = graph [ x ] [ i ];\n      if ( ! marked [ b ] ) {\n        que . push ( b );\n        level [ b ] = level [ x ] + 1;\n        marked [ b ] = true;\n      }\n    }\n  }\n  cout << \"Nodes\" << \"    \" << \"Level\" << endl;\n  for ( int i = 0;\n  i < V;\n  i ++ ) cout << \" \" << i << \"   -->   \" << level [ i ] << endl;\n}\n", "FIND_SQUARE_ROOT_UNDER_MODULO_P_SET_1_WHEN_P_IS_IN_FORM_OF_4I_3": "void squareRoot ( int n, int p ) {\n  n = n % p;\n  for ( int x = 2;\n  x < p;\n  x ++ ) {\n    if ( ( x * x ) % p == n ) {\n      cout << \"Square root is \" << x;\n      return;\n    }\n  }\n  cout << \"Square root doesn't exist\";\n}\n", "CHECK_IF_ARRAY_ELEMENTS_ARE_CONSECUTIVE": "bool areConsecutive ( int arr [ ], int n ) {\n  if ( n < 1 ) return false;\n  int min = getMin ( arr, n );\n  int max = getMax ( arr, n );\n  if ( max - min + 1 == n ) {\n    bool * visited = ( bool * ) calloc ( n, sizeof ( bool ) );\n    int i;\n    for ( i = 0;\n    i < n;\n    i ++ ) {\n      if ( visited [ arr [ i ] - min ] != false ) return false;\n      visited [ arr [ i ] - min ] = true;\n    }\n    return true;\n  }\n  return false;\n}\n", "SMALLEST_SUBSET_SUM_GREATER_ELEMENTS": "int minElements ( int arr [ ], int n ) {\n  int halfSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) halfSum = halfSum + arr [ i ];\n  halfSum = halfSum / 2;\n  sort ( arr, arr + n, greater < int > ( ) );\n  int res = 0, curr_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    curr_sum += arr [ i ];\n    res ++;\n    if ( curr_sum > halfSum ) return res;\n  }\n  return res;\n}\n", "SUM_OF_ALL_ELEMENTS_UP_TO_NTH_ROW_IN_A_PASCALS_TRIANGLE_1": "long long int calculateSum ( int n ) {\n  long long int sum = 0;\n  sum = 1 << n;\n  return ( sum - 1 );\n}\n", "SWAP_TWO_NIBBLES_BYTE": "int swapNibbles ( int x ) {\n  return ( ( x & 0x0F ) << 4 | ( x & 0xF0 ) >> 4 );\n}\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME_1": "bool canFormPalindrome ( string str ) {\n  vector < char > list;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    auto pos = find ( list . begin ( ), list . end ( ), str [ i ] );\n    if ( pos != list . end ( ) ) {\n      auto posi = find ( list . begin ( ), list . end ( ), str [ i ] );\n      list . erase ( posi );\n    }\n    else list . push_back ( str [ i ] );\n  }\n  if ( str . length ( ) % 2 == 0 && list . empty ( ) || ( str . length ( ) % 2 == 1 && list . size ( ) == 1 ) ) return true;\n  else return false;\n}\n", "WAYS_SPLIT_STRING_PARTITION_STARTS_DISTINCT_CHARACTER": "int countWays ( string s ) {\n  int count [ 26 ] = {\n    0 };\n    for ( char x : s ) count [ x - 'a' ] ++;\n    count [ s [ 0 ] - 'a' ] = 1;\n    int ans = 1;\n    for ( int i = 0;\n    i < 26;\n    ++ i ) if ( count [ i ] != 0 ) ans *= count [ i ];\n    return ans;\n  }\n  ", "ENTRINGER_NUMBER_1": "int zigzag ( int n, int k ) {\n  int dp [ n + 1 ] [ k + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) dp [ i ] [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= i;\n    j ++ ) dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ i - j ];\n    return dp [ n ] [ k ];\n  }\n  int main ( ) {\n    int n = 4, k = 3;\n    cout << zigzag ( n, k ) << endl;\n    return 0;\n  }\n  ", "COUNT_PAIRS_DIFFERENCE_EQUAL_K": "int countPairsWithDiffK ( int arr [ ], int n, int k ) {\n  int count = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) if ( arr [ i ] - arr [ j ] == k || arr [ j ] - arr [ i ] == k ) count ++;\n  }\n  return count;\n}\n", "EXPECTATION_EXPECTED_VALUE_ARRAY": "float calc_Expectation ( float a [ ], float n ) {\n  float prb = ( 1 / n );\n  float sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += a [ i ] * prb;\n  return sum;\n}\n", "GROUP_OCCURRENCES_CHARACTERS_ACCORDING_FIRST_APPEARANCE": "void printGrouped ( string str ) {\n  int n = str . length ( );\n  int count [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) count [ str [ i ] - 'a' ] ++;\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      while ( count [ str [ i ] - 'a' ] -- ) cout << str [ i ];\n      count [ str [ i ] - 'a' ] = 0;\n    }\n  }\n  ", "MAXIMUM_PATH_SUM_POSITION_JUMPS_DIVISIBILITY_CONDITION": "void printMaxSum ( int arr [ ], int n ) {\n  int dp [ n ];\n  memset ( dp, 0, sizeof dp );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    dp [ i ] = arr [ i ];\n    int maxi = 0;\n    for ( int j = 1;\n    j <= sqrt ( i + 1 );\n    j ++ ) {\n      if ( ( ( i + 1 ) % j == 0 ) && ( i + 1 ) != j ) {\n        if ( dp [ j - 1 ] > maxi ) maxi = dp [ j - 1 ];\n        if ( dp [ ( i + 1 ) / j - 1 ] > maxi && j != 1 ) maxi = dp [ ( i + 1 ) / j - 1 ];\n      }\n    }\n    dp [ i ] += maxi;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << dp [ i ] << \" \";\n}\n", "PROGRAM_CIRCUMFERENCE_PARALLELOGRAM": "float circumferenceparallelogram ( float a, float b ) {\n  return ( ( 2 * a ) + ( 2 * b ) );\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_2": "int numberOfPaths ( int m, int n ) {\n  int dp [ n ] = {\n    1 };\n    dp [ 0 ] = 1;\n    for ( int i = 0;\n    i < m;\n    i ++ ) {\n      for ( int j = 1;\n      j < n;\n      j ++ ) {\n        dp [ j ] += dp [ j - 1 ];\n      }\n    }\n    return dp [ n - 1 ];\n  }\n  ", "REMOVE_MINIMUM_NUMBER_CHARACTERS_TWO_STRINGS_BECOME_ANAGRAM": "int remAnagram ( string str1, string str2 ) {\n  int count1 [ CHARS ] = {\n    0 },\n    count2 [ CHARS ] = {\n      0 };\n      for ( int i = 0;\n      str1 [ i ] != '\\0';\n      i ++ ) count1 [ str1 [ i ] - 'a' ] ++;\n      for ( int i = 0;\n      str2 [ i ] != '\\0';\n      i ++ ) count2 [ str2 [ i ] - 'a' ] ++;\n      int result = 0;\n      for ( int i = 0;\n      i < 26;\n      i ++ ) result += abs ( count1 [ i ] - count2 [ i ] );\n      return result;\n    }\n    ", "SUM_DIVISORS_1_N_1": "int divisorSum ( int n ) {\n  int sum = 0;\n  for ( int i = 1;\n  i <= n;\n  ++ i ) sum += ( n / i ) * i;\n  return sum;\n}\n", "FIND_LENGTH_LONGEST_SUBSEQUENCE_ONE_STRING_SUBSTRING_ANOTHER_STRING": "int maxSubsequenceSubstring ( char x [ ], char y [ ], int n, int m ) {\n  int dp [ MAX ] [ MAX ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) for ( int j = 0;\n  j <= n;\n  j ++ ) dp [ i ] [ j ] = 0;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      if ( x [ j - 1 ] == y [ i - 1 ] ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = dp [ i ] [ j - 1 ];\n    }\n  }\n  int ans = 0;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) ans = max ( ans, dp [ i ] [ n ] );\n  return ans;\n}\n", "SUM_FAI_AJ_PAIRS_ARRAY_N_INTEGERS": "int sum ( int a [ ], int n ) {\n  unordered_map < int, int > cnt;\n  int ans = 0, pre_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    ans += ( i * a [ i ] ) - pre_sum;\n    pre_sum += a [ i ];\n    if ( cnt [ a [ i ] - 1 ] ) ans -= cnt [ a [ i ] - 1 ];\n    if ( cnt [ a [ i ] + 1 ] ) ans += cnt [ a [ i ] + 1 ];\n    cnt [ a [ i ] ] ++;\n  }\n  return ans;\n}\n", "BINARY_REPRESENTATION_OF_A_GIVEN_NUMBER": "void bin ( unsigned n ) {\n  if ( n > 1 ) bin ( n / 2 );\n  cout << n % 2;\n}\n", "KNAPSACK_PROBLEM": "int knapSack ( int W, int wt [ ], int val [ ], int n ) {\n  if ( n == 0 || W == 0 ) return 0;\n  if ( wt [ n - 1 ] > W ) return knapSack ( W, wt, val, n - 1 );\n  else return max ( val [ n - 1 ] + knapSack ( W - wt [ n - 1 ], wt, val, n - 1 ), knapSack ( W, wt, val, n - 1 ) );\n}\n", "DOUBLE_FACTORIAL_1": "unsigned int doublefactorial ( unsigned int n ) {\n  int res = 1;\n  for ( int i = n;\n  i >= 0;\n  i = i - 2 ) {\n    if ( i == 0 || i == 1 ) return res;\n    else res *= i;\n  }\n}\n", "COUNT_DIGITS_FACTORIAL_SET_2": "long long findDigits ( int n ) {\n  if ( n < 0 ) return 0;\n  if ( n <= 1 ) return 1;\n  double x = ( ( n * log10 ( n / M_E ) + log10 ( 2 * M_PI * n ) / 2.0 ) );\n  return floor ( x ) + 1;\n}\n", "DELANNOY_NUMBER_1": "int dealnnoy ( int n, int m ) {\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) dp [ i ] [ 0 ] = 1;\n  for ( int i = 0;\n  i <= m;\n  i ++ ) dp [ 0 ] [ i ] = 1;\n  for ( int i = 1;\n  i <= m;\n  i ++ ) for ( int j = 1;\n  j <= n;\n  j ++ ) dp [ i ] [ j ] = dp [ i - 1 ] [ j ] + dp [ i - 1 ] [ j - 1 ] + dp [ i ] [ j - 1 ];\n  return dp [ m ] [ n ];\n}\n", "FIND_THE_MISSING_NUMBER_2": "int getMissingNo ( int a [ ], int n ) {\n  int x1 = a [ 0 ];\n  int x2 = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) x1 = x1 ^ a [ i ];\n  for ( int i = 2;\n  i <= n + 1;\n  i ++ ) x2 = x2 ^ i;\n  return ( x1 ^ x2 );\n}\n", "FIND_NUMBER_OF_TRIANGLES_POSSIBLE": "int findNumberOfTriangles ( int arr [ ], int n ) {\n  qsort ( arr, n, sizeof ( arr [ 0 ] ), comp );\n  int count = 0;\n  for ( int i = 0;\n  i < n - 2;\n  ++ i ) {\n    int k = i + 2;\n    for ( int j = i + 1;\n    j < n;\n    ++ j ) {\n      while ( k < n && arr [ i ] + arr [ j ] > arr [ k ] ) ++ k;\n      if ( k > j ) count += k - j - 1;\n    }\n  }\n  return count;\n}\n", "NUMBER_TRIANGLES_N_MOVES": "int numberOfTriangles ( int n ) {\n  int answer [ n + 1 ] = {\n    0 };\n    answer [ 0 ] = 1;\n    for ( int i = 1;\n    i <= n;\n    i ++ ) answer [ i ] = answer [ i - 1 ] * 3 + 2;\n    return answer [ n ];\n  }\n  ", "CHECK_SUMS_TH_ROW_TH_COLUMN_MATRIX": "bool areSumSame ( int a [ ] [ MAX ], int n, int m ) {\n  int sum1 = 0, sum2 = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum1 = 0, sum2 = 0;\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      sum1 += a [ i ] [ j ];\n      sum2 += a [ j ] [ i ];\n    }\n    if ( sum1 == sum2 ) return true;\n  }\n  return false;\n}\n", "WRITE_ONE_LINE_C_FUNCTION_TO_FIND_WHETHER_A_NO_IS_POWER_OF_TWO": "bool isPowerOfTwo ( int n ) {\n  if ( n == 0 ) return 0;\n  while ( n != 1 ) {\n    if ( n % 2 != 0 ) return 0;\n    n = n / 2;\n  }\n  return 1;\n}\n", "PUT_SPACES_WORDS_STARTING_CAPITAL_LETTERS": "void amendSentence ( string str ) {\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) {\n      str [ i ] = str [ i ] + 32;\n      if ( i != 0 ) cout << \" \";\n      cout << str [ i ];\n    }\n    else cout << str [ i ];\n  }\n}\n", "CHECK_DIVISIBILITY_BINARY_STRING_2K": "bool isDivisible ( char str [ ], int k ) {\n  int n = strlen ( str );\n  int c = 0;\n  for ( int i = 0;\n  i < k;\n  i ++ ) if ( str [ n - i - 1 ] == '0' ) c ++;\n  return ( c == k );\n}\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M": "int coutSubSeq ( int A [ ], int N, int M ) {\n  int sum = 0;\n  int ans = 0;\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < N;\n    j ++ ) {\n      for ( int k = j + 1;\n      k < N;\n      k ++ ) {\n        sum = A [ i ] + A [ j ] + A [ k ];\n        if ( sum % M == 0 ) ans ++;\n      }\n    }\n  }\n  return ans;\n}\n", "LONGEST_CONSECUTIVE_SUBSEQUENCE": "int findLongestConseqSubseq ( int arr [ ], int n ) {\n  unordered_set < int > S;\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) S . insert ( arr [ i ] );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( S . find ( arr [ i ] - 1 ) == S . end ( ) ) {\n      int j = arr [ i ];\n      while ( S . find ( j ) != S . end ( ) ) j ++;\n      ans = max ( ans, j - arr [ i ] );\n    }\n  }\n  return ans;\n}\n", "FIND_INDEX_GIVEN_FIBONACCI_NUMBER_CONSTANT_TIME_1": "int findIndex ( int n ) {\n  float fibo = 2.078087 * log ( n ) + 1.672276;\n  return round ( fibo );\n}\n", "LARGEST_DIVISIBLE_PAIRS_SUBSET": "int largestSubset ( int a [ ], int n ) {\n  sort ( a, a + n );\n  int dp [ n ];\n  dp [ n - 1 ] = 1;\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    int mxm = 0;\n    for ( int j = i + 1;\n    j < n;\n    j ++ ) if ( a [ j ] % a [ i ] == 0 ) mxm = max ( mxm, dp [ j ] );\n    dp [ i ] = 1 + mxm;\n  }\n  return * max_element ( dp, dp + n );\n}\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT_2": "bool isPowerOfFour ( unsigned int n ) {\n  return n != 0 && ( ( n & ( n - 1 ) ) == 0 ) && ! ( n & 0xAAAAAAAA );\n}\n", "COMPUTE_NCR_P_SET_1_INTRODUCTION_AND_DYNAMIC_PROGRAMMING_SOLUTION": "int nCrModp ( int n, int r, int p ) {\n  int C [ r + 1 ];\n  memset ( C, 0, sizeof ( C ) );\n  C [ 0 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = min ( i, r );\n    j > 0;\n    j -- ) C [ j ] = ( C [ j ] + C [ j - 1 ] ) % p;\n  }\n  return C [ r ];\n}\n", "ROUND_THE_GIVEN_NUMBER_TO_NEAREST_MULTIPLE_OF_10": "int round ( int n ) {\n  int a = ( n / 10 ) * 10;\n  int b = a + 10;\n  return ( n - a > b - n ) ? b : a;\n}\n", "SORT_EVEN_NUMBERS_ASCENDING_ORDER_SORT_ODD_NUMBERS_DESCENDING_ORDER_1": "void twoWaySort ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] & 1 ) arr [ i ] *= - 1;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr [ i ] & 1 ) arr [ i ] *= - 1;\n}\n", "POINT_CLIPPING_ALGORITHM_COMPUTER_GRAPHICS": "void pointClip ( int XY [ ] [ 2 ], int n, int Xmin, int Ymin, int Xmax, int Ymax ) {\n  cout << \"Point inside the viewing pane:\" << endl;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ( XY [ i ] [ 0 ] >= Xmin ) && ( XY [ i ] [ 0 ] <= Xmax ) ) {\n      if ( ( XY [ i ] [ 1 ] >= Ymin ) && ( XY [ i ] [ 1 ] <= Ymax ) ) cout << \"[\" << XY [ i ] [ 0 ] << \",\" << XY [ i ] [ 1 ] << \"] \";\n    }\n  }\n  cout << \"\\n\" << endl;\n  cout << \"Point outside the viewing pane:\" << endl;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ( XY [ i ] [ 0 ] < Xmin ) || ( XY [ i ] [ 0 ] > Xmax ) ) cout << \"[\" << XY [ i ] [ 0 ] << \",\" << XY [ i ] [ 1 ] << \"] \";\n    if ( ( XY [ i ] [ 1 ] < Ymin ) || ( XY [ i ] [ 1 ] > Ymax ) ) cout << \"[\" << XY [ i ] [ 0 ] << \",\" << XY [ i ] [ 1 ] << \"] \";\n  }\n}\n", "WAYS_TRANSFORMING_ONE_STRING_REMOVING_0_CHARACTERS": "int countTransformation ( string a, string b ) {\n  int n = a . size ( ), m = b . size ( );\n  if ( m == 0 ) return 1;\n  int dp [ m + 1 ] [ n + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 0;\n  i < m;\n  i ++ ) {\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      if ( i == 0 ) {\n        if ( j == 0 ) dp [ i ] [ j ] = ( a [ j ] == b [ i ] ) ? 1 : 0;\n        else if ( a [ j ] == b [ i ] ) dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + 1;\n        else dp [ i ] [ j ] = dp [ i ] [ j - 1 ];\n      }\n      else {\n        if ( a [ j ] == b [ i ] ) dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ j - 1 ];\n        else dp [ i ] [ j ] = dp [ i ] [ j - 1 ];\n      }\n    }\n  }\n  return dp [ m - 1 ] [ n - 1 ];\n}\n", "FIND_RELATIVE_COMPLEMENT_TWO_SORTED_ARRAYS": "void relativeComplement ( int arr1 [ ], int arr2 [ ], int n, int m ) {\n  int i = 0, j = 0;\n  while ( i < n && j < m ) {\n    if ( arr1 [ i ] < arr2 [ j ] ) {\n      cout << arr1 [ i ] << \" \";\n      i ++;\n    }\n    else if ( arr1 [ i ] > arr2 [ j ] ) {\n      j ++;\n    }\n    else if ( arr1 [ i ] == arr2 [ j ] ) {\n      i ++;\n      j ++;\n    }\n  }\n  while ( i < n ) cout << arr1 [ i ] << \" \";\n}\n", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY": "int countPairs ( int arr [ ], int n ) {\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( arr [ i ] == arr [ j ] ) ans ++;\n  return ans;\n}\n", "GIVEN_AN_ARRAY_OF_PAIRS_FIND_ALL_SYMMETRIC_PAIRS_IN_IT": "void findSymPairs ( int arr [ ] [ 2 ], int row ) {\n  unordered_map < int, int > hM;\n  for ( int i = 0;\n  i < row;\n  i ++ ) {\n    int first = arr [ i ] [ 0 ];\n    int sec = arr [ i ] [ 1 ];\n    if ( hM . find ( sec ) != hM . end ( ) && hM [ sec ] == first ) cout << \"(\" << sec << \", \" << first << \")\" << endl;\n    else hM [ first ] = sec;\n  }\n}\n", "COUNT_SUBSEQUENCES_PRODUCT_LESS_K": "int productSubSeqCount ( vector < int > & arr, int k ) {\n  int n = arr . size ( );\n  int dp [ k + 1 ] [ n + 1 ];\n  memset ( dp, 0, sizeof ( dp ) );\n  for ( int i = 1;\n  i <= k;\n  i ++ ) {\n    for ( int j = 1;\n    j <= n;\n    j ++ ) {\n      dp [ i ] [ j ] = dp [ i ] [ j - 1 ];\n      if ( arr [ j - 1 ] <= i && arr [ j - 1 ] > 0 ) dp [ i ] [ j ] += dp [ i / arr [ j - 1 ] ] [ j - 1 ] + 1;\n    }\n  }\n  return dp [ k ] [ n ];\n}\n", "REARRANGE_ARRAY_ARRI_ARRJ_EVEN_ARRI": "void rearrangeArr ( int arr [ ], int n ) {\n  int evenPos = n / 2;\n  int oddPos = n - evenPos;\n  int tempArr [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) tempArr [ i ] = arr [ i ];\n  sort ( tempArr, tempArr + n );\n  int j = oddPos - 1;\n  for ( int i = 0;\n  i < n;\n  i += 2 ) {\n    arr [ i ] = tempArr [ j ];\n    j --;\n  }\n  j = oddPos;\n  for ( int i = 1;\n  i < n;\n  i += 2 ) {\n    arr [ i ] = tempArr [ j ];\n    j ++;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "MINIMUM_ROTATIONS_UNLOCK_CIRCULAR_LOCK": "int minRotation ( int input, int unlock_code ) {\n  int rotation = 0;\n  int input_digit, code_digit;\n  while ( input || unlock_code ) {\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 /= 10;\n    unlock_code /= 10;\n  }\n  return rotation;\n}\n", "REARRANGE_BINARY_STRING_ALTERNATE_X_Y_OCCURRENCES": "void arrangeString ( string str, int x, int y ) {\n  int count_0 = 0;\n  int count_1 = 0;\n  int len = str . length ( );\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    if ( str [ i ] == '0' ) count_0 ++;\n    else count_1 ++;\n  }\n  while ( count_0 > 0 || count_1 > 0 ) {\n    for ( int j = 0;\n    j < x && count_0 > 0;\n    j ++ ) {\n      if ( count_0 > 0 ) {\n        cout << \"0\";\n        count_0 --;\n      }\n    }\n    for ( int j = 0;\n    j < y && count_1 > 0;\n    j ++ ) {\n      if ( count_1 > 0 ) {\n        cout << \"1\";\n        count_1 --;\n      }\n    }\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_14_MAXIMUM_SUM_INCREASING_SUBSEQUENCE": "int maxSumIS ( int arr [ ], int n ) {\n  int i, j, max = 0;\n  int msis [ n ];\n  for ( i = 0;\n  i < n;\n  i ++ ) msis [ i ] = arr [ i ];\n  for ( i = 1;\n  i < n;\n  i ++ ) for ( j = 0;\n  j < i;\n  j ++ ) if ( arr [ i ] > arr [ j ] && msis [ i ] < msis [ j ] + arr [ i ] ) msis [ i ] = msis [ j ] + arr [ i ];\n  for ( i = 0;\n  i < n;\n  i ++ ) if ( max < msis [ i ] ) max = msis [ i ];\n  return max;\n}\n", "NUMBER_UNIQUE_RECTANGLES_FORMED_USING_N_UNIT_SQUARES": "int countRect ( int n ) {\n  int ans = 0;\n  for ( int length = 1;\n  length <= sqrt ( n );\n  ++ length ) for ( int height = length;\n  height * length <= n;\n  ++ height ) ans ++;\n  return ans;\n}\n", "PROGRAM_TO_PRINT_TETRAHEDRAL_NUMBERS_UPTO_NTH_TERM": "void printSeries ( int n ) {\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    int num = i * ( i + 1 ) * ( i + 2 ) / 6;\n    cout << num << \" \";\n  }\n}\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX": "void transpose ( int A [ ] [ N ], int B [ ] [ N ] ) {\n  int i, j;\n  for ( i = 0;\n  i < N;\n  i ++ ) for ( j = 0;\n  j < N;\n  j ++ ) B [ i ] [ j ] = A [ j ] [ i ];\n}\n", "PROGRAM_DECIMAL_BINARY_CONVERSION_1": "int decToBinary ( int n ) {\n  for ( int i = 31;\n  i >= 0;\n  i -- ) {\n    int k = n >> i;\n    if ( k & 1 ) cout << \"1\";\n    else cout << \"0\";\n  }\n}\n", "REARRANGE_ARRAY_ORDER_SMALLEST_LARGEST_2ND_SMALLEST_2ND_LARGEST": "void rearrangeArray ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int tempArr [ n ];\n  int ArrIndex = 0;\n  for ( int i = 0, j = n - 1;\n  i <= n / 2 || j > n / 2;\n  i ++, j -- ) {\n    tempArr [ ArrIndex ] = arr [ i ];\n    ArrIndex ++;\n    tempArr [ ArrIndex ] = arr [ j ];\n    ArrIndex ++;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = tempArr [ i ];\n}\n", "SUM_AREA_RECTANGLES_POSSIBLE_ARRAY": "int MaxTotalRectangleArea ( int a [ ], int n ) {\n  sort ( a, a + n, greater < int > ( ) );\n  int sum = 0;\n  bool flag = false;\n  int len;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ( a [ i ] == a [ i + 1 ] || a [ i ] - a [ i + 1 ] == 1 ) && ( ! flag ) ) {\n      flag = true;\n      len = a [ i + 1 ];\n      i ++;\n    }\n    else if ( ( a [ i ] == a [ i + 1 ] || a [ i ] - a [ i + 1 ] == 1 ) && ( flag ) ) {\n      sum = sum + a [ i + 1 ] * len;\n      flag = false;\n      i ++;\n    }\n  }\n  return sum;\n}\n", "GIVEN_BINARY_STRING_COUNT_NUMBER_SUBSTRINGS_START_END_1": "int countSubStr ( char str [ ] ) {\n  int res = 0;\n  for ( int i = 0;\n  str [ i ] != '\\0';\n  i ++ ) {\n    if ( str [ i ] == '1' ) {\n      for ( int j = i + 1;\n      str [ j ] != '\\0';\n      j ++ ) if ( str [ j ] == '1' ) res ++;\n    }\n  }\n  return res;\n}\n", "DYNAMIC_PROGRAMMING_SET_31_OPTIMAL_STRATEGY_FOR_A_GAME": "int optimalStrategyOfGame ( int * arr, int n ) {\n  int table [ n ] [ n ];\n  for ( int gap = 0;\n  gap < n;\n  ++ gap ) {\n    for ( int i = 0, j = gap;\n    j < n;\n    ++ i, ++ j ) {\n      int x = ( ( i + 2 ) <= j ) ? table [ i + 2 ] [ j ] : 0;\n      int y = ( ( i + 1 ) <= ( j - 1 ) ) ? table [ i + 1 ] [ j - 1 ] : 0;\n      int z = ( i <= ( j - 2 ) ) ? table [ i ] [ j - 2 ] : 0;\n      table [ i ] [ j ] = max ( arr [ i ] + min ( x, y ), arr [ j ] + min ( y, z ) );\n    }\n  }\n  return table [ 0 ] [ n - 1 ];\n}\n", "REPLACE_CHARACTER_C1_C2_C2_C1_STRING_S": "string replace ( string s, char c1, char c2 ) {\n  int l = s . length ( );\n  for ( int i = 0;\n  i < l;\n  i ++ ) {\n    if ( s [ i ] == c1 ) s [ i ] = c2;\n    else if ( s [ i ] == c2 ) s [ i ] = c1;\n  }\n  return s;\n}\n", "FIND_THE_LARGEST_SUBARRAY_WITH_0_SUM_1": "int maxLen ( int arr [ ], int n ) {\n  unordered_map < int, int > presum;\n  int sum = 0;\n  int max_len = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    sum += arr [ i ];\n    if ( arr [ i ] == 0 && max_len == 0 ) max_len = 1;\n    if ( sum == 0 ) max_len = i + 1;\n    if ( presum . find ( sum ) != presum . end ( ) ) {\n      max_len = max ( max_len, i - presum [ sum ] );\n    }\n    else {\n      presum [ sum ] = i;\n    }\n  }\n  return max_len;\n}\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM_1": "int summingSeries ( long n ) {\n  return pow ( n, 2 );\n}\n", "RECURSIVE_C_PROGRAM_LINEARLY_SEARCH_ELEMENT_GIVEN_ARRAY": "int recSearch ( int arr [ ], int l, int r, int x ) {\n  if ( r < l ) return - 1;\n  if ( arr [ l ] == x ) return l;\n  if ( arr [ r ] == x ) return r;\n  return recSearch ( arr, l + 1, r - 1, x );\n}\n", "PRINT_SHORTEST_PATH_PRINT_STRING_SCREEN": "void printPath ( string str ) {\n  int i = 0;\n  int curX = 0, curY = 0;\n  while ( i < str . length ( ) ) {\n    int nextX = ( str [ i ] - 'A' ) / 5;\n    int nextY = ( str [ i ] - 'B' + 1 ) % 5;\n    while ( curX > nextX ) {\n      cout << \"Move Up\" << endl;\n      curX --;\n    }\n    while ( curY > nextY ) {\n      cout << \"Move Left\" << endl;\n      curY --;\n    }\n    while ( curX < nextX ) {\n      cout << \"Move Down\" << endl;\n      curX ++;\n    }\n    while ( curY < nextY ) {\n      cout << \"Move Right\" << endl;\n      curY ++;\n    }\n    cout << \"Press OK\" << endl;\n    i ++;\n  }\n}\n", "COUNT_ENTRIES_EQUAL_TO_X_IN_A_SPECIAL_MATRIX": "int count ( int n, int x ) {\n  int count == 0;\n  for ( int i = 1;\n  i <= n && i <= x;\n  i ++ ) {\n    if ( x / i <= n && x % i == 0 ) count ++;\n  }\n  return count;\n}\n", "PROGRAM_FIND_LINE_PASSING_2_POINTS": "pair < double, double > void lineFromPoints ( pdd P, pdd Q ) {\n  double a = Q . second - P . second;\n  double b = P . first - Q . first;\n  double c = a * ( P . first ) + b * ( P . second );\n  if ( b < 0 ) {\n    cout << \"The line passing through points P and Q is: \" << a << \"x \" << b << \"y = \" << c << endl;\n  }\n  else {\n    cout << \"The line passing through points P and Q is: \" << a << \"x + \" << b << \"y = \" << c << endl;\n  }\n}\n", "REMOVE_ARRAY_END_ELEMENT_MAXIMIZE_SUM_PRODUCT": "int solve ( int dp [ ] [ MAX ], int a [ ], int low, int high, int turn ) {\n  if ( low == high ) return a [ low ] * turn;\n  if ( dp [ low ] [ high ] != 0 ) 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}\n", "CHECK_GRAPHS_CYCLE_ODD_LENGTH": "bool containsOdd ( int G [ ] [ V ], int src ) {\n  int colorArr [ V ];\n  for ( int i = 0;\n  i < V;\n  ++ i ) colorArr [ i ] = - 1;\n  colorArr [ src ] = 1;\n  queue < int > q;\n  q . push ( src );\n  while ( ! q . empty ( ) ) {\n    int u = q . front ( );\n    q . pop ( );\n    if ( G [ u ] [ u ] == 1 ) return true;\n    for ( int v = 0;\n    v < V;\n    ++ v ) {\n      if ( G [ u ] [ v ] && colorArr [ v ] == - 1 ) {\n        colorArr [ v ] = 1 - colorArr [ u ];\n        q . push ( v );\n      }\n      else if ( G [ u ] [ v ] && colorArr [ v ] == colorArr [ u ] ) return true;\n    }\n  }\n  return false;\n}\n", "SUM_SERIES_ALTERNATE_SIGNED_SQUARES_AP": "int seiresSum ( int n, int a [ ] ) {\n  int res = 0;\n  for ( int i = 0;\n  i < 2 * n;\n  i ++ ) {\n    if ( i % 2 == 0 ) res += a [ i ] * a [ i ];\n    else res -= a [ i ] * a [ i ];\n  }\n  return res;\n}\n", "PROGRAM_DECIMAL_BINARY_CONVERSION": "void decToBinary ( int n ) {\n  int binaryNum [ 32 ];\n  int i = 0;\n  while ( n > 0 ) {\n    binaryNum [ i ] = n % 2;\n    n = n / 2;\n    i ++;\n  }\n  for ( int j = i - 1;\n  j >= 0;\n  j -- ) cout << binaryNum [ j ];\n}\n", "LONGEST_ALTERNATING_POSITIVE_NEGATIVE_SUBARRAY_STARTING_EVERY_INDEX": "void longestAlternating ( int arr [ ], int n ) {\n  int count [ n ];\n  count [ n - 1 ] = 1;\n  for ( int i = n - 2;\n  i >= 0;\n  i -- ) {\n    if ( arr [ i ] * arr [ i + 1 ] < 0 ) count [ i ] = count [ i + 1 ] + 1;\n    else count [ i ] = 1;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) cout << count [ i ] << \" \";\n}\n", "FIND_STRING_LEXICOGRAPHIC_ORDER_GIVEN_TWO_STRINGS": "string lexNext ( string s, int n ) {\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    if ( s [ i ] != 'z' ) {\n      s [ i ] ++;\n      return s;\n    }\n    s [ i ] = 'a';\n  }\n}\n", "NUMBER_DECIMAL_NUMBERS_LENGTH_K_STRICT_MONOTONE": "int getNumStrictMonotone ( int len ) {\n  int DP [ len ] [ DP_s ];\n  memset ( DP, 0, sizeof ( DP ) );\n  for ( int i = 0;\n  i < DP_s;\n  ++ i ) DP [ 0 ] [ i ] = i + 1;\n  for ( int i = 1;\n  i < len;\n  ++ i ) for ( int j = 1;\n  j < DP_s;\n  ++ j ) DP [ i ] [ j ] = DP [ i - 1 ] [ j - 1 ] + DP [ i ] [ j - 1 ];\n  return DP [ len - 1 ] [ DP_s - 1 ];\n}\n", "PRINT_POSSIBLE_EDGES_TREE_GIVEN_DIAMETER_HEIGHT_VERTICES": "void constructTree ( int n, int d, int h ) {\n  if ( d == 1 ) {\n    if ( n == 2 && h == 1 ) {\n      cout << \"1 2\" << endl;\n      return;\n    }\n    cout << \"-1\" << endl;\n    return;\n  }\n  if ( d > 2 * h ) {\n    cout << \"-1\" << endl;\n    return;\n  }\n  for ( int i = 1;\n  i <= h;\n  i ++ ) cout << i << \" \" << i + 1 << endl;\n  if ( d > h ) {\n    cout << \"1\" << \" \" << h + 2 << endl;\n    for ( int i = h + 2;\n    i <= d;\n    i ++ ) {\n      cout << i << \" \" << i + 1 << endl;\n    }\n  }\n  for ( int i = d + 1;\n  i < n;\n  i ++ ) {\n    int k = 1;\n    if ( d == h ) k = 2;\n    cout << k << \" \" << i + 1 << endl;\n  }\n}\n", "MINIMAL_OPERATIONS_MAKE_NUMBER_MAGICAL": "int calculate ( string s ) {\n  int ans = 6;\n  for ( int i = 0;\n  i < 10;\n  ++ i ) {\n    for ( int j = 0;\n    j < 10;\n    ++ j ) {\n      for ( int k = 0;\n      k < 10;\n      ++ k ) {\n        for ( int l = 0;\n        l < 10;\n        ++ l ) {\n          for ( int m = 0;\n          m < 10;\n          ++ m ) {\n            for ( int n = 0;\n            n < 10;\n            ++ n ) {\n              if ( i + j + k == l + m + n ) {\n                int c = 0;\n                if ( i != s [ 0 ] - '0' ) c ++;\n                if ( j != s [ 1 ] - '0' ) c ++;\n                if ( k != s [ 2 ] - '0' ) c ++;\n                if ( l != s [ 3 ] - '0' ) c ++;\n                if ( m != s [ 4 ] - '0' ) c ++;\n                if ( n != s [ 5 ] - '0' ) c ++;\n                if ( c < ans ) ans = c;\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  return ans;\n}\n", "FIND_A_TRIPLET_THAT_SUM_TO_A_GIVEN_VALUE": "bool find3Numbers ( int A [ ], int arr_size, int sum ) {\n  int l, r;\n  for ( int i = 0;\n  i < arr_size - 2;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < arr_size - 1;\n    j ++ ) {\n      for ( int k = j + 1;\n      k < arr_size;\n      k ++ ) {\n        if ( A [ i ] + A [ j ] + A [ k ] == sum ) {\n          cout << \"Triplet is \" << A [ i ] << \", \" << A [ j ] << \", \" << A [ k ];\n          return true;\n        }\n      }\n    }\n  }\n  return false;\n}\n", "AREA_OF_THE_CIRCLE_THAT_HAS_A_SQUARE_AND_A_CIRCLE_INSCRIBED_IN_IT": "float getArea ( int a ) {\n  float area = ( M_PI * a * a ) / 4.0;\n  return area;\n}\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X_1": "void findPairs ( int arr1 [ ], int arr2 [ ], int n, int m, int x ) {\n  unordered_set < int > s;\n  for ( int i = 0;\n  i < n;\n  i ++ ) s . insert ( arr1 [ i ] );\n  for ( int j = 0;\n  j < m;\n  j ++ ) if ( s . find ( x - arr2 [ j ] ) != s . end ( ) ) cout << x - arr2 [ j ] << \" \" << arr2 [ j ] << endl;\n}\n", "QUICK_WAY_CHECK_CHARACTERS_STRING": "bool allCharactersSame ( string s ) {\n  int n = s . length ( );\n  for ( int i = 1;\n  i < n;\n  i ++ ) if ( s [ i ] != s [ 0 ] ) return false;\n  return true;\n}\n", "REARRANGE_ARRAY_ARRI": "int fix ( int A [ ], int len ) {\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    if ( A [ i ] != - 1 && A [ i ] != i ) {\n      int x = A [ i ];\n      while ( A [ x ] != - 1 && A [ x ] != x ) {\n        int y = A [ x ];\n        A [ x ] = x;\n        x = y;\n      }\n      A [ x ] = x;\n      if ( A [ i ] != i ) {\n        A [ i ] = - 1;\n      }\n    }\n  }\n}\n", "PAIR_WITH_GIVEN_PRODUCT_SET_1_FIND_IF_ANY_PAIR_EXISTS": "bool isProduct ( int arr [ ], int n, int x ) {\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) for ( int j = i + 1;\n  i < n;\n  i ++ ) if ( arr [ i ] * arr [ j ] == x ) return true;\n  return false;\n}\n", "SORT_GIVEN_STRING_USING_CHARACTER_SEARCH": "string sortString ( string str, int n ) {\n  string new_str = \"\";\n  for ( int i = 'a';\n  i <= 'z';\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) if ( str [ j ] == i ) new_str += str [ j ];\n  return new_str;\n}\n", "COUNT_OF_OCCURRENCES_OF_A_101_PATTERN_IN_A_STRING": "int countPattern ( string str ) {\n  int len = str . size ( );\n  bool oneSeen = 0;\n  int count = 0;\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    if ( str [ i ] == '1' && oneSeen == 1 ) if ( str [ i - 1 ] == '0' ) count ++;\n    if ( str [ i ] == '1' && oneSeen == 0 ) {\n      oneSeen = 1;\n      continue;\n    }\n    if ( str [ i ] != '0' && str [ i ] != '1' ) oneSeen = 0;\n  }\n  return count;\n}\n", "C_PROGRAM_CYCLICALLY_ROTATE_ARRAY_ONE": "void rotate ( int arr [ ], int n ) {\n  int x = arr [ n - 1 ], i;\n  for ( i = n - 1;\n  i > 0;\n  i -- ) arr [ i ] = arr [ i - 1 ];\n  arr [ 0 ] = x;\n}\n", "QUEUE_BASED_APPROACH_FOR_FIRST_NON_REPEATING_CHARACTER_IN_A_STREAM": "void firstnonrepeating ( char str [ ] ) {\n  queue < char > q;\n  int charCount [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    str [ i ];\n    i ++ ) {\n      q . push ( str [ i ] );\n      charCount [ str [ i ] - 'a' ] ++;\n      while ( ! q . empty ( ) ) {\n        if ( charCount [ q . front ( ) - 'a' ] > 1 ) q . pop ( );\n        else {\n          cout << q . front ( ) << \" \";\n          break;\n        }\n      }\n      if ( q . empty ( ) ) cout << - 1 << \" \";\n    }\n    cout << endl;\n  }\n  ", "CHECK_LARGE_NUMBER_DIVISIBLE_6_NOT": "bool check ( string str ) {\n  int n = str . length ( );\n  if ( ( str [ n - 1 ] - '0' ) % 2 != 0 ) return false;\n  int digitSum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) digitSum += ( str [ i ] - '0' );\n  return ( digitSum % 3 == 0 );\n}\n", "MINIMUM_NUMBER_OF_SQUARES_WHOSE_SUM_EQUALS_TO_GIVEN_NUMBER_N": "int getMinSquares ( unsigned int n ) {\n  if ( sqrt ( n ) - floor ( sqrt ( n ) ) == 0 ) return 1;\n  if ( n <= 3 ) return n;\n  int res = n;\n  for ( int x = 1;\n  x <= n;\n  x ++ ) {\n    int temp = x * x;\n    if ( temp > n ) break;\n    else res = min ( res, 1 + getMinSquares ( n - temp ) );\n  }\n  return res;\n}\n", "OVERLAPPING_SUM_TWO_ARRAY": "int findSum ( int A [ ], int B [ ], int n ) {\n  unordered_map < int, int > hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    hash [ A [ i ] ] ++;\n    hash [ B [ i ] ] ++;\n  }\n  int sum = 0;\n  for ( auto x : hash ) if ( x . second == 1 ) sum += x . first;\n  return sum;\n}\n", "MOBILE_NUMERIC_KEYPAD_PROBLEM": "int getCount ( char keypad [ ] [ 3 ], int n ) {\n  if ( keypad == NULL || n <= 0 ) return 0;\n  if ( n == 1 ) return 10;\n  int odd [ 10 ], even [ 10 ];\n  int i = 0, j = 0, useOdd = 0, totalCount = 0;\n  for ( i = 0;\n  i <= 9;\n  i ++ ) odd [ i ] = 1;\n  for ( j = 2;\n  j <= n;\n  j ++ ) {\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    }\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    }\n  }\n  totalCount = 0;\n  if ( useOdd == 1 ) {\n    for ( i = 0;\n    i <= 9;\n    i ++ ) totalCount += even [ i ];\n  }\n  else {\n    for ( i = 0;\n    i <= 9;\n    i ++ ) totalCount += odd [ i ];\n  }\n  return totalCount;\n}\n", "FIND_ELEMENTS_LARGER_HALF_ELEMENTS_ARRAY": "void findLarger ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  for ( int i = n - 1;\n  i >= n / 2;\n  i -- ) cout << arr [ i ] << \" \";\n}\n", "SUM_BINOMIAL_COEFFICIENTS": "int binomialCoeffSum ( int n ) {\n  int C [ n + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= min ( i, n );\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ];\n    }\n  }\n  int sum = 0;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) sum += C [ n ] [ i ];\n  return sum;\n}\n", "FIND_COMMON_ELEMENT_ROWS_ROW_WISE_SORTED_MATRIX_1": "int findCommon ( int mat [ M ] [ N ] ) {\n  unordered_map < int, int > cnt;\n  int i, j;\n  for ( i = 0;\n  i < M;\n  i ++ ) {\n    cnt [ mat [ i ] [ 0 ] ] ++;\n    for ( j = 1;\n    j < N;\n    j ++ ) {\n      if ( mat [ i ] [ j ] != mat [ i ] [ j - 1 ] ) cnt [ mat [ i ] [ j ] ] ++;\n    }\n  }\n  for ( auto ele : cnt ) {\n    if ( ele . second == M ) return ele . first;\n  }\n  return - 1;\n}\n", "SIEVE_ERATOSTHENES_0N_TIME_COMPLEXITY": "void manipulated_seive ( int N ) {\n  isprime [ 0 ] = isprime [ 1 ] = false;\n  for ( long long int i = 2;\n  i < N;\n  i ++ ) {\n    if ( isprime [ i ] ) {\n      prime . push_back ( i );\n      SPF [ i ] = i;\n    }\n    for ( long long int j = 0;\n    j < ( int ) prime . size ( ) && i * prime [ j ] < N && prime [ j ] <= SPF [ i ];\n    j ++ ) {\n      isprime [ i * prime [ j ] ] = false;\n      SPF [ i * prime [ j ] ] = prime [ j ];\n    }\n  }\n}\n", "COUNT_SORTED_ROWS_MATRIX": "int sortedCount ( int mat [ ] [ MAX ], int r, int c ) {\n  int result = 0;\n  for ( int i = 0;\n  i < r;\n  i ++ ) {\n    int j;\n    for ( j = 0;\n    j < c - 1;\n    j ++ ) if ( mat [ i ] [ j + 1 ] <= mat [ i ] [ j ] ) break;\n    if ( j == c - 1 ) result ++;\n  }\n  for ( int i = 0;\n  i < r;\n  i ++ ) {\n    int j;\n    for ( j = c - 1;\n    j > 0;\n    j -- ) if ( mat [ i ] [ j - 1 ] <= mat [ i ] [ j ] ) break;\n    if ( c > 1 && j == 0 ) result ++;\n  }\n  return result;\n}\n", "NUMBER_WAYS_NODE_MAKE_LOOP_SIZE_K_UNDIRECTED_COMPLETE_CONNECTED_GRAPH_N_NODES": "int numOfways ( int n, int k ) {\n  int p = 1;\n  if ( k % 2 ) p = - 1;\n  return ( pow ( n - 1, k ) + p * ( n - 1 ) ) / n;\n}\n", "DICE_THROW_PROBLEM": "int findWays ( int m, int n, int x ) {\n  int table [ n + 1 ] [ x + 1 ];\n  memset ( table, 0, sizeof ( table ) );\n  for ( int j = 1;\n  j <= m && j <= x;\n  j ++ ) table [ 1 ] [ j ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) for ( int j = 1;\n  j <= x;\n  j ++ ) for ( int k = 1;\n  k <= m && k < j;\n  k ++ ) table [ i ] [ j ] += table [ i - 1 ] [ j - k ];\n  return table [ n ] [ x ];\n}\n", "MINIMUM_NUMBER_DELETIONS_MAKE_STRING_PALINDROME_SET_2": "int getLevenstein ( string const & input ) {\n  string revInput ( input . rbegin ( ), input . rend ( ) );\n  int n = input . size ( );\n  vector < vector < int > > dp ( n + 1, vector < int > ( n + 1, - 1 ) );\n  for ( int i = 0;\n  i <= n;\n  ++ i ) {\n    dp [ 0 ] [ i ] = i;\n    dp [ i ] [ 0 ] = i;\n  }\n  for ( int i = 1;\n  i <= n;\n  ++ i ) {\n    for ( int j = 1;\n    j <= n;\n    ++ j ) {\n      if ( input [ i - 1 ] == revInput [ j - 1 ] ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = 1 + min ( {\n        dp [ i - 1 ] [ j ], dp [ i ] [ j - 1 ] }\n        );\n      }\n    }\n    int res = numeric_limits < int > :: max ( );\n    for ( int i = n, j = 0;\n    i >= 0;\n    -- i, ++ j ) {\n      res = min ( res, dp [ i ] [ j ] );\n      if ( i < n ) res = min ( res, dp [ i + 1 ] [ j ] );\n      if ( i > 0 ) res = min ( res, dp [ i - 1 ] [ j ] );\n    }\n    return res;\n  }\n  ", "DYNAMIC_PROGRAMMING_SET_37_BOOLEAN_PARENTHESIZATION_PROBLEM": "int countParenth ( char symb [ ], char oper [ ], int n ) {\n  int F [ n ] [ n ], T [ n ] [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    F [ i ] [ i ] = ( symb [ i ] == 'F' ) ? 1 : 0;\n    T [ i ] [ i ] = ( symb [ i ] == 'T' ) ? 1 : 0;\n  }\n  for ( int gap = 1;\n  gap < n;\n  ++ gap ) {\n    for ( int i = 0, j = gap;\n    j < n;\n    ++ i, ++ j ) {\n      T [ i ] [ j ] = F [ i ] [ j ] = 0;\n      for ( int g = 0;\n      g < gap;\n      g ++ ) {\n        int k = i + g;\n        int tik = T [ i ] [ k ] + F [ i ] [ k ];\n        int 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        }\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        }\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        }\n      }\n    }\n  }\n  return T [ 0 ] [ n - 1 ];\n}\n", "PYTHON_PROGRAM_FIND_PERIMETER_CIRCUMFERENCE_SQUARE_RECTANGLE_1": "int Circumference ( int l, int w ) {\n  return ( 2 * ( l + w ) );\n}\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS_1": "void thirdLargest ( int arr [ ], int arr_size ) {\n  if ( arr_size < 3 ) {\n    printf ( \" Invalid Input \" );\n    return;\n  }\n  int first = arr [ 0 ], second = INT_MIN, third = INT_MIN;\n  for ( int i = 1;\n  i < arr_size;\n  i ++ ) {\n    if ( arr [ i ] > first ) {\n      third = second;\n      second = first;\n      first = arr [ i ];\n    }\n    else if ( arr [ i ] > second ) {\n      third = second;\n      second = arr [ i ];\n    }\n    else if ( arr [ i ] > third ) third = arr [ i ];\n  }\n  printf ( \"The third Largest element is %d\\n\", third );\n}\n", "MINIMUM_ROOMS_FOR_M_EVENTS_OF_N_BATCHES_WITH_GIVEN_SCHEDULE": "int findMinRooms ( string slots [ ], int n, int m ) {\n  int counts [ m ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) for ( int j = 0;\n    j < m;\n    j ++ ) if ( slots [ i ] [ j ] == '1' ) counts [ j ] ++;\n    return * max_element ( counts, counts + m );\n  }\n  ", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM": "bool isSubsetSum ( int set [ ], int n, int sum ) {\n  if ( sum == 0 ) return true;\n  if ( n == 0 && sum != 0 ) return false;\n  if ( set [ n - 1 ] > sum ) return isSubsetSum ( set, n - 1, sum );\n  return isSubsetSum ( set, n - 1, sum ) || isSubsetSum ( set, n - 1, sum - set [ n - 1 ] );\n}\n", "COUNT_WAYS_DIVIDE_CIRCLE_USING_N_NON_INTERSECTING_CHORDS": "int chordCnt ( int A ) {\n  int n = 2 * A;\n  int dpArray [ n + 1 ] = {\n    0 };\n    dpArray [ 0 ] = 1;\n    dpArray [ 2 ] = 1;\n    for ( int i = 4;\n    i <= n;\n    i += 2 ) {\n      for ( int j = 0;\n      j < i - 1;\n      j += 2 ) {\n        dpArray [ i ] += ( dpArray [ j ] * dpArray [ i - 2 - j ] );\n      }\n    }\n    return dpArray [ n ];\n  }\n  ", "BREAK_NUMBER_THREE_PARTS_1": "ll count_of_ways ( ll n ) {\n  ll count;\n  count = ( n + 1 ) * ( n + 2 ) / 2;\n  return count;\n}\n", "PRINT_DIGITS_POSITION_REMOVED_MAKE_NUMBER_DIVISIBLE_6": "void greatest ( string s ) {\n  int n = s . length ( );\n  int a [ n ];\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    a [ i ] = s [ i ] - '0';\n    sum += a [ i ];\n  }\n  if ( a [ n - 1 ] % 2 ) {\n    if ( a [ n - 2 ] % 2 != 0 or ( sum - a [ n - 1 ] ) % 3 != 0 ) {\n      cout << \"-1\" << endl;\n    }\n    else {\n      cout << n << endl;\n    }\n  }\n  else {\n    int re = sum % 3;\n    int del = - 1;\n    int flag = 0;\n    for ( int i = 0;\n    i < n - 1;\n    i ++ ) {\n      if ( ( a [ i ] ) % 3 == re ) {\n        if ( a [ i + 1 ] > a [ i ] ) {\n          del = i;\n          flag = 1;\n          break;\n        }\n        else {\n          del = i;\n        }\n      }\n    }\n    if ( flag == 0 ) {\n      if ( a [ n - 2 ] % 2 == 0 and re == a [ n - 1 ] % 3 ) del = n - 1;\n    }\n    if ( del == - 1 ) cout << - 1 << endl;\n    else {\n      cout << del + 1 << endl;\n    }\n  }\n}\n", "MAXIMUM_HEIGHT_OF_TRIANGULAR_ARRANGEMENT_OF_ARRAY_VALUES": "int MaximumHeight ( int a [ ], int n ) {\n  int result = 1;\n  for ( int i = 1;\n  i <= n;\n  ++ i ) {\n    long long y = ( i * ( i + 1 ) ) / 2;\n    if ( y < n ) result = i;\n    else break;\n  }\n  return result;\n}\n", "SQUARED_TRIANGULAR_NUMBER_SUM_CUBES": "int findS ( int s ) {\n  int sum = 0;\n  for ( int n = 1;\n  sum < s;\n  n ++ ) {\n    sum += n * n * n;\n    if ( sum == s ) return n;\n  }\n  return - 1;\n}\n", "EVALUATE_A_BOOLEAN_EXPRESSION_REPRESENTED_AS_STRING": "int evaluateBoolExpr ( string s ) {\n  int n = s . length ( );\n  for ( int i = 0;\n  i < n;\n  i += 2 ) {\n    if ( s [ i + 1 ] == 'A' ) {\n      if ( s [ i + 2 ] == '0' || s [ i ] == '0' ) s [ i + 2 ] = '0';\n      else s [ i + 2 ] = '1';\n    }\n    else if ( s [ i + 1 ] == 'B' ) {\n      if ( s [ i + 2 ] == '1' || s [ i ] == '1' ) s [ i + 2 ] = '1';\n      else s [ i + 2 ] = '0';\n    }\n    else {\n      if ( s [ i + 2 ] == s [ i ] ) s [ i + 2 ] = '0';\n      else s [ i + 2 ] = '1';\n    }\n  }\n  return s [ n - 1 ] - '0';\n}\n", "PROGRAMMING_PUZZLE_ASSIGN_VALUE_WITHOUT_CONTROL_STATEMENT": "int assignValue ( int a, int b, bool x ) {\n  int arr [ ] = {\n    a, b };\n    return ( arr [ x ] );\n  }\n  ", "MINIMUM_SUM_SQUARES_CHARACTERS_COUNTS_GIVEN_STRING_REMOVING_K_CHARACTERS": "int minStringValue ( string str, int k ) {\n  int l = str . length ( );\n  if ( k >= l ) return 0;\n  int frequency [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < l;\n    i ++ ) frequency [ str [ i ] - 'a' ] ++;\n    priority_queue < int > q;\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) q . push ( frequency [ i ] );\n    while ( k -- ) {\n      int temp = q . top ( );\n      q . pop ( );\n      temp = temp - 1;\n      q . push ( temp );\n    }\n    int result = 0;\n    while ( ! q . empty ( ) ) {\n      int temp = q . top ( );\n      result += temp * temp;\n      q . pop ( );\n    }\n    return result;\n  }\n  ", "MAJORITY_ELEMENT_1": "void findMajority ( int arr [ ], int size ) {\n  unordered_map < int, int > m;\n  for ( int i = 0;\n  i < size;\n  i ++ ) m [ arr [ i ] ] ++;\n  int count = 0;\n  for ( auto i : m ) {\n    if ( i . second > size / 2 ) {\n      count = 1;\n      cout << \"Majority found :- \" << i . first << endl;\n      break;\n    }\n  }\n  if ( count == 0 ) cout << \"No Majority element\" << endl;\n}\n", "LARGEST_SUBSET_GRAPH_VERTICES_EDGES_2_COLORS": "int subsetGraph ( int C [ ] [ N ] ) {\n  set < int > vertices;\n  for ( int i = 0;\n  i < N;\n  ++ i ) vertices . insert ( i );\n  while ( ! vertices . empty ( ) ) {\n    if ( vertices . size ( ) == 1 ) return 1;\n    bool someone_removed = false;\n    for ( int x : vertices ) {\n      set < int > values;\n      for ( int y : vertices ) if ( y != x ) values . insert ( C [ x ] [ y ] );\n      if ( values . size ( ) == 1 ) {\n        vertices . erase ( x );\n        someone_removed = true;\n        break;\n      }\n    }\n    if ( ! someone_removed ) break;\n  }\n  return ( vertices . size ( ) );\n}\n", "FLOOR_IN_A_SORTED_ARRAY_1": "int floorSearch ( int arr [ ], int low, int high, int x ) {\n  if ( low > high ) return - 1;\n  if ( x >= arr [ high ] ) return high;\n  int mid = ( low + high ) / 2;\n  if ( arr [ mid ] == x ) return mid;\n  if ( mid > 0 && arr [ mid - 1 ] <= x && x < arr [ mid ] ) return mid - 1;\n  if ( x < arr [ mid ] ) return floorSearch ( arr, low, mid - 1, x );\n  return floorSearch ( arr, mid + 1, high, x );\n}\n", "LONGEST_PREFIX_ALSO_SUFFIX_1": "int longestPrefixSuffix ( string s ) {\n  int n = s . length ( );\n  int lps [ n ];\n  lps [ 0 ] = 0;\n  int len = 0;\n  int i = 1;\n  while ( i < n ) {\n    if ( s [ i ] == s [ len ] ) {\n      len ++;\n      lps [ i ] = len;\n      i ++;\n    }\n    else {\n      if ( len != 0 ) {\n        len = lps [ len - 1 ];\n      }\n      else {\n        lps [ i ] = 0;\n        i ++;\n      }\n    }\n  }\n  int res = lps [ n - 1 ];\n  return ( res > n / 2 ) ? n / 2 : res;\n}\n", "COUNT_NUMBER_OF_WAYS_TO_PARTITION_A_SET_INTO_K_SUBSETS": "int countP ( int n, int k ) {\n  if ( n == 0 || k == 0 || k > n ) return 0;\n  if ( k == 1 || k == n ) return 1;\n  return k * countP ( n - 1, k ) + countP ( n - 1, k - 1 );\n}\n", "C_PROGRAM_FACTORIAL_NUMBER_2": "int factorial ( int n ) {\n  return ( n == 1 || n == 0 ) ? 1 : n * factorial ( n - 1 );\n}\n", "FIND_REPEATED_CHARACTER_PRESENT_FIRST_STRING_1": "int findRepeatFirst ( char * s ) {\n  int p = - 1, i, k;\n  int hash [ MAX_CHAR ] = {\n    0 };\n    int pos [ MAX_CHAR ];\n    for ( i = 0;\n    i < strlen ( s );\n    i ++ ) {\n      k = ( int ) s [ i ];\n      if ( hash [ k ] == 0 ) {\n        hash [ k ] ++;\n        pos [ k ] = i;\n      }\n      else if ( hash [ k ] == 1 ) hash [ k ] ++;\n    }\n    for ( i = 0;\n    i < MAX_CHAR;\n    i ++ ) {\n      if ( hash [ i ] == 2 ) {\n        if ( p == - 1 ) p = pos [ i ];\n        else if ( p > pos [ i ] ) p = pos [ i ];\n      }\n    }\n    return p;\n  }\n  ", "NUMBER_OF_PERMUTATION_WITH_K_INVERSIONS": "int numberOfPermWithKInversion ( int N, int K ) {\n  if ( N == 0 ) return 0;\n  if ( K == 0 ) return 1;\n  if ( memo [ N ] [ K ] != 0 ) return memo [ N ] [ K ];\n  int sum = 0;\n  for ( int i = 0;\n  i <= K;\n  i ++ ) {\n    if ( i <= N - 1 ) sum += numberOfPermWithKInversion ( N - 1, K - i );\n  }\n  memo [ N ] [ K ] = sum;\n  return sum;\n}\n", "K_TH_LARGEST_SUM_CONTIGUOUS_SUBARRAY": "int kthLargestSum ( int arr [ ], int n, int k ) {\n  int sum [ n + 1 ];\n  sum [ 0 ] = 0;\n  sum [ 1 ] = arr [ 0 ];\n  for ( int i = 2;\n  i <= n;\n  i ++ ) sum [ i ] = sum [ i - 1 ] + arr [ i - 1 ];\n  priority_queue < int, vector < int >, greater < int > > Q;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = i;\n    j <= n;\n    j ++ ) {\n      int x = sum [ j ] - sum [ i - 1 ];\n      if ( Q . size ( ) < k ) Q . push ( x );\n      else {\n        if ( Q . top ( ) < x ) {\n          Q . pop ( );\n          Q . push ( x );\n        }\n      }\n    }\n  }\n  return Q . top ( );\n}\n", "FIND_THE_LARGEST_THREE_ELEMENTS_IN_AN_ARRAY": "void find3largest ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int check = 0, count = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    if ( count < 4 ) {\n      if ( check != arr [ n - i ] ) {\n        cout << arr [ n - i ] << \" \";\n        check = arr [ n - i ];\n        count ++;\n      }\n    }\n    else break;\n  }\n}\n", "MAXIMUM_DISTINCT_LOWERCASE_ALPHABETS_TWO_UPPERCASE": "int maxLower ( string str ) {\n  int n = str . length ( );\n  int i = 0;\n  for (;\n  i < n;\n  i ++ ) {\n    if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) {\n      i ++;\n      break;\n    }\n  }\n  int maxCount = 0;\n  int count [ MAX_CHAR ] = {\n    0 };\n    for (;\n    i < n;\n    i ++ ) {\n      if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) {\n        int currCount = 0;\n        for ( int j = 0;\n        j < MAX_CHAR;\n        j ++ ) if ( count [ j ] > 0 ) currCount ++;\n        maxCount = max ( maxCount, currCount );\n        memset ( count, 0, sizeof ( count ) );\n      }\n      if ( str [ i ] >= 'a' && str [ i ] <= 'z' ) count [ str [ i ] - 'a' ] ++;\n    }\n    return maxCount;\n  }\n  ", "CHECK_IF_A_STRING_HAS_ALL_CHARACTERS_WITH_SAME_FREQUENCY_WITH_ONE_VARIATION_ALLOWED": "bool isValidString ( string str ) {\n  int freq [ CHARS ] = {\n    0 };\n    for ( int i = 0;\n    i < str . length ( );\n    i ++ ) freq [ str [ i ] - 'a' ] ++;\n    int i, freq1 = 0, count_freq1 = 0;\n    for ( i = 0;\n    i < CHARS;\n    i ++ ) {\n      if ( freq [ i ] != 0 ) {\n        freq1 = freq [ i ];\n        count_freq1 = 1;\n        break;\n      }\n    }\n    int j, freq2 = 0, count_freq2 = 0;\n    for ( j = i + 1;\n    j < CHARS;\n    j ++ ) {\n      if ( freq [ j ] != 0 ) {\n        if ( freq [ j ] == freq1 ) count_freq1 ++;\n        else {\n          count_freq2 = 1;\n          freq2 = freq [ j ];\n          break;\n        }\n      }\n    }\n    for ( int k = j + 1;\n    k < CHARS;\n    k ++ ) {\n      if ( freq [ k ] != 0 ) {\n        if ( freq [ k ] == freq1 ) count_freq1 ++;\n        if ( freq [ k ] == freq2 ) count_freq2 ++;\n        else return false;\n      }\n      if ( count_freq1 > 1 && count_freq2 > 1 ) return false;\n    }\n    return true;\n  }\n  ", "MAXIMUM_AVERAGE_SUM_PARTITION_ARRAY": "double largestSumOfAverages ( vector < int > & A, int K ) {\n  int n = A . size ( );\n  double pre_sum [ n + 1 ];\n  pre_sum [ 0 ] = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) pre_sum [ i + 1 ] = pre_sum [ i ] + A [ i ];\n  double dp [ n ] = {\n    0 };\n    double sum = 0;\n    for ( int i = 0;\n    i < n;\n    i ++ ) dp [ i ] = ( pre_sum [ n ] - pre_sum [ i ] ) / ( n - i );\n    for ( int k = 0;\n    k < K - 1;\n    k ++ ) for ( int i = 0;\n    i < n;\n    i ++ ) for ( int j = i + 1;\n    j < n;\n    j ++ ) dp [ i ] = max ( dp [ i ], ( pre_sum [ j ] - pre_sum [ i ] ) / ( j - i ) + dp [ j ] );\n    return dp [ 0 ];\n  }\n  ", "FIND_SUBARRAY_WITH_GIVEN_SUM_IN_ARRAY_OF_INTEGERS": "void subArraySum ( int arr [ ], int n, int sum ) {\n  unordered_map < int, int > map;\n  int curr_sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    curr_sum = curr_sum + arr [ i ];\n    if ( curr_sum == sum ) {\n      cout << \"Sum found between indexes \" << 0 << \" to \" << i << endl;\n      return;\n    }\n    if ( map . find ( curr_sum - sum ) != map . end ( ) ) {\n      cout << \"Sum found between indexes \" << map [ curr_sum - sum ] + 1 << \" to \" << i << endl;\n      return;\n    }\n    map [ curr_sum ] = i;\n  }\n  cout << \"No subarray with given sum exists\";\n}\n", "REMOVE_MINIMUM_ELEMENTS_EITHER_SIDE_2MIN_MAX": "int minRemovalsDP ( int arr [ ], int n ) {\n  int longest_start = - 1, longest_end = 0;\n  for ( int start = 0;\n  start < n;\n  start ++ ) {\n    int min = INT_MAX, max = INT_MIN;\n    for ( int end = start;\n    end < n;\n    end ++ ) {\n      int val = arr [ end ];\n      if ( val < min ) min = val;\n      if ( val > max ) max = val;\n      if ( 2 * min <= max ) break;\n      if ( end - start > longest_end - longest_start || longest_start == - 1 ) {\n        longest_start = start;\n        longest_end = end;\n      }\n    }\n  }\n  if ( longest_start == - 1 ) return n;\n  return ( n - ( longest_end - longest_start + 1 ) );\n}\n", "FIND_THE_MISSING_NUMBER_1": "int getMissingNo ( int a [ ], int n ) {\n  int i, total = 1;\n  for ( i = 2;\n  i <= ( n + 1 );\n  i ++ ) {\n    total += i;\n    total -= a [ i - 2 ];\n  }\n  return total;\n}\n", "SIEVE_SUNDARAM_PRINT_PRIMES_SMALLER_N": "int SieveOfSundaram ( int n ) {\n  int nNew = ( n - 2 ) / 2;\n  bool marked [ nNew + 1 ];\n  memset ( marked, false, sizeof ( marked ) );\n  for ( int i = 1;\n  i <= nNew;\n  i ++ ) for ( int j = i;\n  ( i + j + 2 * i * j ) <= nNew;\n  j ++ ) marked [ i + j + 2 * i * j ] = true;\n  if ( n > 2 ) cout << 2 << \" \";\n  for ( int i = 1;\n  i <= nNew;\n  i ++ ) if ( marked [ i ] == false ) cout << 2 * i + 1 << \" \";\n}\n", "MAXIMUM_PRODUCT_SUBSET_ARRAY": "int maxProductSubset ( int a [ ], int n ) {\n  if ( n == 1 ) return a [ 0 ];\n  int max_neg = INT_MIN;\n  int count_neg = 0, count_zero = 0;\n  int prod = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] == 0 ) {\n      count_zero ++;\n      continue;\n    }\n    if ( a [ i ] < 0 ) {\n      count_neg ++;\n      max_neg = max ( max_neg, a [ i ] );\n    }\n    prod = prod * a [ i ];\n  }\n  if ( count_zero == n ) return 0;\n  if ( count_neg & 1 ) {\n    if ( count_neg == 1 && count_zero > 0 && count_zero + count_neg == n ) return 0;\n    prod = prod / max_neg;\n  }\n  return prod;\n}\n", "FIND_THE_NEAREST_SMALLER_NUMBERS_ON_LEFT_SIDE_IN_AN_ARRAY": "void printPrevSmaller ( int arr [ ], int n ) {\n  cout << \"_, \";\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int j;\n    for ( j = i - 1;\n    j >= 0;\n    j -- ) {\n      if ( arr [ j ] < arr [ i ] ) {\n        cout << arr [ j ] << \", \";\n        break;\n      }\n    }\n    if ( j == - 1 ) cout << \"_, \";\n  }\n}\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0_1": "int calculate ( int a [ ], int n ) {\n  int * maximum = max_element ( a, a + 5 );\n  int frequency [ * maximum + 1 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      frequency [ a [ i ] ] += 1;\n    }\n    int answer = 0;\n    for ( int i = 0;\n    i < ( * maximum ) + 1;\n    i ++ ) {\n      answer = answer + frequency [ i ] * ( frequency [ i ] - 1 );\n    }\n    return answer / 2;\n  }\n  ", "SUM_BINOMIAL_COEFFICIENTS_1": "int binomialCoeffSum ( int n ) {\n  return ( 1 << n );\n}\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE_1": "int maxSumPairWithDifferenceLessThanK ( int arr [ ], int N, int k ) {\n  int maxSum = 0;\n  sort ( arr, arr + N );\n  for ( int i = N - 1;\n  i > 0;\n  -- i ) {\n    if ( arr [ i ] - arr [ i - 1 ] < k ) {\n      maxSum += arr [ i ];\n      maxSum += arr [ i - 1 ];\n      -- i;\n    }\n  }\n  return maxSum;\n}\n", "KTH_ADJACENT_NODE_GRAPH_VERTEX_WEIGHT": "void printkthnode ( vector < pair < int, int > > adj [ ], int wt [ ], int n, int k ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) sort ( adj [ i ] . begin ( ), adj [ i ] . end ( ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( adj [ i ] . size ( ) >= k ) cout << adj [ i ] [ adj [ i ] . size ( ) - k ] . second;\n    else cout << \"-1\";\n  }\n}\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM": "int KnapSack ( int val [ ], int wt [ ], int n, int W ) {\n  int mat [ 2 ] [ W + 1 ];\n  memset ( mat, 0, sizeof ( mat ) );\n  int i = 0;\n  while ( i < n ) {\n    int j = 0;\n    if ( i % 2 != 0 ) {\n      while ( ++ j <= W ) {\n        if ( wt [ i ] <= j ) mat [ 1 ] [ j ] = max ( val [ i ] + mat [ 0 ] [ j - wt [ i ] ], mat [ 0 ] [ j ] );\n        else mat [ 1 ] [ j ] = mat [ 0 ] [ j ];\n      }\n    }\n    else {\n      while ( ++ j <= W ) {\n        if ( wt [ i ] <= j ) mat [ 0 ] [ j ] = max ( val [ i ] + mat [ 1 ] [ j - wt [ i ] ], mat [ 1 ] [ j ] );\n        else mat [ 0 ] [ j ] = mat [ 1 ] [ j ];\n      }\n    }\n    i ++;\n  }\n  return ( n % 2 != 0 ) ? mat [ 0 ] [ W ] : mat [ 1 ] [ W ];\n}\n", "BINARY_REPRESENTATION_OF_A_GIVEN_NUMBER_1": "void bin ( unsigned n ) {\n  if ( n > 1 ) bin ( n >> 1 );\n  printf ( \"%d\", n & 1 );\n}\n", "PRIME_FACTORS_BIG_NUMBER": "void factorize ( long long n ) {\n  int count = 0;\n  while ( ! ( n % 2 ) ) {\n    n >>= 1;\n    count ++;\n  }\n  if ( count ) cout << 2 << \"  \" << count << endl;\n  for ( long long i = 3;\n  i <= sqrt ( n );\n  i += 2 ) {\n    count = 0;\n    while ( n % i == 0 ) {\n      count ++;\n      n = n / i;\n    }\n    if ( count ) cout << i << \"  \" << count << endl;\n  }\n  if ( n > 2 ) cout << n << \"  \" << 1 << endl;\n}\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS_1": "int countSubstringWithEqualEnds ( string s ) {\n  int result = 0;\n  int n = s . length ( );\n  int count [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) count [ s [ i ] - 'a' ] ++;\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) result += ( count [ i ] * ( count [ i ] + 1 ) / 2 );\n    return result;\n  }\n  ", "LONGEST_PALINDROME_SUBSTRING_SET_1": "void printSubStr ( string str, int low, int high ) {\n  for ( int i = low;\n  i <= high;\n  ++ i ) cout << str [ i ];\n}\n", "FIND_THE_SMALLEST_WINDOW_IN_A_STRING_CONTAINING_ALL_CHARACTERS_OF_ANOTHER_STRING": "string findSubString ( string str, string pat ) {\n  int len1 = str . length ( );\n  int len2 = pat . length ( );\n  if ( len1 < len2 ) {\n    cout << \"No such window exists\";\n    return \"\";\n  }\n  int hash_pat [ no_of_chars ] = {\n    0 };\n    int hash_str [ no_of_chars ] = {\n      0 };\n      for ( int i = 0;\n      i < len2;\n      i ++ ) hash_pat [ pat [ i ] ] ++;\n      int start = 0, start_index = - 1, min_len = INT_MAX;\n      int count = 0;\n      for ( int j = 0;\n      j < len1;\n      j ++ ) {\n        hash_str [ str [ j ] ] ++;\n        if ( hash_pat [ str [ j ] ] != 0 && hash_str [ str [ j ] ] <= hash_pat [ str [ j ] ] ) count ++;\n        if ( count == len2 ) {\n          while ( hash_str [ str [ start ] ] > hash_pat [ str [ start ] ] || hash_pat [ str [ start ] ] == 0 ) {\n            if ( hash_str [ str [ start ] ] > hash_pat [ str [ start ] ] ) hash_str [ str [ start ] ] --;\n            start ++;\n          }\n          int len_window = j - start + 1;\n          if ( min_len > len_window ) {\n            min_len = len_window;\n            start_index = start;\n          }\n        }\n      }\n      if ( start_index == - 1 ) {\n        cout << \"No such window exists\";\n        return \"\";\n      }\n      return str . substr ( start_index, min_len );\n    }\n    ", "MARKOV_MATRIX": "bool checkMarkov ( double m [ ] [ n ] ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    double sum = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) sum = sum + m [ i ] [ j ];\n    if ( sum != 1 ) return false;\n  }\n  return true;\n}\n", "LEAF_NODES_PREORDER_BINARY_SEARCH_TREE": "void leafNode ( int preorder [ ], int n ) {\n  stack < int > s;\n  for ( int i = 0, j = 1;\n  j < n;\n  i ++, j ++ ) {\n    bool found = false;\n    if ( preorder [ i ] > preorder [ j ] ) s . push ( preorder [ i ] );\n    else {\n      while ( ! s . empty ( ) ) {\n        if ( preorder [ j ] > s . top ( ) ) {\n          s . pop ( );\n          found = true;\n        }\n        else break;\n      }\n    }\n    if ( found ) cout << preorder [ i ] << \" \";\n  }\n  cout << preorder [ n - 1 ];\n}\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N": "unsigned int nextPowerOf2 ( unsigned int n ) {\n  unsigned count = 0;\n  if ( n && ! ( n & ( n - 1 ) ) ) return n;\n  while ( n != 0 ) {\n    n >>= 1;\n    count += 1;\n  }\n  return 1 << count;\n}\n", "PROGRAM_CHECK_WATER_TANK_OVERFLOWS_N_SOLID_BALLS_DIPPED_WATER_TANK": "void overflow ( int H, int r, int h, int N, int R ) {\n  float tank_cap = 3.14 * r * r * H;\n  float water_vol = 3.14 * r * r * h;\n  float balls_vol = N * ( 4 / 3 ) * 3.14 * R * R * R;\n  float vol = water_vol + balls_vol;\n  if ( vol > tank_cap ) {\n    cout << \"Overflow\" << endl;\n  }\n  else {\n    cout << \"Not in overflow state\" << endl;\n  }\n}\n", "SMALLEST_DERANGEMENT_SEQUENCE": "void generate_derangement ( int N ) {\n  int S [ N + 1 ];\n  for ( int i = 1;\n  i <= N;\n  i ++ ) S [ i ] = i;\n  int D [ N + 1 ];\n  for ( int i = 1;\n  i <= N;\n  i += 2 ) {\n    if ( i == N && i % N != 0 ) {\n      int temp = D [ N ] D [ N ] = D [ N - 1 ];\n      D [ N - 1 ] = temp;\n    }\n    else {\n      D [ i ] = i + 1;\n      D [ i + 1 ] = i;\n    }\n  }\n  for ( int i = 1;\n  i <= N;\n  i ++ ) printf ( \"%d \", D [ i ] );\n  printf ( \"\\n\" );\n}\n", "MAXIMUM_PRODUCT_INCREASING_SUBSEQUENCE": "ll lis ( ll arr [ ], ll n ) {\n  ll mpis [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) mpis [ i ] = arr [ i ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < i;\n  j ++ ) if ( arr [ i ] > arr [ j ] && mpis [ i ] < ( mpis [ j ] * arr [ i ] ) ) mpis [ i ] = mpis [ j ] * arr [ i ];\n  return * max_element ( mpis, mpis + n );\n}\n", "CHANGE_BITS_CAN_MADE_ONE_FLIP": "bool canMakeAllSame ( string str ) {\n  int zeros = 0, ones = 0;\n  for ( char ch : str ) ( ch == '0' ) ? ++ zeros : ++ ones;\n  return ( zeros == 1 || ones == 1 );\n}\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0": "int calculate ( int a [ ], int n ) {\n  sort ( a, a + n );\n  int count = 1;\n  int answer = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    if ( a [ i ] == a [ i - 1 ] ) {\n      count += 1;\n    }\n    else {\n      answer = answer + ( count * ( count - 1 ) ) / 2;\n      count = 1;\n    }\n  }\n  answer = answer + ( count * ( count - 1 ) ) / 2;\n  return answer;\n}\n", "FIND_ROOT_TREE_CHILDREN_ID_SUM_EVERY_NODE_GIVEN": "int findRoot ( pair < int, int > arr [ ], int n ) {\n  int root = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) root += ( arr [ i ] . first - arr [ i ] . second );\n  return root;\n}\n", "BINARY_SEARCH": "int binarySearch ( int arr [ ], int l, int r, int x ) {\n  if ( r >= l ) {\n    int mid = l + ( r - l ) / 2;\n    if ( arr [ mid ] == x ) return mid;\n    if ( arr [ mid ] > x ) return binarySearch ( arr, l, mid - 1, x );\n    return binarySearch ( arr, mid + 1, r, x );\n  }\n  return - 1;\n}\n", "FIBONACCI_MODULO_P": "int findMinZero ( int p ) {\n  int first = 1, second = 1, number = 2, next = 1;\n  while ( next ) {\n    next = ( first + second ) % p;\n    first = second;\n    second = next;\n    number ++;\n  }\n  return number;\n}\n", "K_LARGESTOR_SMALLEST_ELEMENTS_IN_AN_ARRAY": "void kLargest ( int arr [ ], int n, int k ) {\n  sort ( arr, arr + n, greater < int > ( ) );\n  for ( int i = 0;\n  i < k;\n  i ++ ) cout << arr [ i ] << \" \";\n}\n", "C_PROGRAM_FIND_AREA_CIRCLE": "float findArea ( float r ) {\n  return ( pi * r * r );\n}\n", "SUM_TWO_LARGE_NUMBERS": "string findSum ( string str1, string str2 ) {\n  if ( str1 . length ( ) > str2 . length ( ) ) swap ( str1, str2 );\n  string str = \"\";\n  int n1 = str1 . length ( ), n2 = str2 . length ( );\n  reverse ( str1 . begin ( ), str1 . end ( ) );\n  reverse ( str2 . begin ( ), str2 . end ( ) );\n  int carry = 0;\n  for ( int i = 0;\n  i < n1;\n  i ++ ) {\n    int sum = ( ( str1 [ i ] - '0' ) + ( str2 [ i ] - '0' ) + carry );\n    str . push_back ( sum % 10 + '0' );\n    carry = sum / 10;\n  }\n  for ( int i = n1;\n  i < n2;\n  i ++ ) {\n    int sum = ( ( str2 [ i ] - '0' ) + carry );\n    str . push_back ( sum % 10 + '0' );\n    carry = sum / 10;\n  }\n  if ( carry ) str . push_back ( carry + '0' );\n  reverse ( str . begin ( ), str . end ( ) );\n  return str;\n}\n", "ARRAY_RANGE_QUERIES_ELEMENTS_FREQUENCY_VALUE": "int solveQuery ( int start, int end, int arr [ ] ) {\n  unordered_map < int, int > frequency;\n  for ( int i = start;\n  i <= end;\n  i ++ ) frequency [ arr [ i ] ] ++;\n  int count = 0;\n  for ( auto x : frequency ) if ( x . first == x . second ) count ++;\n  return count;\n}\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS": "int countSubstringWithEqualEnds ( string s ) {\n  int result = 0;\n  int n = s . length ( );\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i;\n  j < n;\n  j ++ ) if ( s [ i ] == s [ j ] ) result ++;\n  return result;\n}\n", "DYNAMIC_PROGRAMMING_HIGH_EFFORT_VS_LOW_EFFORT_TASKS_PROBLEM": "int maxTasks ( int high [ ], int low [ ], int n ) {\n  if ( n <= 0 ) return 0;\n  return max ( high [ n - 1 ] + maxTasks ( high, low, ( n - 2 ) ), low [ n - 1 ] + maxTasks ( high, low, ( n - 1 ) ) );\n}\n", "MAXIMUM_DIFFERENCE_SUM_ELEMENTS_TWO_ROWS_MATRIX": "int maxRowDiff ( int mat [ ] [ MAX ], int m, int n ) {\n  int rowSum [ m ];\n  for ( int i = 0;\n  i < m;\n  i ++ ) {\n    int sum = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) sum += mat [ i ] [ j ];\n    rowSum [ i ] = sum;\n  }\n  int max_diff = rowSum [ 1 ] - rowSum [ 0 ];\n  int min_element = rowSum [ 0 ];\n  for ( int i = 1;\n  i < m;\n  i ++ ) {\n    if ( rowSum [ i ] - min_element > max_diff ) max_diff = rowSum [ i ] - min_element;\n    if ( rowSum [ i ] < min_element ) min_element = rowSum [ i ];\n  }\n  return max_diff;\n}\n", "PAPER_CUT_MINIMUM_NUMBER_SQUARES": "int minimumSquare ( int a, int b ) {\n  long long result = 0, rem = 0;\n  if ( a < b ) swap ( a, b );\n  while ( b > 0 ) {\n    result += a / b;\n    long long rem = a % b;\n    a = b;\n    b = rem;\n  }\n  return result;\n}\n", "SEARCH_AN_ELEMENT_IN_AN_ARRAY_WHERE_DIFFERENCE_BETWEEN_ADJACENT_ELEMENTS_IS_1": "int search ( int arr [ ], int n, int x ) {\n  int i = 0;\n  while ( i < n ) {\n    if ( arr [ i ] == x ) return i;\n    i = i + abs ( arr [ i ] - x );\n  }\n  cout << \"number is not present!\";\n  return - 1;\n}\n", "PANGRAM_CHECKING": "bool checkPangram ( string & str ) {\n  vector < bool > mark ( 26, false );\n  int index;\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) {\n    if ( 'A' <= str [ i ] && str [ i ] <= 'Z' ) index = str [ i ] - 'A';\n    else if ( 'a' <= str [ i ] && str [ i ] <= 'z' ) index = str [ i ] - 'a';\n    mark [ index ] = true;\n  }\n  for ( int i = 0;\n  i <= 25;\n  i ++ ) if ( mark [ i ] == false ) return ( false );\n  return ( true );\n}\n", "PRINT_SHORTEST_COMMON_SUPERSEQUENCE": "string printShortestSuperSeq ( string X, string Y ) {\n  int m = X . length ( );\n  int n = Y . length ( );\n  int dp [ m + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= m;\n  i ++ ) {\n    for ( int j = 0;\n    j <= n;\n    j ++ ) {\n      if ( i == 0 ) dp [ i ] [ j ] = j;\n      else if ( j == 0 ) dp [ i ] [ j ] = i;\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) 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    }\n  }\n  int index = dp [ m ] [ n ];\n  string str;\n  int i = m, j = n;\n  while ( i > 0 && j > 0 ) {\n    if ( X [ i - 1 ] == Y [ j - 1 ] ) {\n      str . push_back ( X [ i - 1 ] );\n      i --, j --, index --;\n    }\n    else if ( dp [ i - 1 ] [ j ] > dp [ i ] [ j - 1 ] ) {\n      str . push_back ( Y [ j - 1 ] );\n      j --, index --;\n    }\n    else {\n      str . push_back ( X [ i - 1 ] );\n      i --, index --;\n    }\n  }\n  while ( i > 0 ) {\n    str . push_back ( X [ i - 1 ] );\n    i --, index --;\n  }\n  while ( j > 0 ) {\n    str . push_back ( Y [ j - 1 ] );\n    j --, index --;\n  }\n  reverse ( str . begin ( ), str . end ( ) );\n  return str;\n}\n", "FIND_PAIR_MAXIMUM_GCD_ARRAY_1": "int findMaxGCD ( int arr [ ], int n ) {\n  int high = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) high = max ( high, arr [ i ] );\n  int count [ high + 1 ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) count [ arr [ i ] ] ++;\n    int counter = 0;\n    for ( int i = high;\n    i >= 1;\n    i -- ) {\n      int j = i;\n      counter = 0;\n      while ( j <= high ) {\n        if ( count [ j ] >= 2 ) return j;\n        else if ( count [ j ] == 1 ) counter ++;\n        j += i;\n        if ( counter == 2 ) return i;\n      }\n    }\n  }\n  ", "PROGRAM_CALCULATE_AREA_OCTAGON": "double areaOctagon ( double side ) {\n  return ( float ) ( 2 * ( 1 + sqrt ( 2 ) ) * side * side );\n}\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY_1": "int findExtra ( int arr1 [ ], int arr2 [ ], int n ) {\n  int index = n;\n  int left = 0, right = n - 1;\n  while ( left <= right ) {\n    int mid = ( left + right ) / 2;\n    if ( arr2 [ mid ] == arr1 [ mid ] ) left = mid + 1;\n    else {\n      index = mid;\n      right = mid - 1;\n    }\n  }\n  return index;\n}\n", "NOBLE_INTEGERS_IN_AN_ARRAY_COUNT_OF_GREATER_ELEMENTS_IS_EQUAL_TO_VALUE_1": "int nobleInteger ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( arr [ i ] == arr [ i + 1 ] ) continue;\n    if ( arr [ i ] == n - i - 1 ) return arr [ i ];\n  }\n  if ( arr [ n - 1 ] == 0 ) return arr [ n - 1 ];\n  return - 1;\n}\n", "MAXIMUM_NUMBER_OF_SQUARES_THAT_CAN_BE_FIT_IN_A_RIGHT_ANGLE_ISOSCELES_TRIANGLE": "int maxSquare ( int b, int m ) {\n  return ( b / m - 1 ) * ( b / m ) / 2;\n}\n", "HOW_TO_COMPUTE_MOD_OF_A_BIG_NUMBER": "int mod ( string num, int a ) {\n  int res = 0;\n  for ( int i = 0;\n  i < num . length ( );\n  i ++ ) res = ( res * 10 + ( int ) num [ i ] - '0' ) % a;\n  return res;\n}\n", "LONGEST_COMMON_SUBSTRING_1": "int lcs ( int i, int j, int count ) {\n  if ( i == 0 || j == 0 ) return count;\n  if ( X [ i - 1 ] == Y [ j - 1 ] ) {\n    count = lcs ( i - 1, j - 1, count + 1 );\n  }\n  count = max ( count, max ( lcs ( i, j - 1, 0 ), lcs ( i - 1, j, 0 ) ) );\n  return count;\n}\n", "FIND_PATTERNS_101_GIVEN_STRING": "int patternCount ( string str ) {\n  char last = str [ 0 ];\n  int i = 1, counter = 0;\n  while ( i < str . size ( ) ) {\n    if ( str [ i ] == '0' && last == '1' ) {\n      while ( str [ i ] == '0' ) i ++;\n      if ( str [ i ] == '1' ) counter ++;\n    }\n    last = str [ i ];\n    i ++;\n  }\n  return counter;\n}\n", "LONGEST_INCREASING_ODD_EVEN_SUBSEQUENCE": "int longOddEvenIncSeq ( int arr [ ], int n ) {\n  int lioes [ n ];\n  int maxLen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) lioes [ i ] = 1;\n  for ( int i = 1;\n  i < n;\n  i ++ ) for ( int j = 0;\n  j < i;\n  j ++ ) if ( arr [ i ] > arr [ j ] && ( arr [ i ] + arr [ j ] ) % 2 != 0 && lioes [ i ] < lioes [ j ] + 1 ) lioes [ i ] = lioes [ j ] + 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( maxLen < lioes [ i ] ) maxLen = lioes [ i ];\n  return maxLen;\n}\n", "COUNT_NUMBER_OF_SUBSTRINGS_WITH_EXACTLY_K_DISTINCT_CHARACTERS": "int countkDist ( string str, int k ) {\n  int n = str . length ( );\n  int res = 0;\n  int cnt [ 26 ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int dist_count = 0;\n    memset ( cnt, 0, sizeof ( cnt ) );\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      if ( cnt [ str [ j ] - 'a' ] == 0 ) dist_count ++;\n      cnt [ str [ j ] - 'a' ] ++;\n      if ( dist_count == k ) res ++;\n      if ( dist_count > k ) break;\n    }\n  }\n  return res;\n}\n", "C_PROGRAM_FACTORIAL_NUMBER_1": "unsigned int factorial ( unsigned int n ) {\n  int res = 1, i;\n  for ( i = 2;\n  i <= n;\n  i ++ ) res *= i;\n  return res;\n}\n", "K_MAXIMUM_SUMS_NON_OVERLAPPING_CONTIGUOUS_SUB_ARRAYS": "void kmax ( int arr [ ], int k, int n ) {\n  for ( int c = 0;\n  c < k;\n  c ++ ) {\n    int max_so_far = numeric_limits < int > :: min ( );\n    int max_here = 0;\n    int start = 0, end = 0, s = 0;\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\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      }\n      if ( max_here < 0 ) {\n        max_here = 0;\n        s = i + 1;\n      }\n    }\n    cout << \"Maximum non-overlapping sub-array sum\" << ( c + 1 ) << \": \" << max_so_far << \", starting index: \" << start << \", ending index: \" << end << \".\" << endl;\n    for ( int l = start;\n    l <= end;\n    l ++ ) arr [ l ] = numeric_limits < int > :: min ( );\n  }\n  cout << endl;\n}\n", "DISTANCE_NEAREST_CELL_1_BINARY_MATRIX": "void printDistance ( int mat [ N ] [ M ] ) {\n  int ans [ N ] [ M ];\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < M;\n  j ++ ) ans [ i ] [ j ] = INT_MAX;\n  for ( int i = 0;\n  i < N;\n  i ++ ) for ( int j = 0;\n  j < M;\n  j ++ ) {\n    for ( int k = 0;\n    k < N;\n    k ++ ) for ( int l = 0;\n    l < M;\n    l ++ ) {\n      if ( mat [ k ] [ l ] == 1 ) ans [ i ] [ j ] = min ( ans [ i ] [ j ], abs ( i - k ) + abs ( j - l ) );\n    }\n  }\n  for ( int i = 0;\n  i < N;\n  i ++ ) {\n    for ( int j = 0;\n    j < M;\n    j ++ ) cout << ans [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "MINIMUM_NUMBER_OF_BRACKET_REVERSALS_NEEDED_TO_MAKE_AN_EXPRESSION_BALANCED": "int countMinReversals ( string expr ) {\n  int len = expr . length ( );\n  if ( len % 2 ) return - 1;\n  stack < char > s;\n  for ( int i = 0;\n  i < len;\n  i ++ ) {\n    if ( expr [ i ] == '}' && ! s . empty ( ) ) {\n      if ( s . top ( ) == '{' ) s . pop ( );\n      else s . push ( expr [ i ] );\n    }\n    else s . push ( expr [ i ] );\n  }\n  int red_len = s . size ( );\n  int n = 0;\n  while ( ! s . empty ( ) && s . top ( ) == '{' ) {\n    s . pop ( );\n    n ++;\n  }\n  return ( red_len / 2 + n % 2 );\n}\n", "FIRST_NEGATIVE_INTEGER_EVERY_WINDOW_SIZE_K_1": "void printFirstNegativeInteger ( int arr [ ], int n, int k ) {\n  deque < int > Di;\n  int i;\n  for ( i = 0;\n  i < k;\n  i ++ ) if ( arr [ i ] < 0 ) Di . push_back ( i );\n  for (;\n  i < n;\n  i ++ ) {\n    if ( ! Di . empty ( ) ) cout << arr [ Di . front ( ) ] << \" \";\n    else cout << \"0\" << \" \";\n    while ( ( ! Di . empty ( ) ) && Di . front ( ) < ( i - k + 1 ) ) Di . pop_front ( );\n    if ( arr [ i ] < 0 ) Di . push_back ( i );\n  }\n  if ( ! Di . empty ( ) ) cout << arr [ Di . front ( ) ] << \" \";\n  else cout << \"0\" << \" \";\n}\n", "MAGIC_SQUARE": "void generateSquare ( int n ) {\n  int magicSquare [ n ] [ n ];\n  memset ( magicSquare, 0, sizeof ( magicSquare ) );\n  int i = n / 2;\n  int j = n - 1;\n  for ( int num = 1;\n  num <= n * n;\n  ) {\n    if ( i == - 1 && j == n ) {\n      j = n - 2;\n      i = 0;\n    }\n    else {\n      if ( j == n ) j = 0;\n      if ( i < 0 ) i = n - 1;\n    }\n    if ( magicSquare [ i ] [ j ] ) {\n      j -= 2;\n      i ++;\n      continue;\n    }\n    else magicSquare [ i ] [ j ] = num ++;\n    j ++;\n    i --;\n  }\n  cout << \"The Magic Square for n=\" << n << \":\\nSum of \" \"each row or column \" << n * ( n * n + 1 ) / 2 << \":\\n\\n\";\n  for ( i = 0;\n  i < n;\n  i ++ ) {\n    for ( j = 0;\n    j < n;\n    j ++ ) cout << magicSquare [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "PROGRAM_BINOMIAL_COEFFICIENTS_TABLE": "int printbinomial ( int max ) {\n  for ( int m = 0;\n  m <= max;\n  m ++ ) {\n    printf ( \"%2d\", m );\n    int binom = 1;\n    for ( int x = 0;\n    x <= m;\n    x ++ ) {\n      if ( m != 0 && x != 0 ) binom = binom * ( m - x + 1 ) / x;\n      printf ( \"%4d\", binom );\n    }\n    printf ( \"\\n\" );\n  }\n}\n", "CHINESE_REMAINDER_THEOREM_SET_1_INTRODUCTION": "int findMinX ( int num [ ], int rem [ ], int k ) {\n  int x = 1;\n  while ( true ) {\n    int j;\n    for ( j = 0;\n    j < k;\n    j ++ ) if ( x % num [ j ] != rem [ j ] ) break;\n    if ( j == k ) return x;\n    x ++;\n  }\n  return x;\n}\n", "MINIMUM_NUMBER_POINTS_REMOVED_GET_REMAINING_POINTS_ONE_SIDE_AXIS": "int findmin ( Point p [ ], int n ) {\n  int a = 0, b = 0, c = 0, d = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( p [ i ] . x <= 0 ) a ++;\n    else if ( p [ i ] . x >= 0 ) b ++;\n    if ( p [ i ] . y >= 0 ) c ++;\n    else if ( p [ i ] . y <= 0 ) d ++;\n  }\n  return min ( {\n    a, b, c, d }\n    );\n  }\n  ", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE": "void translate ( char * str ) {\n  if ( str [ 0 ] == '' ) return;\n  for ( int i = 1;\n  str [ i ] != '';\n  i ++ ) {\n    if ( str [ i - 1 ] == 'A' && str [ i ] == 'B' ) {\n      str [ i - 1 ] = 'C';\n      for ( int j = i;\n      str [ j ] != '';\n      j ++ ) str [ j ] = str [ j + 1 ];\n    }\n  }\n  return;\n}\n", "PAIRS_OF_POSITIVE_NEGATIVE_VALUES_IN_AN_ARRAY": "void printPairs ( int arr [ ], int n ) {\n  vector < int > v;\n  for ( int i = 0;\n  i < n;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) if ( abs ( arr [ i ] ) == abs ( arr [ j ] ) ) v . push_back ( abs ( arr [ i ] ) );\n  if ( v . size ( ) == 0 ) return;\n  sort ( v . begin ( ), v . end ( ) );\n  for ( int i = 0;\n  i < v . size ( );\n  i ++ ) cout << - v [ i ] << \" \" << v [ i ];\n}\n", "NON_REPEATING_ELEMENT_1": "int firstNonRepeating ( int arr [ ], int n ) {\n  unordered_map < int, int > mp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mp [ arr [ i ] ] ++;\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( mp [ arr [ i ] ] == 1 ) return arr [ i ];\n  return - 1;\n}\n", "PRINT_FIBONACCI_SERIES_REVERSE_ORDER": "void reverseFibonacci ( int n ) {\n  int a [ n ];\n  a [ 0 ] = 0;\n  a [ 1 ] = 1;\n  for ( int i = 2;\n  i < n;\n  i ++ ) {\n    a [ i ] = a [ i - 2 ] + a [ i - 1 ];\n  }\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    cout << a [ i ] << \" \";\n  }\n}\n", "FIND_MINIMUM_DIFFERENCE_PAIR_1": "int findMinDiff ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int diff = INT_MAX;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) if ( arr [ i + 1 ] - arr [ i ] < diff ) diff = arr [ i + 1 ] - arr [ i ];\n  return diff;\n}\n", "MINIMUM_NUMBER_PLATFORMS_REQUIRED_RAILWAYBUS_STATION": "int findPlatform ( int arr [ ], int dep [ ], int n ) {\n  sort ( arr, arr + n );\n  sort ( dep, dep + n );\n  int plat_needed = 1, result = 1;\n  int i = 1, j = 0;\n  while ( i < n && j < n ) {\n    if ( arr [ i ] <= dep [ j ] ) {\n      plat_needed ++;\n      i ++;\n      if ( plat_needed > result ) result = plat_needed;\n    }\n    else {\n      plat_needed --;\n      j ++;\n    }\n  }\n  return result;\n}\n", "MULTIPLICATIVE_INVERSE_UNDER_MODULO_M_1": "int modInverse ( int a, int m ) {\n  int m0 = m;\n  int y = 0, x = 1;\n  if ( m == 1 ) return 0;\n  while ( a > 1 ) {\n    int q = a / m;\n    int t = m;\n    m = a % m, a = t;\n    t = y;\n    y = x - q * y;\n    x = t;\n  }\n  if ( x < 0 ) x += m0;\n  return x;\n}\n", "NUMBER_N_DIGIT_STEPPING_NUMBERS": "long long answer ( int n ) {\n  int dp [ n + 1 ] [ 10 ];\n  if ( n == 1 ) return 10;\n  for ( int j = 0;\n  j <= 9;\n  j ++ ) dp [ 1 ] [ j ] = 1;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= 9;\n    j ++ ) {\n      if ( j == 0 ) dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ];\n      else if ( j == 9 ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ];\n      else dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ];\n    }\n  }\n  long long sum = 0;\n  for ( int j = 1;\n  j <= 9;\n  j ++ ) sum += dp [ n ] [ j ];\n  return sum;\n}\n", "CREATE_A_MATRIX_WITH_ALTERNATING_RECTANGLES_OF_0_AND_X": "void fill0X ( int m, int n ) {\n  int i, k = 0, l = 0;\n  int r = m, c = n;\n  char a [ m ] [ n ];\n  char x = 'X';\n  while ( k < m && l < n ) {\n    for ( i = l;\n    i < n;\n    ++ i ) a [ k ] [ i ] = x;\n    k ++;\n    for ( i = k;\n    i < m;\n    ++ i ) a [ i ] [ n - 1 ] = x;\n    n --;\n    if ( k < m ) {\n      for ( i = n - 1;\n      i >= l;\n      -- i ) a [ m - 1 ] [ i ] = x;\n      m --;\n    }\n    if ( l < n ) {\n      for ( i = m - 1;\n      i >= k;\n      -- i ) a [ i ] [ l ] = x;\n      l ++;\n    }\n    x = ( x == '0' ) ? 'X' : '0';\n  }\n  for ( i = 0;\n  i < r;\n  i ++ ) {\n    for ( int j = 0;\n    j < c;\n    j ++ ) printf ( \"%c \", a [ i ] [ j ] );\n    printf ( \"\\n\" );\n  }\n}\n", "FIND_SUM_UNIQUE_SUB_ARRAY_SUM_GIVEN_ARRAY": "long long int findSubarraySum ( int arr [ ], int n ) {\n  int res = 0;\n  unordered_map < int, int > m;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int sum = 0;\n    for ( int j = i;\n    j < n;\n    j ++ ) {\n      sum += arr [ j ];\n      m [ sum ] ++;\n    }\n  }\n  for ( auto x : m ) if ( x . second == 1 ) res += x . first;\n  return res;\n}\n", "REVERSE_A_STRING_USING_RECURSION": "void reverse ( string str ) {\n  if ( str . size ( ) == 0 ) {\n    return;\n  }\n  reverse ( str . substr ( 1 ) );\n  cout << str [ 0 ];\n}\n", "PRINTING_ITEMS_01_KNAPSACK": "void printknapSack ( int W, int wt [ ], int val [ ], int n ) {\n  int i, w;\n  int K [ n + 1 ] [ W + 1 ];\n  for ( i = 0;\n  i <= n;\n  i ++ ) {\n    for ( w = 0;\n    w <= W;\n    w ++ ) {\n      if ( i == 0 || w == 0 ) K [ i ] [ w ] = 0;\n      else if ( wt [ i - 1 ] <= w ) K [ i ] [ w ] = max ( val [ i - 1 ] + K [ i - 1 ] [ w - wt [ i - 1 ] ], K [ i - 1 ] [ w ] );\n      else K [ i ] [ w ] = K [ i - 1 ] [ w ];\n    }\n  }\n  int res = K [ n ] [ W ];\n  printf ( \"%d\\n\", res );\n  w = W;\n  for ( i = n;\n  i > 0 && res > 0;\n  i -- ) {\n    if ( res == K [ i - 1 ] [ w ] ) continue;\n    else {\n      printf ( \"%d \", wt [ i - 1 ] );\n      res = res - val [ i - 1 ];\n      w = w - wt [ i - 1 ];\n    }\n  }\n}\n", "FIND_LARGEST_PRIME_FACTOR_NUMBER": "long long maxPrimeFactors ( long long n ) {\n  long long maxPrime = - 1;\n  while ( n % 2 == 0 ) {\n    maxPrime = 2;\n    n >>= 1;\n  }\n  for ( int i = 3;\n  i <= sqrt ( n );\n  i += 2 ) {\n    while ( n % i == 0 ) {\n      maxPrime = i;\n      n = n / i;\n    }\n  }\n  if ( n > 2 ) maxPrime = n;\n  return maxPrime;\n}\n", "FIND_THE_ELEMENT_BEFORE_WHICH_ALL_THE_ELEMENTS_ARE_SMALLER_THAN_IT_AND_AFTER_WHICH_ALL_ARE_GREATER_THAN_IT": "int findElement ( int arr [ ], int n ) {\n  int leftMax [ n ];\n  leftMax [ 0 ] = INT_MIN;\n  for ( int i = 1;\n  i < n;\n  i ++ ) leftMax [ i ] = max ( leftMax [ i - 1 ], arr [ i - 1 ] );\n  int rightMin = INT_MAX;\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    if ( leftMax [ i ] < arr [ i ] && rightMin > arr [ i ] ) return i;\n    rightMin = min ( rightMin, arr [ i ] );\n  }\n  return - 1;\n}\n", "COMMON_CHARACTERS_N_STRINGS": "void commonCharacters ( string str [ ], int n ) {\n  bool prim [ MAX_CHAR ];\n  memset ( prim, true, sizeof ( prim ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    bool sec [ MAX_CHAR ] = {\n      false };\n      for ( int j = 0;\n      str [ i ] [ j ];\n      j ++ ) {\n        if ( prim [ str [ i ] [ j ] - 'a' ] ) sec [ str [ i ] [ j ] - 'a' ] = true;\n      }\n      memcpy ( prim, sec, MAX_CHAR );\n    }\n    for ( int i = 0;\n    i < 26;\n    i ++ ) if ( prim [ i ] ) printf ( \"%c \", i + 'a' );\n  }\n  ", "MINIMAL_MOVES_FORM_STRING_ADDING_CHARACTERS_APPENDING_STRING": "int minimalSteps ( string s, int n ) {\n  int dp [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) dp [ i ] = INT_MAX;\n  string s1 = \"\", s2 = \"\";\n  dp [ 0 ] = 1;\n  s1 += s [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    s1 += s [ i ];\n    s2 = s . substr ( i + 1, i + 1 );\n    dp [ i ] = min ( dp [ i ], dp [ i - 1 ] + 1 );\n    if ( s1 == s2 ) dp [ i * 2 + 1 ] = min ( dp [ i ] + 1, dp [ i * 2 + 1 ] );\n  }\n  return dp [ n - 1 ];\n}\n", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS_1": "int findSum ( int n ) {\n  int sum = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) sum += i * ( n - i );\n  return 2 * sum;\n}\n", "FIND_FREQUENCY_EVEN_ODD_NUMBERS_MATRIX": "void freq ( int ar [ ] [ MAX ], int m, int n ) {\n  int even = 0, odd = 0;\n  for ( int i = 0;\n  i < m;\n  ++ i ) {\n    for ( int j = 0;\n    j < n;\n    ++ j ) {\n      if ( ( ar [ i ] [ j ] % 2 ) == 0 ) ++ even;\n      else ++ odd;\n    }\n  }\n  printf ( \" Frequency of odd number = %d \\n\", odd );\n  printf ( \" Frequency of even number = %d \\n\", even );\n}\n", "COUNT_SUBARRAYS_WITH_SAME_EVEN_AND_ODD_ELEMENTS": "int countSubarrays ( int arr [ ], int n ) {\n  int difference = 0;\n  int ans = 0;\n  int hash_positive [ n + 1 ], hash_negative [ n + 1 ];\n  fill_n ( hash_positive, n + 1, 0 );\n  fill_n ( hash_negative, n + 1, 0 );\n  hash_positive [ 0 ] = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] & 1 == 1 ) difference ++;\n    else difference --;\n    if ( difference < 0 ) {\n      ans += hash_negative [ - difference ];\n      hash_negative [ - difference ] ++;\n    }\n    else {\n      ans += hash_positive [ difference ];\n      hash_positive [ difference ] ++;\n    }\n  }\n  return ans;\n}\n", "PASCAL_TRIANGLE_1": "void printPascal ( int n ) {\n  for ( int line = 1;\n  line <= n;\n  line ++ ) {\n    int C = 1;\n    for ( int i = 1;\n    i <= line;\n    i ++ ) {\n      cout << C << \" \";\n      C = C * ( line - i ) / i;\n    }\n    cout << \"\\n\";\n  }\n}\n", "NUMBER_OF_TRIANGLES_IN_A_PLANE_IF_NO_MORE_THAN_TWO_POINTS_ARE_COLLINEAR": "int countNumberOfTriangles ( int n ) {\n  return n * ( n - 1 ) * ( n - 2 ) / 6;\n}\n", "MERGE_TWO_SORTED_ARRAYS_O1_EXTRA_SPACE": "void merge ( int ar1 [ ], int ar2 [ ], int m, int n ) {\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    int j, last = ar1 [ m - 1 ];\n    for ( j = m - 2;\n    j >= 0 && ar1 [ j ] > ar2 [ i ];\n    j -- ) ar1 [ j + 1 ] = ar1 [ j ];\n    if ( j != m - 2 || last > ar2 [ i ] ) {\n      ar1 [ j + 1 ] = ar2 [ i ];\n      ar2 [ i ] = last;\n    }\n  }\n}\n", "NEWMAN_SHANKS_WILLIAMS_PRIME": "int nswp ( int n ) {\n  if ( n == 0 || n == 1 ) return 1;\n  return 2 * nswp ( n - 1 ) + nswp ( n - 2 );\n}\n", "SMALLEST_OF_THREE_INTEGERS_WITHOUT_COMPARISON_OPERATORS": "int smallest ( int x, int y, int z ) {\n  int c = 0;\n  while ( x && y && z ) {\n    x --;\n    y --;\n    z --;\n    c ++;\n  }\n  return c;\n}\n", "COUNT_PAIRS_TWO_SORTED_ARRAYS_WHOSE_SUM_EQUAL_GIVEN_VALUE_X": "int countPairs ( int arr1 [ ], int arr2 [ ], int m, int n, int x ) {\n  int count = 0;\n  for ( int i = 0;\n  i < m;\n  i ++ ) for ( int j = 0;\n  j < n;\n  j ++ ) if ( ( arr1 [ i ] + arr2 [ j ] ) == x ) count ++;\n  return count;\n}\n", "SORT_ARRAY_APPLYING_GIVEN_EQUATION": "void sortArray ( int arr [ ], int n, int A, int B, int C ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = A * arr [ i ] * arr [ i ] + B * arr [ i ] + C;\n  int index, maximum = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( maximum < arr [ i ] ) {\n      index = i;\n      maximum = arr [ i ];\n    }\n  }\n  int i = 0, j = n - 1;\n  int new_arr [ n ], k = 0;\n  while ( i < index && j > index ) {\n    if ( arr [ i ] < arr [ j ] ) new_arr [ k ++ ] = arr [ i ++ ];\n    else new_arr [ k ++ ] = arr [ j -- ];\n  }\n  while ( i < index ) new_arr [ k ++ ] = arr [ i ++ ];\n  while ( j > index ) new_arr [ k ++ ] = arr [ j -- ];\n  new_arr [ n - 1 ] = maximum;\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = new_arr [ i ];\n}\n", "PROGRAM_TO_FIND_THE_AREA_OF_PENTAGON": "float findArea ( float a ) {\n  float area;\n  area = ( sqrt ( 5 * ( 5 + 2 * ( sqrt ( 5 ) ) ) ) * a * a ) / 4;\n  return area;\n}\n", "MAXIMIZE_SUM_CONSECUTIVE_DIFFERENCES_CIRCULAR_ARRAY": "int maxSum ( int arr [ ], int n ) {\n  int sum = 0;\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n / 2;\n  i ++ ) {\n    sum -= ( 2 * arr [ i ] );\n    sum += ( 2 * arr [ n - i - 1 ] );\n  }\n  return sum;\n}\n", "COUNT_ARRAYS_CONSECUTIVE_ELEMENT_DIFFERENT_VALUES": "int countarray ( int n, int k, int x ) {\n  int dp [ MAXN ] = {\n    0 };\n    dp [ 0 ] = 0;\n    dp [ 1 ] = 1;\n    for ( int i = 2;\n    i < n;\n    i ++ ) dp [ i ] = ( k - 2 ) * dp [ i - 1 ] + ( k - 1 ) * dp [ i - 2 ];\n    return ( x == 1 ? ( k - 1 ) * dp [ n - 2 ] : dp [ n - 1 ] );\n  }\n  ", "SUM_SERIES_12_32_52_2N_12": "int sumOfSeries ( int n ) {\n  int sum = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) sum = sum + ( 2 * i - 1 ) * ( 2 * i - 1 );\n  return sum;\n}\n", "FIND_THE_NEAREST_SMALLER_NUMBERS_ON_LEFT_SIDE_IN_AN_ARRAY_1": "void printPrevSmaller ( int arr [ ], int n ) {\n  stack < int > S;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( ! S . empty ( ) && S . top ( ) >= arr [ i ] ) S . pop ( );\n    if ( S . empty ( ) ) cout << \"_, \";\n    else cout << S . top ( ) << \", \";\n    S . push ( arr [ i ] );\n  }\n}\n", "FIND_NUMBER_OF_TRIANGLES_POSSIBLE_1": "void CountTriangles ( vector < int > A ) {\n  int n = A . size ( );\n  sort ( A . begin ( ), A . end ( ) );\n  int count = 0;\n  for ( int i = n - 1;\n  i >= 1;\n  i -- ) {\n    int l = 0, r = i - 1;\n    while ( l < r ) {\n      if ( A [ l ] + A [ r ] > A [ i ] ) {\n        count += r - l;\n        r --;\n      }\n      else l ++;\n    }\n  }\n  cout << \"No of possible solutions: \" << count;\n}\n", "MAXIMUM_GAMES_PLAYED_WINNER": "int maxGameByWinner ( int N ) {\n  int dp [ N ];\n  dp [ 0 ] = 1;\n  dp [ 1 ] = 2;\n  int i = 2;\n  do {\n    dp [ i ] = dp [ i - 1 ] + dp [ i - 2 ];\n  }\n  while ( dp [ i ++ ] <= N );\n  return ( i - 2 );\n}\n", "NUMBER_OF_SUBSTRINGS_WITH_ODD_DECIMAL_VALUE_IN_A_BINARY_STRING": "int countSubstr ( string s ) {\n  int n = s . length ( );\n  int auxArr [ n ] = {\n    0 };\n    if ( s [ 0 ] == '1' ) auxArr [ 0 ] = 1;\n    for ( int i = 1;\n    i < n;\n    i ++ ) {\n      if ( s [ i ] == '1' ) auxArr [ i ] = auxArr [ i - 1 ] + 1;\n      else auxArr [ i ] = auxArr [ i - 1 ];\n    }\n    int count = 0;\n    for ( int i = n - 1;\n    i >= 0;\n    i -- ) if ( s [ i ] == '1' ) count += auxArr [ i ];\n    return count;\n  }\n  ", "ELEMENTS_TO_BE_ADDED_SO_THAT_ALL_ELEMENTS_OF_A_RANGE_ARE_PRESENT_IN_ARRAY_1": "int countNum ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  int count = 0, maxm = INT_MIN, minm = INT_MAX;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    s . insert ( arr [ i ] );\n    if ( arr [ i ] < minm ) minm = arr [ i ];\n    if ( arr [ i ] > maxm ) maxm = arr [ i ];\n  }\n  for ( int i = minm;\n  i <= maxm;\n  i ++ ) if ( s . find ( arr [ i ] ) == s . end ( ) ) count ++;\n  return count;\n}\n", "WRITE_A_C_PROGRAM_TO_CALCULATE_POWXN_1": "float power ( float x, int y ) {\n  float temp;\n  if ( y == 0 ) return 1;\n  temp = power ( x, y / 2 );\n  if ( y % 2 == 0 ) return temp * temp;\n  else {\n    if ( y > 0 ) return x * temp * temp;\n    else return ( temp * temp ) / x;\n  }\n}\n", "N_TH_TERM_SERIES_2_12_36_80_150": "int nthTerm ( int n ) {\n  return ( n * n ) + ( n * n * n );\n}\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES": "int getOddOccurrence ( int arr [ ], int arr_size ) {\n  for ( int i = 0;\n  i < arr_size;\n  i ++ ) {\n    int count = 0;\n    for ( int j = 0;\n    j < arr_size;\n    j ++ ) {\n      if ( arr [ i ] == arr [ j ] ) count ++;\n    }\n    if ( count % 2 != 0 ) return arr [ i ];\n  }\n  return - 1;\n}\n", "EFFICIENT_METHOD_2S_COMPLEMENT_BINARY_STRING": "string findTwoscomplement ( string str ) {\n  int n = str . length ( );\n  int i;\n  for ( i = n - 1;\n  i >= 0;\n  i -- ) if ( str [ i ] == '1' ) break;\n  if ( i == - 1 ) return '1' + str;\n  for ( int k = i - 1;\n  k >= 0;\n  k -- ) {\n    if ( str [ k ] == '1' ) str [ k ] = '0';\n    else str [ k ] = '1';\n  }\n  return str;\n  ;\n}\n", "PAPER_CUT_MINIMUM_NUMBER_SQUARES_SET_2": "int minimumSquare ( int m, int n ) {\n  int vertical_min = INT_MAX;\n  int horizontal_min = INT_MAX;\n  if ( m == n ) return 1;\n  if ( dp [ m ] [ n ] ) return dp [ m ] [ n ];\n  for ( int i = 1;\n  i <= m / 2;\n  i ++ ) {\n    horizontal_min = min ( minimumSquare ( i, n ) + minimumSquare ( m - i, n ), horizontal_min );\n  }\n  for ( int j = 1;\n  j <= n / 2;\n  j ++ ) {\n    vertical_min = min ( minimumSquare ( m, j ) + minimumSquare ( m, n - j ), vertical_min );\n  }\n  dp [ m ] [ n ] = min ( vertical_min, horizontal_min );\n  return dp [ m ] [ n ];\n}\n", "MINIMIZE_ABSOLUTE_DIFFERENCE_SUM_TWO_SUBSETS": "void subsetDifference ( int n ) {\n  int s = n * ( n + 1 ) / 2;\n  if ( n % 4 == 0 ) {\n    cout << \"First subset sum = \" << s / 2;\n    cout << \"\\nSecond subset sum = \" << s / 2;\n    cout << \"\\nDifference = \" << 0;\n  }\n  else {\n    if ( n % 4 == 1 || n % 4 == 2 ) {\n      cout << \"First subset sum = \" << s / 2;\n      cout << \"\\nSecond subset sum = \" << s / 2 + 1;\n      cout << \"\\nDifference = \" << 1;\n    }\n    else {\n      cout << \"First subset sum = \" << s / 2;\n      cout << \"\\nSecond subset sum = \" << s / 2;\n      cout << \"\\nDifference = \" << 0;\n    }\n  }\n}\n", "PROGRAM_CALCULATE_VOLUME_ELLIPSOID": "float volumeOfEllipsoid ( float r1, float r2, float r3 ) {\n  float pi = 3.14;\n  return 1.33 * pi * r1 * r2 * r3;\n}\n", "DYNAMIC_PROGRAMMING_SET_13_CUTTING_A_ROD": "int cutRod ( int price [ ], int n ) {\n  int val [ n + 1 ];\n  val [ 0 ] = 0;\n  int i, j;\n  for ( i = 1;\n  i <= n;\n  i ++ ) {\n    int max_val = INT_MIN;\n    for ( j = 0;\n    j < i;\n    j ++ ) max_val = max ( max_val, price [ j ] + val [ i - j - 1 ] );\n    val [ i ] = max_val;\n  }\n  return val [ n ];\n}\n", "RECURSIVE_INSERTION_SORT": "void insertionSortRecursive ( int arr [ ], int n ) {\n  if ( n <= 1 ) return;\n  insertionSortRecursive ( arr, n - 1 );\n  int last = arr [ n - 1 ];\n  int j = n - 2;\n  while ( j >= 0 && arr [ j ] > last ) {\n    arr [ j + 1 ] = arr [ j ];\n    j --;\n  }\n  arr [ j + 1 ] = last;\n}\n", "FIND_EXPRESSION_DUPLICATE_PARENTHESIS_NOT": "bool findDuplicateparenthesis ( string str ) {\n  stack < char > Stack;\n  for ( char ch : str ) {\n    if ( ch == ')' ) {\n      char top = Stack . top ( );\n      Stack . pop ( );\n      int elementsInside = 0;\n      while ( top != '(' ) {\n        elementsInside ++;\n        top = Stack . top ( );\n        Stack . pop ( );\n      }\n      if ( elementsInside < 1 ) {\n        return 1;\n      }\n    }\n    else Stack . push ( ch );\n  }\n  return false;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1": "int findRepeating ( int arr [ ], int n ) {\n  return accumulate ( arr, arr + n, 0 ) - ( ( n - 1 ) * n / 2 );\n}\n", "CHECK_ARRAY_CONTAINS_CONTIGUOUS_INTEGERS_DUPLICATES_ALLOWED": "bool areElementsContiguous ( int arr [ ], int n ) {\n  int max = * max_element ( arr, arr + n );\n  int min = * min_element ( arr, arr + n );\n  int m = max - min + 1;\n  if ( m > n ) return false;\n  bool visited [ m ];\n  memset ( visited, false, sizeof ( visited ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) visited [ arr [ i ] - min ] = true;\n  for ( int i = 0;\n  i < m;\n  i ++ ) if ( visited [ i ] == false ) return false;\n  return true;\n}\n", "LENGTH_LONGEST_BALANCED_SUBSEQUENCE_1": "int maxLength ( char s [ ], int n ) {\n  int invalidOpenBraces = 0;\n  int invalidCloseBraces = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s [ i ] == '(' ) {\n      invalidOpenBraces ++;\n    }\n    else {\n      if ( invalidOpenBraces == 0 ) {\n        invalidCloseBraces ++;\n      }\n      else {\n        invalidOpenBraces --;\n      }\n    }\n  }\n  return ( n - ( invalidOpenBraces + invalidCloseBraces ) );\n}\n", "SUM_SERIES_ALTERNATE_SIGNED_SQUARES_AP_1": "int seiresSum ( int n, int a [ ] ) {\n  return n * ( a [ 0 ] * a [ 0 ] - a [ 2 * n - 1 ] * a [ 2 * n - 1 ] ) / ( 2 * n - 1 );\n}\n", "EQUILIBRIUM_INDEX_OF_AN_ARRAY": "int equilibrium ( int arr [ ], int n ) {\n  int i, j;\n  int leftsum, rightsum;\n  for ( i = 0;\n  i < n;\n  ++ i ) {\n    leftsum = 0;\n    for ( j = 0;\n    j < i;\n    j ++ ) leftsum += arr [ j ];\n    rightsum = 0;\n    for ( j = i + 1;\n    j < n;\n    j ++ ) rightsum += arr [ j ];\n    if ( leftsum == rightsum ) return i;\n  }\n  return - 1;\n}\n", "COUNT_WAYS_REACH_NTH_STAIR_USING_STEP_1_2_3": "public : int findStep ( int n ) {\n  if ( n == 1 || n == 0 ) return 1;\n  else if ( n == 2 ) return 2;\n  else return findStep ( n - 3 ) + findStep ( n - 2 ) + findStep ( n - 1 );\n}\n", "FIND_MINIMUM_NUMBER_OF_COINS_THAT_MAKE_A_CHANGE": "int minCoins ( int coins [ ], int m, int V ) {\n  if ( V == 0 ) return 0;\n  int res = INT_MAX;\n  for ( int i = 0;\n  i < m;\n  i ++ ) {\n    if ( coins [ i ] <= V ) {\n      int sub_res = minCoins ( coins, m, V - coins [ i ] );\n      if ( sub_res != INT_MAX && sub_res + 1 < res ) res = sub_res + 1;\n    }\n  }\n  return res;\n}\n", "BELL_NUMBERS_NUMBER_OF_WAYS_TO_PARTITION_A_SET": "int bellNumber ( int n ) {\n  int bell [ n + 1 ] [ n + 1 ];\n  bell [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    bell [ i ] [ 0 ] = bell [ i - 1 ] [ i - 1 ];\n    for ( int j = 1;\n    j <= i;\n    j ++ ) bell [ i ] [ j ] = bell [ i - 1 ] [ j - 1 ] + bell [ i ] [ j - 1 ];\n  }\n  return bell [ n ] [ 0 ];\n}\n", "FIND_ELEMENT_GIVEN_INDEX_NUMBER_ROTATIONS": "int findElement ( int arr [ ], int ranges [ ] [ 2 ], int rotations, int index ) {\n  for ( int i = rotations - 1;\n  i >= 0;\n  i -- ) {\n    int left = ranges [ i ] [ 0 ];\n    int right = ranges [ i ] [ 1 ];\n    if ( left <= index && right >= index ) {\n      if ( index == left ) index = right;\n      else index --;\n    }\n  }\n  return arr [ index ];\n}\n", "DYCK_PATH": "int countDyckPaths ( unsigned int n ) {\n  int res = 1;\n  for ( int i = 0;\n  i < n;\n  ++ i ) {\n    res *= ( 2 * n - i );\n    res /= ( i + 1 );\n  }\n  return res / ( n + 1 );\n}\n", "COUNTING_PAIRS_PERSON_CAN_FORM_PAIR_ONE": "int numberOfWays ( int x ) {\n  if ( x == 0 || x == 1 ) return 1;\n  else return numberOfWays ( x - 1 ) + ( x - 1 ) * numberOfWays ( x - 2 );\n}\n", "PROGRAM_DISPLAY_ASTROLOGICAL_SIGN_ZODIAC_SIGN_GIVEN_DATE_BIRTH": "void zodiac_sign ( int day, string month ) {\n  string astro_sign = \"\";\n  if ( month == \"december\" ) {\n    if ( day < 22 ) astro_sign = \"Sagittarius\";\n    else astro_sign = \"capricorn\";\n  }\n  else if ( month == \"january\" ) {\n    if ( day < 20 ) astro_sign = \"Capricorn\";\n    else astro_sign = \"aquarius\";\n  }\n  else if ( month == \"february\" ) {\n    if ( day < 19 ) astro_sign = \"Aquarius\";\n    else astro_sign = \"pisces\";\n  }\n  else if ( month == \"march\" ) {\n    if ( day < 21 ) astro_sign = \"Pisces\";\n    else astro_sign = \"aries\";\n  }\n  else if ( month == \"april\" ) {\n    if ( day < 20 ) astro_sign = \"Aries\";\n    else astro_sign = \"taurus\";\n  }\n  else if ( month == \"may\" ) {\n    if ( day < 21 ) astro_sign = \"Taurus\";\n    else astro_sign = \"gemini\";\n  }\n  else if ( month == \"june\" ) {\n    if ( day < 21 ) astro_sign = \"Gemini\";\n    else astro_sign = \"cancer\";\n  }\n  else if ( month == \"july\" ) {\n    if ( day < 23 ) astro_sign = \"Cancer\";\n    else astro_sign = \"leo\";\n  }\n  else if ( month == \"august\" ) {\n    if ( day < 23 ) astro_sign = \"Leo\";\n    else astro_sign = \"virgo\";\n  }\n  else if ( month == \"september\" ) {\n    if ( day < 23 ) astro_sign = \"Virgo\";\n    else astro_sign = \"libra\";\n  }\n  else if ( month == \"october\" ) {\n    if ( day < 23 ) astro_sign = \"Libra\";\n    else astro_sign = \"scorpio\";\n  }\n  else if ( month == \"november\" ) {\n    if ( day < 22 ) astro_sign = \"scorpio\";\n    else astro_sign = \"sagittarius\";\n  }\n  cout << astro_sign;\n}\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE_2": "void recursiveReverse ( string & str, int i = 0 ) {\n  int n = str . length ( );\n  if ( i == n / 2 ) return;\n  swap ( str [ i ], str [ n - i - 1 ] );\n  recursiveReverse ( str, i + 1 );\n}\n", "K_TH_DIGIT_RAISED_POWER_B": "int kthdigit ( int a, int b, int k ) {\n  int p = pow ( a, b );\n  int count = 0;\n  while ( p > 0 && count < k ) {\n    int rem = p % 10;\n    count ++;\n    if ( count == k ) return rem;\n    p = p / 10;\n  }\n  return 0;\n}\n", "SMALLEST_DIFFERENCE_PAIR_VALUES_TWO_UNSORTED_ARRAYS": "int findSmallestDifference ( int A [ ], int B [ ], int m, int n ) {\n  sort ( A, A + m );\n  sort ( B, B + n );\n  int a = 0, b = 0;\n  int result = INT_MAX;\n  while ( a < m && b < n ) {\n    if ( abs ( A [ a ] - B [ b ] ) < result ) result = abs ( A [ a ] - B [ b ] );\n    if ( A [ a ] < B [ b ] ) a ++;\n    else b ++;\n  }\n  return result;\n}\n", "MAXIMUM_AREA_RECTANGLE_PICKING_FOUR_SIDES_ARRAY_1": "int findArea ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  int first = 0, second = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s . find ( arr [ i ] ) == s . end ( ) ) {\n      s . insert ( arr [ i ] );\n      continue;\n    }\n    if ( arr [ i ] > first ) {\n      second = first;\n      first = arr [ i ];\n    }\n    else if ( arr [ i ] > second ) second = arr [ i ];\n  }\n  return ( first * second );\n}\n", "PROGRAM_PAGE_REPLACEMENT_ALGORITHMS_SET_2_FIFO": "int pageFaults ( int pages [ ], int n, int capacity ) {\n  unordered_set < int > s;\n  queue < int > indexes;\n  int page_faults = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( s . size ( ) < capacity ) {\n      if ( s . find ( pages [ i ] ) == s . end ( ) ) {\n        s . insert ( pages [ i ] );\n        page_faults ++;\n        indexes . push ( pages [ i ] );\n      }\n    }\n    else {\n      if ( s . find ( pages [ i ] ) == s . end ( ) ) {\n        int val = indexes . front ( );\n        indexes . pop ( );\n        s . erase ( val );\n        s . insert ( pages [ i ] );\n        indexes . push ( pages [ i ] );\n        page_faults ++;\n      }\n    }\n  }\n  return page_faults;\n}\n", "FIND_LARGEST_D_IN_ARRAY_SUCH_THAT_A_B_C_D_1": "int findFourElements ( int arr [ ], int n ) {\n  unordered_map < int, pair < int, int > > mp;\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) for ( int j = i + 1;\n  j < n;\n  j ++ ) mp [ arr [ i ] + arr [ j ] ] = {\n    i, j };\n    int d = INT_MIN;\n    for ( int i = 0;\n    i < n - 1;\n    i ++ ) {\n      for ( int j = i + 1;\n      j < n;\n      j ++ ) {\n        int abs_diff = abs ( arr [ i ] - arr [ j ] );\n        if ( mp . find ( abs_diff ) != mp . end ( ) ) {\n          pair < int, int > p = mp [ abs_diff ];\n          if ( p . first != i && p . first != j && p . second != i && p . second != j ) d = max ( d, max ( arr [ i ], arr [ j ] ) );\n        }\n      }\n    }\n    return d;\n  }\n  ", "PRINT_GIVEN_MATRIX_REVERSE_SPIRAL_FORM": "void ReversespiralPrint ( int m, int n, int a [ R ] [ C ] ) {\n  long int b [ 100 ];\n  int i, k = 0, l = 0;\n  int z = 0;\n  int size = m * n;\n  while ( k < m && l < n ) {\n    int val;\n    for ( i = l;\n    i < n;\n    ++ i ) {\n      val = a [ k ] [ i ];\n      b [ z ] = val;\n      ++ z;\n    }\n    k ++;\n    for ( i = k;\n    i < m;\n    ++ i ) {\n      val = a [ i ] [ n - 1 ];\n      b [ z ] = val;\n      ++ z;\n    }\n    n --;\n    if ( k < m ) {\n      for ( i = n - 1;\n      i >= l;\n      -- i ) {\n        val = a [ m - 1 ] [ i ];\n        b [ z ] = val;\n        ++ z;\n      }\n      m --;\n    }\n    if ( l < n ) {\n      for ( i = m - 1;\n      i >= k;\n      -- i ) {\n        val = a [ i ] [ l ];\n        b [ z ] = val;\n        ++ z;\n      }\n      l ++;\n    }\n  }\n  for ( int i = size - 1;\n  i >= 0;\n  -- i ) {\n    cout << b [ i ] << \" \";\n  }\n}\n", "NUMBER_N_DIGITS_NON_DECREASING_INTEGERS": "int nonDecNums ( int n ) {\n  int a [ n + 1 ] [ 10 ];\n  for ( int i = 0;\n  i <= 9;\n  i ++ ) a [ 0 ] [ i ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) a [ i ] [ 9 ] = 1;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) for ( int j = 8;\n  j >= 0;\n  j -- ) a [ i ] [ j ] = a [ i - 1 ] [ j ] + a [ i ] [ j + 1 ];\n  return a [ n ] [ 0 ];\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF": "int findLength ( char * str ) {\n  int n = strlen ( str );\n  int maxlen = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    for ( int j = i + 1;\n    j < n;\n    j += 2 ) {\n      int length = j - i + 1;\n      int leftsum = 0, rightsum = 0;\n      for ( int k = 0;\n      k < length / 2;\n      k ++ ) {\n        leftsum += ( str [ i + k ] - '0' );\n        rightsum += ( str [ i + k + length / 2 ] - '0' );\n      }\n      if ( leftsum == rightsum && maxlen < length ) maxlen = length;\n    }\n  }\n  return maxlen;\n}\n", "PROGRAM_WORST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "void worstFit ( int blockSize [ ], int m, int processSize [ ], int n ) {\n  int allocation [ n ];\n  memset ( allocation, - 1, sizeof ( allocation ) );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int wstIdx = - 1;\n    for ( int j = 0;\n    j < m;\n    j ++ ) {\n      if ( blockSize [ j ] >= processSize [ i ] ) {\n        if ( wstIdx == - 1 ) wstIdx = j;\n        else if ( blockSize [ wstIdx ] < blockSize [ j ] ) wstIdx = j;\n      }\n    }\n    if ( wstIdx != - 1 ) {\n      allocation [ i ] = wstIdx;\n      blockSize [ wstIdx ] -= processSize [ i ];\n    }\n  }\n  cout << \"\\nProcess No.\\tProcess Size\\tBlock no.\\n\";\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    cout << \"   \" << i + 1 << \"\\t\\t\" << processSize [ i ] << \"\\t\\t\";\n    if ( allocation [ i ] != - 1 ) cout << allocation [ i ] + 1;\n    else cout << \"Not Allocated\";\n    cout << endl;\n  }\n}\n", "SUM_SUBSETS_SET_FORMED_FIRST_N_NATURAL_NUMBERS": "unsigned long long findSumSubsets ( int n ) {\n  return ( n * ( n + 1 ) / 2 ) * ( 1 << ( n - 1 ) );\n}\n", "ADD_TWO_NUMBERS_WITHOUT_USING_ARITHMETIC_OPERATORS": "int Add ( int x, int y ) {\n  while ( y != 0 ) {\n    int carry = x & y;\n    x = x ^ y;\n    y = carry << 1;\n  }\n  return x;\n}\n", "MAXIMUM_BINOMIAL_COEFFICIENT_TERM_VALUE": "int maxcoefficientvalue ( int n ) {\n  int C [ n + 1 ] [ n + 1 ];\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= min ( i, n );\n    j ++ ) {\n      if ( j == 0 || j == i ) C [ i ] [ j ] = 1;\n      else C [ i ] [ j ] = C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ];\n    }\n  }\n  int maxvalue = 0;\n  for ( int i = 0;\n  i <= n;\n  i ++ ) maxvalue = max ( maxvalue, C [ n ] [ i ] );\n  return maxvalue;\n}\n", "EULERIAN_PATH_UNDIRECTED_GRAPH": "void findpath ( int graph [ ] [ 5 ], int n ) {\n  vector < int > numofadj;\n  for ( int i = 0;\n  i < n;\n  i ++ ) numofadj . push_back ( accumulate ( graph [ i ], graph [ i ] + 5, 0 ) );\n  int startpoint = 0, numofodd = 0;\n  for ( int i = n - 1;\n  i >= 0;\n  i -- ) {\n    if ( numofadj [ i ] % 2 == 1 ) {\n      numofodd ++;\n      startpoint = i;\n    }\n  }\n  if ( numofodd > 2 ) {\n    cout << \"No Solution\" << endl;\n    return;\n  }\n  stack < int > stack;\n  vector < int > path;\n  int cur = startpoint;\n  while ( ! stack . empty ( ) or accumulate ( graph [ cur ], graph [ cur ] + 5, 0 ) != 0 ) {\n    if ( accumulate ( graph [ cur ], graph [ cur ] + 5, 0 ) == 0 ) {\n      path . push_back ( cur );\n      cur = stack . top ( );\n      stack . pop ( );\n    }\n    else {\n      for ( int i = 0;\n      i < n;\n      i ++ ) {\n        if ( graph [ cur ] [ i ] == 1 ) {\n          stack . push ( cur );\n          graph [ cur ] [ i ] = 0;\n          graph [ i ] [ cur ] = 0;\n          cur = i;\n          break;\n        }\n      }\n    }\n  }\n  for ( auto ele : path ) cout << ele << \" -> \";\n  cout << cur << endl;\n}\n", "RECURSIVE_SOLUTION_COUNT_SUBSTRINGS_FIRST_LAST_CHARACTERS": "int countSubstrs ( string str, int i, int j, int n ) {\n  if ( n == 1 ) return 1;\n  if ( n <= 0 ) return 0;\n  int 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 ] ) res ++;\n  return res;\n}\n", "FIND_NUMBER_TIMES_STRING_OCCURS_GIVEN_STRING_1": "int count ( string a, string b ) {\n  int m = a . length ( );\n  int n = b . length ( );\n  int lookup [ m + 1 ] [ n + 1 ] = {\n    {\n      0 }\n    };\n    for ( int i = 0;\n    i <= n;\n    ++ i ) lookup [ 0 ] [ i ] = 0;\n    for ( int i = 0;\n    i <= m;\n    ++ i ) lookup [ i ] [ 0 ] = 1;\n    for ( int i = 1;\n    i <= m;\n    i ++ ) {\n      for ( int j = 1;\n      j <= n;\n      j ++ ) {\n        if ( a [ i - 1 ] == b [ j - 1 ] ) lookup [ i ] [ j ] = lookup [ i - 1 ] [ j - 1 ] + lookup [ i - 1 ] [ j ];\n        else lookup [ i ] [ j ] = lookup [ i - 1 ] [ j ];\n      }\n    }\n    return lookup [ m ] [ n ];\n  }\n  ", "AREA_OF_A_POLYGON_WITH_GIVEN_N_ORDERED_VERTICES": "double polygonArea ( double X [ ], double Y [ ], int n ) {\n  double area = 0.0;\n  int j = n - 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    area += ( X [ j ] + X [ i ] ) * ( Y [ j ] - Y [ i ] );\n    j = i;\n  }\n  return abs ( area / 2.0 );\n}\n", "PRINT_POSSIBLE_SUMS_CONSECUTIVE_NUMBERS_SUM_N": "void findConsecutive ( int N ) {\n  int start = 1, end = ( N + 1 ) / 2;\n  while ( start < end ) {\n    int sum = 0;\n    for ( int i = start;\n    i <= end;\n    i ++ ) {\n      sum = sum + i;\n      if ( sum == N ) {\n        for ( int j = start;\n        j <= i;\n        j ++ ) printf ( \"%d \", j );\n        printf ( \"\\n\" );\n        break;\n      }\n      if ( sum > N ) break;\n    }\n    sum = 0;\n    start ++;\n  }\n}\n", "BALANCED_EXPRESSIONS_SUCH_THAT_GIVEN_POSITIONS_HAVE_OPENING_BRACKETS": "long long arrangeBraces ( int n, int pos [ ], int k ) {\n  bool h [ N ];\n  int dp [ N ] [ N ];\n  memset ( h, 0, sizeof h );\n  memset ( dp, 0, sizeof dp );\n  for ( int i = 0;\n  i < k;\n  i ++ ) h [ pos [ i ] ] = 1;\n  dp [ 0 ] [ 0 ] = 1;\n  for ( int i = 1;\n  i <= 2 * n;\n  i ++ ) {\n    for ( int j = 0;\n    j <= 2 * n;\n    j ++ ) {\n      if ( h [ i ] ) {\n        if ( j != 0 ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ];\n        else dp [ i ] [ j ] = 0;\n      }\n      else {\n        if ( j != 0 ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ];\n        else dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ];\n      }\n    }\n  }\n  return dp [ 2 * n ] [ 0 ];\n}\n", "GIVEN_1S_2S_3S_KS_PRINT_ZIG_ZAG_WAY": "void ZigZag ( int rows, int columns, int numbers [ ] ) {\n  int k = 0;\n  int arr [ rows ] [ columns ];\n  for ( int i = 0;\n  i < rows;\n  i ++ ) {\n    if ( i % 2 == 0 ) {\n      for ( int j = 0;\n      j < columns and numbers [ k ] > 0;\n      j ++ ) {\n        arr [ i ] [ j ] = k + 1;\n        numbers [ k ] --;\n        if ( numbers [ k ] == 0 ) k ++;\n      }\n    }\n    else {\n      for ( int j = columns - 1;\n      j >= 0 and numbers [ k ] > 0;\n      j -- ) {\n        arr [ i ] [ j ] = k + 1;\n        numbers [ k ] --;\n        if ( numbers [ k ] == 0 ) k ++;\n      }\n    }\n  }\n  for ( int i = 0;\n  i < rows;\n  i ++ ) {\n    for ( int j = 0;\n    j < columns;\n    j ++ ) cout << arr [ i ] [ j ] << \" \";\n    cout << endl;\n  }\n}\n", "CONVERT_STRING_BINARY_SEQUENCE": "void strToBinary ( string s ) {\n  int n = s . length ( );\n  for ( int i = 0;\n  i <= n;\n  i ++ ) {\n    int val = int ( s [ i ] );\n    string bin = \"\";\n    while ( val > 0 ) {\n      ( val % 2 ) ? bin . push_back ( '1' ) : bin . push_back ( '0' );\n      val /= 2;\n    }\n    reverse ( bin . begin ( ), bin . end ( ) );\n    cout << bin << \" \";\n  }\n}\n", "LUCKY_NUMBERS": "int bool isLucky ( int n ) {\n  static int counter = 2;\n  int next_position = n;\n  if ( counter > n ) return 1;\n  if ( n % counter == 0 ) return 0;\n  next_position -= next_position / counter;\n  counter ++;\n  return isLucky ( next_position );\n}\n", "SMALLEST_SUM_CONTIGUOUS_SUBARRAY": "int smallestSumSubarr ( int arr [ ], int n ) {\n  int min_ending_here = INT_MAX;\n  int min_so_far = INT_MAX;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( min_ending_here > 0 ) min_ending_here = arr [ i ];\n    else min_ending_here += arr [ i ];\n    min_so_far = min ( min_so_far, min_ending_here );\n  }\n  return min_so_far;\n}\n", "PRINT_N_TERMS_NEWMAN_CONWAY_SEQUENCE": "void sequence ( int n ) {\n  int f [ n + 1 ];\n  f [ 0 ] = 0;\n  f [ 1 ] = 1;\n  f [ 2 ] = 1;\n  cout << f [ 1 ] << \" \" << f [ 2 ] << \" \";\n  for ( int i = 3;\n  i <= n;\n  i ++ ) {\n    f [ i ] = f [ f [ i - 1 ] ] + f [ i - f [ i - 1 ] ];\n    cout << f [ i ] << \" \";\n  }\n}\n", "MASTER_THEOREM_SUBTRACT_CONQUER_RECURRENCES": "int fib ( int n ) {\n  if ( n <= 1 ) return n;\n  return fib ( n - 1 ) + fib ( n - 2 );\n}\n", "MINIMUM_COST_MAKE_ARRAY_SIZE_1_REMOVING_LARGER_PAIRS": "int cost ( int a [ ], int n ) {\n  return ( n - 1 ) * ( * min_element ( a, a + n ) );\n}\n", "CHOCOLATE_DISTRIBUTION_PROBLEM": "int findMinDiff ( int arr [ ], int n, int m ) {\n  if ( m == 0 || n == 0 ) return 0;\n  sort ( arr, arr + n );\n  if ( n < m ) return - 1;\n  int min_diff = INT_MAX;\n  int first = 0, last = 0;\n  for ( int i = 0;\n  i + m - 1 < n;\n  i ++ ) {\n    int 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    }\n  }\n  return ( arr [ last ] - arr [ first ] );\n}\n", "FIND_ONE_EXTRA_CHARACTER_STRING_1": "char findExtraCharcter ( string strA, string strB ) {\n  int res = 0, i;\n  for ( i = 0;\n  i < strA . length ( );\n  i ++ ) {\n    res ^= strA [ i ];\n  }\n  for ( i = 0;\n  i < strB . length ( );\n  i ++ ) {\n    res ^= strB [ i ];\n  }\n  return ( ( char ) ( res ) );\n}\n", "CHECK_WHETHER_TWO_STRINGS_ARE_ANAGRAM_OF_EACH_OTHER": "bool areAnagram ( string str1, string str2 ) {\n  int n1 = str1 . length ( );\n  int n2 = str2 . length ( );\n  if ( n1 != n2 ) return false;\n  sort ( str1 . begin ( ), str1 . end ( ) );\n  sort ( str2 . begin ( ), str2 . end ( ) );\n  for ( int i = 0;\n  i < n1;\n  i ++ ) if ( str1 [ i ] != str2 [ i ] ) return false;\n  return true;\n}\n", "CALCULATE_MAXIMUM_VALUE_USING_SIGN_TWO_NUMBERS_STRING": "int calcMaxValue ( string str ) {\n  int res = str [ 0 ] - '0';\n  for ( int i = 1;\n  i < str . length ( );\n  i ++ ) {\n    if ( str [ i ] == '0' || str [ i ] == '1' || res < 2 ) res += ( str [ i ] - '0' );\n    else res *= ( str [ i ] - '0' );\n  }\n  return res;\n}\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER": "int findSum ( int N, int K ) {\n  int ans = 0;\n  for ( int i = 1;\n  i <= N;\n  i ++ ) ans += ( i % K );\n  return ans;\n}\n", "DISTRIBUTING_ITEMS_PERSON_CANNOT_TAKE_TWO_ITEMS_TYPE_1": "bool checkCount ( int arr [ ], int n, int k ) {\n  unordered_map < int, int > hash;\n  for ( int i = 0;\n  i < n;\n  i ++ ) hash [ arr [ i ] ] ++;\n  for ( auto x : hash ) if ( x . second > 2 * k ) return false;\n  return true;\n}\n", "SEARCH_IN_ROW_WISE_AND_COLUMN_WISE_SORTED_MATRIX": "int search ( int mat [ 4 ] [ 4 ], int n, int x ) {\n  if ( n == 0 ) return - 1;\n  int smallest = a [ 0 ] [ 0 ], largest = a [ n - 1 ] [ n - 1 ];\n  if ( x < smallest || x > largest ) return - 1;\n  int i = 0, j = n - 1;\n  while ( i < n && j >= 0 ) {\n    if ( mat [ i ] [ j ] == x ) {\n      cout << \"n Found at \" << i << \", \" << j;\n      return 1;\n    }\n    if ( mat [ i ] [ j ] > x ) j --;\n    else i ++;\n  }\n  cout << \"n Element not found\";\n  return 0;\n}\n", "RETURN_PREVIOUS_ELEMENT_IN_AN_EXPANDING_MATRIX": "string findLeft ( string str ) {\n  int n = str . length ( );\n  while ( n -- ) {\n    if ( str [ n ] == 'd' ) {\n      str [ n ] = 'c';\n      break;\n    }\n    if ( str [ n ] == 'b' ) {\n      str [ n ] = 'a';\n      break;\n    }\n    if ( str [ n ] == 'a' ) str [ n ] = 'b';\n    else if ( str [ n ] == 'c' ) str [ n ] = 'd';\n  }\n  return str;\n}\n", "SUM_FACTORS_NUMBER": "int divSum ( int n ) {\n  int result = 0;\n  for ( int i = 2;\n  i <= sqrt ( n );\n  i ++ ) {\n    if ( n % i == 0 ) {\n      if ( i == ( n / i ) ) result += i;\n      else result += ( i + n / i );\n    }\n  }\n  return ( result + n + 1 );\n}\n", "HOW_CAN_WE_SUM_THE_DIGITS_OF_A_GIVEN_NUMBER_IN_SINGLE_STATEMENT_2": "public : int sumDigits ( int no ) {\n  return no == 0 ? 0 : no % 10 + sumDigits ( no / 10 );\n}\n", "CHECK_POSSIBLE_SORT_ARRAY_CONDITIONAL_SWAPPING_ADJACENT_ALLOWED": "bool checkForSorting ( int arr [ ], int n ) {\n  for ( int i = 0;\n  i < n - 1;\n  i ++ ) {\n    if ( arr [ i ] > arr [ i + 1 ] ) {\n      if ( arr [ i ] - arr [ i + 1 ] == 1 ) swap ( arr [ i ], arr [ i + 1 ] );\n      else return false;\n    }\n  }\n  return true;\n}\n", "SUPER_PRIME": "bool SieveOfEratosthenes ( int n, bool isPrime [ ] ) {\n  isPrime [ 0 ] = isPrime [ 1 ] = false;\n  for ( int i = 2;\n  i <= n;\n  i ++ ) isPrime [ i ] = true;\n  for ( int p = 2;\n  p * p <= n;\n  p ++ ) {\n    if ( isPrime [ p ] == true ) {\n      for ( int i = p * 2;\n      i <= n;\n      i += p ) isPrime [ i ] = false;\n    }\n  }\n}\n", "PROGRAM_BINARY_DECIMAL_CONVERSION_1": "int binaryToDecimal ( string n ) {\n  string num = n;\n  int dec_value = 0;\n  int base = 1;\n  int len = num . length ( );\n  for ( int i = len - 1;\n  i >= 0;\n  i -- ) {\n    if ( num [ i ] == '1' ) dec_value += base;\n    base = base * 2;\n  }\n  return dec_value;\n}\n", "LEONARDO_NUMBER": "int leonardo ( int n ) {\n  if ( n == 0 || n == 1 ) return 1;\n  return leonardo ( n - 1 ) + leonardo ( n - 2 ) + 1;\n}\n", "CHECK_ARRAY_CONTAINS_CONTIGUOUS_INTEGERS_DUPLICATES_ALLOWED_1": "bool areElementsContiguous ( int arr [ ], int n ) {\n  unordered_set < int > us;\n  for ( int i = 0;\n  i < n;\n  i ++ ) us . insert ( arr [ i ] );\n  int count = 1;\n  int curr_ele = arr [ 0 ] - 1;\n  while ( us . find ( curr_ele ) != us . end ( ) ) {\n    count ++;\n    curr_ele --;\n  }\n  curr_ele = arr [ 0 ] + 1;\n  while ( us . find ( curr_ele ) != us . end ( ) ) {\n    count ++;\n    curr_ele ++;\n  }\n  return ( count == ( int ) ( us . size ( ) ) );\n}\n", "SQUARE_ROOT_OF_AN_INTEGER": "int floorSqrt ( int x ) {\n  if ( x == 0 || x == 1 ) return x;\n  int i = 1, result = 1;\n  while ( result <= x ) {\n    i ++;\n    result = i * i;\n  }\n  return i - 1;\n}\n", "LEXICOGRAPHICALLY_LARGEST_SUBSEQUENCE_EVERY_CHARACTER_OCCURS_LEAST_K_TIMES": "void subsequence ( char s [ ], char t [ ], int n, int k ) {\n  int last = 0, cnt = 0, new_last = 0, size = 0;\n  for ( char ch = 'z';\n  ch >= 'a';\n  ch -- ) {\n    cnt = 0;\n    for ( int i = last;\n    i < n;\n    i ++ ) {\n      if ( s [ i ] == ch ) cnt ++;\n    }\n    if ( cnt >= k ) {\n      for ( int i = last;\n      i < n;\n      i ++ ) {\n        if ( s [ i ] == ch ) {\n          t [ size ++ ] = ch;\n          new_last = i;\n        }\n      }\n      last = new_last;\n    }\n  }\n  t [ size ] = '\\0';\n}\n", "RECURSIVELY_BREAK_NUMBER_3_PARTS_GET_MAXIMUM_SUM": "int breakSum ( int n ) {\n  if ( n == 0 || n == 1 ) return n;\n  return max ( ( breakSum ( n / 2 ) + breakSum ( n / 3 ) + breakSum ( n / 4 ) ), n );\n}\n", "MINIMUM_NUMBER_SWAPS_REQUIRED_SORT_ARRAY": "int minSwaps ( int arr [ ], int n ) {\n  pair < int, int > arrPos [ n ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    arrPos [ i ] . first = arr [ i ];\n    arrPos [ i ] . second = i;\n  }\n  sort ( arrPos, arrPos + n );\n  vector < bool > vis ( n, false );\n  int ans = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( vis [ i ] || arrPos [ i ] . second == i ) continue;\n    int cycle_size = 0;\n    int j = i;\n    while ( ! vis [ j ] ) {\n      vis [ j ] = 1;\n      j = arrPos [ j ] . second;\n      cycle_size ++;\n    }\n    if ( cycle_size > 0 ) {\n      ans += ( cycle_size - 1 );\n    }\n  }\n  return ans;\n}\n", "DIAGONALLY_DOMINANT_MATRIX": "bool isDDM ( int m [ N ] [ N ], int n ) {\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    int sum = 0;\n    for ( int j = 0;\n    j < n;\n    j ++ ) sum += abs ( m [ i ] [ j ] );\n    sum -= abs ( m [ i ] [ i ] );\n    if ( abs ( m [ i ] [ i ] ) < sum ) return false;\n  }\n  return true;\n}\n", "SPLIT_N_MAXIMUM_COMPOSITE_NUMBERS": "int count ( int n ) {\n  if ( n < 4 ) return - 1;\n  int rem = n % 4;\n  if ( rem == 0 ) return n / 4;\n  if ( rem == 1 ) {\n    if ( n < 9 ) return - 1;\n    return ( n - 9 ) / 4 + 1;\n  }\n  if ( rem == 2 ) return ( n - 6 ) / 4 + 1;\n  if ( rem == 3 ) {\n    if ( n < 15 ) return - 1;\n    return ( n - 15 ) / 4 + 2;\n  }\n}\n", "FIND_DIMENSIONS_RIGHT_ANGLED_TRIANGLE": "void findDimen ( int H, int A ) {\n  if ( H * H < 4 * A ) {\n    cout << \"Not Possible\\n\";\n    return;\n  }\n  double apb = sqrt ( H * H + 4 * A );\n  double asb = sqrt ( H * H - 4 * A );\n  cout . precision ( 2 );\n  cout << \"P = \" << fixed << ( apb - asb ) / 2.0 << \"\\n\";\n  cout << \"B = \" << ( apb + asb ) / 2.0;\n}\n", "PRODUCT_MAXIMUM_FIRST_ARRAY_MINIMUM_SECOND_1": "int minMaxProduct ( int arr1 [ ], int arr2 [ ], int n1, int n2 ) {\n  int max = arr1 [ 0 ];\n  int min = arr2 [ 0 ];\n  int i;\n  for ( i = 1;\n  i < n1 && i < n2;\n  ++ i ) {\n    if ( arr1 [ i ] > max ) max = arr1 [ i ];\n    if ( arr2 [ i ] < min ) min = arr2 [ i ];\n  }\n  while ( i < n1 ) {\n    if ( arr1 [ i ] > max ) max = arr1 [ i ];\n    i ++;\n  }\n  while ( i < n2 ) {\n    if ( arr2 [ i ] < min ) min = arr2 [ i ];\n    i ++;\n  }\n  return max * min;\n}\n", "PROGRAM_CALCULATE_VOLUME_OCTAHEDRON": "double vol_of_octahedron ( double side ) {\n  return ( ( side * side * side ) * ( sqrt ( 2 ) / 3 ) );\n}\n", "SORT_STRING_CHARACTERS_1": "void sortString ( string & str ) {\n  int charCount [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < str . length ( );\n    i ++ ) charCount [ str [ i ] - 'a' ] ++;\n    for ( int i = 0;\n    i < MAX_CHAR;\n    i ++ ) for ( int j = 0;\n    j < charCount [ i ];\n    j ++ ) cout << ( char ) ( 'a' + i );\n  }\n  ", "MOVE_SPACES_FRONT_STRING_SINGLE_TRAVERSAL": "void moveSpaceInFront ( char str [ ] ) {\n  int i = strlen ( str );\n  for ( int j = i;\n  j >= 0;\n  j -- ) if ( str [ j ] != ' ' ) str [ i -- ] = str [ j ];\n  while ( i >= 0 ) str [ i -- ] = ' ';\n}\n", "MINIMUM_INCREMENT_K_OPERATIONS_MAKE_ELEMENTS_EQUAL": "int minOps ( int arr [ ], int n, int k ) {\n  int max = * max_element ( arr, arr + n );\n  int res = 0;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( ( max - arr [ i ] ) % k != 0 ) return - 1;\n    else res += ( max - arr [ i ] ) / k;\n  }\n  return res;\n}\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER_1": "unsigned int factorial ( unsigned int n ) {\n  int res = 1, i;\n  for ( i = 2;\n  i <= n;\n  i ++ ) res *= i;\n  return res;\n}\n", "MINIMUM_TIME_TO_FINISH_TASKS_WITHOUT_SKIPPING_TWO_CONSECUTIVE": "int minTime ( int arr [ ], int n ) {\n  if ( n <= 0 ) return 0;\n  int incl = arr [ 0 ];\n  int excl = 0;\n  for ( int i = 1;\n  i < n;\n  i ++ ) {\n    int incl_new = arr [ i ] + min ( excl, incl );\n    int excl_new = incl;\n    incl = incl_new;\n    excl = excl_new;\n  }\n  return min ( incl, excl );\n}\n", "CHECK_IF_TWO_ARRAYS_ARE_EQUAL_OR_NOT": "bool areEqual ( int arr1 [ ], int arr2 [ ], int n, int m ) {\n  if ( n != m ) return false;\n  sort ( arr1, arr1 + n );\n  sort ( arr2, arr2 + m );\n  for ( int i = 0;\n  i < n;\n  i ++ ) if ( arr1 [ i ] != arr2 [ i ] ) return false;\n  return true;\n}\n", "MINIMUM_DIFFERENCE_MAX_MIN_K_SIZE_SUBSETS": "int minDifferenceAmongMaxMin ( int arr [ ], int N, int K ) {\n  sort ( arr, arr + N );\n  int res = INT_MAX;\n  for ( int i = 0;\n  i <= ( N - K );\n  i ++ ) {\n    int curSeqDiff = arr [ i + K - 1 ] - arr [ i ];\n    res = min ( res, curSeqDiff );\n  }\n  return res;\n}\n", "SWAP_BITS_IN_A_GIVEN_NUMBER": "int swapBits ( unsigned int x, unsigned int p1, unsigned int p2, unsigned int n ) {\n  unsigned int set1 = ( x >> p1 ) & ( ( 1U << n ) - 1 );\n  unsigned int set2 = ( x >> p2 ) & ( ( 1U << n ) - 1 );\n  unsigned int Xor = ( set1 ^ set2 );\n  Xor = ( Xor << p1 ) | ( Xor << p2 );\n  unsigned int result = x ^ Xor;\n  return result;\n}\n", "COUNT_NUMBER_OF_WAYS_TO_FILL_A_N_X_4_GRID_USING_1_X_4_TILES": "int count ( int n ) {\n  int dp [ n + 1 ];\n  dp [ 0 ] = 0;\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    if ( i >= 1 && i <= 3 ) dp [ i ] = 1;\n    else if ( i == 4 ) dp [ i ] = 2;\n    else dp [ i ] = dp [ i - 1 ] + dp [ i - 4 ];\n  }\n  return dp [ n ];\n}\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING_1": "char maxRepeating ( string str ) {\n  int n = str . length ( );\n  int count = 0;\n  char res = str [ 0 ];\n  int cur_count = 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i < n - 1 && str [ i ] == str [ i + 1 ] ) cur_count ++;\n    else {\n      if ( cur_count > count ) {\n        count = cur_count;\n        res = str [ i ];\n      }\n      cur_count = 1;\n    }\n  }\n  return res;\n}\n", "PASCAL_TRIANGLE": "void printPascal ( int n ) {\n  int arr [ n ] [ n ];\n  for ( int line = 0;\n  line < n;\n  line ++ ) {\n    for ( int i = 0;\n    i <= line;\n    i ++ ) {\n      if ( line == i || i == 0 ) arr [ line ] [ i ] = 1;\n      else arr [ line ] [ i ] = arr [ line - 1 ] [ i - 1 ] + arr [ line - 1 ] [ i ];\n      cout << arr [ line ] [ i ] << \" \";\n    }\n    cout << \"\\n\";\n  }\n}\n", "TURN_OFF_THE_RIGHTMOST_SET_BIT": "int fun ( unsigned int n ) {\n  return n & ( n - 1 );\n}\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM_SET_2_O1_EXTRA_SPACE": "void rearrange ( int arr [ ], int n ) {\n  int max_idx = n - 1, min_idx = 0;\n  int max_elem = arr [ n - 1 ] + 1;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( i % 2 == 0 ) {\n      arr [ i ] += ( arr [ max_idx ] % max_elem ) * max_elem;\n      max_idx --;\n    }\n    else {\n      arr [ i ] += ( arr [ min_idx ] % max_elem ) * max_elem;\n      min_idx ++;\n    }\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) arr [ i ] = arr [ i ] / max_elem;\n}\n", "COUNT_ZEROS_IN_A_ROW_WISE_AND_COLUMN_WISE_SORTED_MATRIX": "int countZeroes ( int mat [ N ] [ N ] ) {\n  int row = N - 1, col = 0;\n  int count = 0;\n  while ( col < N ) {\n    while ( mat [ row ] [ col ] ) if ( -- row < 0 ) return count;\n    count += ( row + 1 );\n    col ++;\n  }\n  return count;\n}\n", "MINIMUM_COST_FOR_ACQUIRING_ALL_COINS_WITH_K_EXTRA_COINS_ALLOWED_WITH_EVERY_COIN": "int minCost ( int coin [ ], int n, int k ) {\n  sort ( coin, coin + n );\n  int coins_needed = ceil ( 1.0 * n / ( k + 1 ) );\n  int ans = 0;\n  for ( int i = 0;\n  i <= coins_needed - 1;\n  i ++ ) ans += coin [ i ];\n  return ans;\n}\n", "COUNT_SUBARRAYS_TOTAL_DISTINCT_ELEMENTS_ORIGINAL_ARRAY": "int countDistictSubarray ( int arr [ ], int n ) {\n  unordered_map < int, int > vis;\n  for ( int i = 0;\n  i < n;\n  ++ i ) vis [ arr [ i ] ] = 1;\n  int k = vis . size ( );\n  vis . clear ( );\n  int ans = 0, right = 0, window = 0;\n  for ( int left = 0;\n  left < n;\n  ++ left ) {\n    while ( right < n && window < k ) {\n      ++ vis [ arr [ right ] ];\n      if ( vis [ arr [ right ] ] == 1 ) ++ window;\n      ++ right;\n    }\n    if ( window == k ) ans += ( n - right + 1 );\n    -- vis [ arr [ left ] ];\n    if ( vis [ arr [ left ] ] == 0 ) -- window;\n  }\n  return ans;\n}\n", "FIND_POSSIBLE_ROTATE_PAGE_ANGLE_NOT": "void possibleOrNot ( long long a1, long long a2, long long b1, long long b2, long long c1, long long c2 ) {\n  long long dis1 = pow ( b1 - a1, 2 ) + pow ( b2 - a2, 2 );\n  long long dis2 = pow ( c1 - b1, 2 ) + pow ( c2 - b2, 2 );\n  if ( dis1 != dis2 ) cout << \"No\";\n  else if ( b1 == ( ( a1 + c1 ) / 2.0 ) && b2 == ( ( a2 + c2 ) / 2.0 ) ) cout << \"No\";\n  else cout << \"Yes\";\n}\n", "TIME_MEET_ANIMALS": "void timeToMeet ( double s, double v ) {\n  double V = 3 * v / 2;\n  double time = s / V;\n  cout << time;\n}\n", "BRESENHAMS_LINE_GENERATION_ALGORITHM": "void bresenham ( int x1, int y1, int x2, int y2 ) {\n  int m_new = 2 * ( y2 - y1 );\n  int slope_error_new = m_new - ( x2 - x1 );\n  for ( int x = x1, y = y1;\n  x <= x2;\n  x ++ ) {\n    cout << \"(\" << x << \",\" << y << \")\\n\";\n    slope_error_new += m_new;\n    if ( slope_error_new >= 0 ) {\n      y ++;\n      slope_error_new -= 2 * ( x2 - x1 );\n    }\n  }\n}\n", "MAXIMUM_NUMBER_CHOCOLATES_DISTRIBUTED_EQUALLY_AMONG_K_STUDENTS": "int maxNumOfChocolates ( int arr [ ], int n, int k ) {\n  unordered_map < int, int > um;\n  int sum [ n ], curr_rem;\n  int maxSum = 0;\n  sum [ 0 ] = arr [ 0 ];\n  for ( int i = 1;\n  i < n;\n  i ++ ) sum [ i ] = sum [ i - 1 ] + arr [ i ];\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    curr_rem = sum [ i ] % k;\n    if ( curr_rem == 0 ) {\n      if ( maxSum < sum [ i ] ) maxSum = sum [ i ];\n    }\n    else if ( um . find ( curr_rem ) == um . end ( ) ) um [ curr_rem ] = i;\n    else if ( maxSum < ( sum [ i ] - sum [ um [ curr_rem ] ] ) ) maxSum = sum [ i ] - sum [ um [ curr_rem ] ];\n  }\n  return ( maxSum / k );\n}\n", "CHECK_TWO_STRINGS_K_ANAGRAMS_NOT_1": "bool areKAnagrams ( string str1, string str2, int k ) {\n  int n = str1 . length ( );\n  if ( str2 . length ( ) != n ) return false;\n  int hash_str1 [ MAX_CHAR ] = {\n    0 };\n    for ( int i = 0;\n    i < n;\n    i ++ ) hash_str1 [ str1 [ i ] - 'a' ] ++;\n    int count = 0;\n    for ( int i = 0;\n    i < n;\n    i ++ ) {\n      if ( hash_str1 [ str2 [ i ] - 'a' ] > 0 ) hash_str1 [ str2 [ i ] - 'a' ] --;\n      else count ++;\n      if ( count > k ) return false;\n    }\n    return true;\n  }\n  ", "DIVISIBILITY_CHECK": "void divisibilityCheck ( int arr [ ], int n ) {\n  unordered_set < int > s;\n  int max_ele = INT_MIN;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    s . insert ( arr [ i ] );\n    max_ele = max ( max_ele, arr [ i ] );\n  }\n  unordered_set < int > res;\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    if ( arr [ i ] != 0 ) {\n      for ( int j = arr [ i ] * 2;\n      j <= max_ele;\n      j += arr [ i ] ) {\n        if ( s . find ( j ) != s . end ( ) ) res . insert ( j );\n      }\n    }\n  }\n  unordered_map < int, int > mp;\n  for ( int i = 0;\n  i < n;\n  i ++ ) mp [ arr [ i ] ] ++;\n  unordered_map < int, int > :: iterator it;\n  vector < int > ans;\n  for ( it = mp . begin ( );\n  it != mp . end ( );\n  it ++ ) {\n    if ( it -> second >= 2 ) {\n      if ( res . find ( it -> first ) == res . end ( ) ) {\n        int val = it -> second;\n        while ( val -- ) ans . push_back ( it -> first );\n      }\n    }\n    if ( res . find ( it -> first ) != res . end ( ) ) {\n      int val = it -> second;\n      while ( val -- ) ans . push_back ( it -> first );\n    }\n  }\n  for ( auto x : ans ) cout << x << \" \";\n}\n", "MAXIMUM_LENGTH_PREFIX_ONE_STRING_OCCURS_SUBSEQUENCE_ANOTHER": "int maxPrefix ( char s [ ], char t [ ] ) {\n  int count = 0;\n  for ( int i = 0;\n  i < strlen ( t );\n  i ++ ) {\n    if ( count == strlen ( s ) ) break;\n    if ( t [ i ] == s [ count ] ) count ++;\n  }\n  return count;\n}\n", "COUNT_DISTINCT_ELEMENTS_IN_EVERY_WINDOW_OF_SIZE_K": "void countDistinct ( int arr [ ], int k, int n ) {\n  map < int, int > hm;\n  int dist_count = 0;\n  for ( int i = 0;\n  i < k;\n  i ++ ) {\n    if ( hm [ arr [ i ] ] == 0 ) {\n      dist_count ++;\n    }\n    hm [ arr [ i ] ] += 1;\n  }\n  cout << dist_count << endl;\n  for ( int i = k;\n  i < n;\n  i ++ ) {\n    if ( hm [ arr [ i - k ] ] == 1 ) {\n      dist_count --;\n    }\n    hm [ arr [ i - k ] ] -= 1;\n    if ( hm [ arr [ i ] ] == 0 ) {\n      dist_count ++;\n    }\n    hm [ arr [ i ] ] += 1;\n    cout << dist_count << endl;\n  }\n}\n", "LCS_FORMED_CONSECUTIVE_SEGMENTS_LEAST_LENGTH_K": "int longestSubsequenceCommonSegment ( int k, string s1, string s2 ) {\n  int n = s1 . length ( );\n  int m = s2 . length ( );\n  int lcs [ n + 1 ] [ m + 1 ];\n  int cnt [ n + 1 ] [ m + 1 ];\n  memset ( lcs, 0, sizeof ( lcs ) );\n  memset ( cnt, 0, sizeof ( cnt ) );\n  for ( int i = 1;\n  i <= n;\n  i ++ ) {\n    for ( int j = 1;\n    j <= m;\n    j ++ ) {\n      lcs [ i ] [ j ] = max ( lcs [ i - 1 ] [ j ], lcs [ i ] [ j - 1 ] );\n      if ( s1 [ i - 1 ] == s2 [ j - 1 ] ) cnt [ i ] [ j ] = cnt [ i - 1 ] [ j - 1 ] + 1;\n      if ( cnt [ i ] [ j ] >= k ) {\n        for ( int a = k;\n        a <= cnt [ i ] [ j ];\n        a ++ ) lcs [ i ] [ j ] = max ( lcs [ i ] [ j ], lcs [ i - a ] [ j - a ] + a );\n      }\n    }\n  }\n  return lcs [ n ] [ m ];\n}\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY_1": "void printDistinct ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    while ( i < n - 1 && arr [ i ] == arr [ i + 1 ] ) i ++;\n    cout << arr [ i ] << \" \";\n  }\n}\n", "PRIMALITY_TEST_SET_5USING_LUCAS_LEHMER_SERIES": "bool isPrime ( int p ) {\n  long long checkNumber = pow ( 2, p ) - 1;\n  long long nextval = 4 % checkNumber;\n  for ( int i = 1;\n  i < p - 1;\n  i ++ ) nextval = ( nextval * nextval - 2 ) % checkNumber;\n  return ( nextval == 0 );\n}\n", "KTH_NON_REPEATING_CHARACTER": "int kthNonRepeating ( string str, int k ) {\n  int n = str . length ( );\n  int count [ MAX_CHAR ];\n  int index [ MAX_CHAR ];\n  for ( int i = 0;\n  i < MAX_CHAR;\n  i ++ ) {\n    count [ i ] = 0;\n    index [ i ] = n;\n  }\n  for ( int i = 0;\n  i < n;\n  i ++ ) {\n    char x = str [ i ];\n    ++ count [ x ];\n    if ( count [ x ] == 1 ) index [ x ] = i;\n    if ( count [ x ] == 2 ) index [ x ] = n;\n  }\n  sort ( index, index + MAX_CHAR );\n  return ( index [ k - 1 ] != n ) ? index [ k - 1 ] : - 1;\n}\n", "FIRST_UPPERCASE_LETTER_IN_A_STRING_ITERATIVE_AND_RECURSIVE": "char first ( string str ) {\n  for ( int i = 0;\n  i < str . length ( );\n  i ++ ) if ( isupper ( str [ i ] ) ) return str [ i ];\n  return 0;\n}\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND": "bool isSubSequence ( char str1 [ ], char str2 [ ], int m, int n ) {\n  if ( m == 0 ) return true;\n  if ( n == 0 ) return false;\n  if ( str1 [ m - 1 ] == str2 [ n - 1 ] ) return isSubSequence ( str1, str2, m - 1, n - 1 );\n  return isSubSequence ( str1, str2, m, n - 1 );\n}\n", "C_PROGRAM_FIND_LARGEST_ELEMENT_ARRAY_1": "int largest ( int arr [ ], int n ) {\n  return * max_element ( arr, arr + n );\n}\n", "DIFFERENCE_BETWEEN_HIGHEST_AND_LEAST_FREQUENCIES_IN_AN_ARRAY": "int findDiff ( int arr [ ], int n ) {\n  sort ( arr, arr + n );\n  int count = 0, max_count = 0, min_count = n;\n  for ( int i = 0;\n  i < ( n - 1 );\n  i ++ ) {\n    if ( arr [ i ] == arr [ i + 1 ] ) {\n      count += 1;\n      continue;\n    }\n    else {\n      max_count = max ( max_count, count );\n      min_count = min ( min_count, count );\n      count = 0;\n    }\n  }\n  return ( max_count - min_count );\n}\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER": "unsigned int factorial ( unsigned int n ) {\n  if ( n == 0 ) return 1;\n  return n * factorial ( n - 1 );\n}\n"}