{"MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING": "static 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 . charAt ( i ) == str . charAt ( j ) ) res = Math . max ( res , Math . abs ( j - i - 1 ) ) ;\n  return res ;\n}\n", "FIND_MIRROR_IMAGE_POINT_2_D_PLANE": "static pair 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 new pair ( x , y ) ;\n}\n", "EFFICIENTLY_COMPUTE_SUMS_OF_DIAGONALS_OF_A_MATRIX": "static void printDiagonalSums ( int [ ] [ ] mat , 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  System . out . println ( \"Principal Diagonal:\" + principal ) ;\n  System . out . println ( \"Secondary Diagonal:\" + secondary ) ;\n}\n", "COUNTS_PATHS_POINT_REACH_ORIGIN": "static 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": "boolean find3Numbers ( int A [ ] , int arr_size , int sum ) {\n  int l , r ;\n  quickSort ( A , 0 , arr_size - 1 ) ;\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        System . out . print ( \"Triplet is \" + 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": "static boolean isMagicSquare ( int mat [ ] [ ] ) {\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": "static int getTotalNumberOfSequences ( int m , int n ) {\n  int T [ ] [ ] = new int [ 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": "public static int difference ( int arr [ ] [ ] , 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 Math . abs ( d1 - d2 ) ;\n}\n", "MINIMUM_NUMBER_SUBSETS_DISTINCT_ELEMENTS": "public static int subset ( int ar [ ] , int n ) {\n  int res = 0 ;\n  Arrays . sort ( ar ) ;\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 = Math . max ( res , count ) ;\n  }\n  return res ;\n}\n", "DECIMAL_BINARY_CONVERSION_WITHOUT_USING_ARITHMETIC_OPERATORS": "static 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": "static 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 . charAt ( 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": "static void reverse ( char str [ ] ) {\n  int n = str . length , i ;\n  for ( i = 0 ;\n  i < n / 2 ;\n  i ++ ) {\n    swap ( str , i , n - i - 1 ) ;\n  }\n}\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER_1": "static 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    arr = swap ( arr , i , j ) ;\n    i += 2 ;\n    j -= 2 ;\n  }\n  Arrays . sort ( arr , 0 , ( n + 1 ) / 2 ) ;\n  Arrays . sort ( arr , ( n + 1 ) / 2 , n ) ;\n  int low = ( n + 1 ) / 2 , high = n - 1 ;\n  while ( low < high ) {\n    Integer temp = arr [ low ] ;\n    arr [ low ] = arr [ high ] ;\n    arr [ high ] = temp ;\n    low ++ ;\n    high -- ;\n  }\n}\n", "GIVEN_TWO_NUMBERS_B_FIND_X_X_B": "static void modularEquation ( int a , int b ) {\n  if ( a < b ) {\n    System . out . println ( \"No solution possible \" ) ;\n    return ;\n  }\n  if ( a == b ) {\n    System . out . println ( \"Infinite Solution possible \" ) ;\n    return ;\n  }\n  int count = 0 ;\n  int n = a - b ;\n  int y = ( int ) Math . 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  System . out . println ( count ) ;\n}\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME": "static boolean canFormPalindrome ( String str ) {\n  int count [ ] = new int [ NO_OF_CHARS ] ;\n  Arrays . fill ( count , 0 ) ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) count [ ( int ) ( str . charAt ( i ) ) ] ++ ;\n  int odd = 0 ;\n  for ( int i = 0 ;\n  i < NO_OF_CHARS ;\n  i ++ ) {\n    if ( ( count [ i ] & 1 ) == 1 ) odd ++ ;\n    if ( odd > 1 ) return false ;\n  }\n  return true ;\n}\n", "MAXIMUM_TRIPLET_SUM_ARRAY_1": "static int maxTripletSum ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  return arr [ n - 1 ] + arr [ n - 2 ] + arr [ n - 3 ] ;\n}\n", "FIND_MEDIAN_ROW_WISE_SORTED_MATRIX": "static int binaryMedian ( int m [ ] [ ] , int r , int c ) {\n  int max = Integer . MIN_VALUE ;\n  int min = Integer . MAX_VALUE ;\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    int get = 0 ;\n    for ( int i = 0 ;\n    i < r ;\n    ++ i ) {\n      get = Arrays . binarySearch ( m [ i ] , mid ) ;\n      if ( get < 0 ) get = Math . abs ( get ) - 1 ;\n      else {\n        while ( get < m [ i ] . length && m [ i ] [ get ] == mid ) get += 1 ;\n      }\n      place = place + get ;\n    }\n    if ( place < desired ) min = mid + 1 ;\n    else max = mid ;\n  }\n  return min ;\n}\n", "HEIGHT_N_ARY_TREE_PARENT_ARRAY_GIVEN": "static 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 = Math . max ( res , current ) ;\n  }\n  return res ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_20": "static Boolean divisibleBy20 ( String num ) {\n  int lastTwoDigits = Integer . parseInt ( num . substring ( num . length ( ) - 2 , num . length ( ) ) ) ;\n  return ( ( lastTwoDigits % 5 == 0 ) && ( lastTwoDigits % 4 == 0 ) ) ;\n}\n", "MAXIMUM_VALUE_CHOICE_EITHER_DIVIDING_CONSIDERING": "static int maxDP ( int n ) {\n  int res [ ] = new int [ n + 1 ] ;\n  res [ 0 ] = 0 ;\n  res [ 1 ] = 1 ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) res [ i ] = Math . 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": "static void PerformQueries ( int [ ] a , int [ ] [ ] vec ) {\n  Vector < Integer > ans = new Vector < > ( ) ;\n  int n = ( int ) a . length - 1 ;\n  int q = ( int ) vec . length ;\n  for ( int i = 0 ;\n  i < q ;\n  ++ i ) {\n    long t = vec [ i ] [ 0 ] ;\n    int m = vec [ i ] [ 1 ] ;\n    if ( m > n ) {\n      ans . add ( - 1 ) ;\n      continue ;\n    }\n    int turn = ( int ) ( t / n ) ;\n    int rem = ( int ) ( t % n ) ;\n    if ( rem == 0 && turn % 2 == 1 ) {\n      ans . add ( - 1 ) ;\n      continue ;\n    }\n    if ( rem == 0 && turn % 2 == 0 ) {\n      ans . add ( a [ m ] ) ;\n      continue ;\n    }\n    if ( turn % 2 == 0 ) {\n      int cursize = n - rem ;\n      if ( cursize < m ) {\n        ans . add ( - 1 ) ;\n        continue ;\n      }\n      ans . add ( a [ m + rem ] ) ;\n    }\n    else {\n      int cursize = rem ;\n      if ( cursize < m ) {\n        ans . add ( - 1 ) ;\n        continue ;\n      }\n      ans . add ( a [ m ] ) ;\n    }\n  }\n  for ( int i : ans ) System . out . print ( 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 = Integer . MAX_VALUE ;\n  int prev = 0 ;\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": "static 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 ] ) System . out . print ( arr1 [ i ++ ] + \" \" ) ;\n    else if ( arr2 [ j ] < arr1 [ i ] ) System . out . print ( arr2 [ j ++ ] + \" \" ) ;\n    else {\n      System . out . print ( arr2 [ j ++ ] + \" \" ) ;\n      i ++ ;\n    }\n  }\n  while ( i < m ) System . out . print ( arr1 [ i ++ ] + \" \" ) ;\n  while ( j < n ) System . out . print ( arr2 [ j ++ ] + \" \" ) ;\n  return 0 ;\n}\n", "WORD_WRAP_PROBLEM_SPACE_OPTIMIZED_SOLUTION": "static void solveWordWrap ( int arr [ ] , int n , int k ) {\n  int i , j ;\n  int currlen ;\n  int cost ;\n  int dp [ ] = new int [ n ] ;\n  int ans [ ] = new int [ 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 ] = Integer . MAX_VALUE ;\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    System . out . print ( ( i + 1 ) + \" \" + ( ans [ i ] + 1 ) + \" \" ) ;\n    i = ans [ i ] + 1 ;\n  }\n}\n", "COUNT_DISTINCT_SUBSEQUENCES": "static int countSub ( String str ) {\n  int [ ] last = new int [ MAX_CHAR ] ;\n  Arrays . fill ( last , - 1 ) ;\n  int n = str . length ( ) ;\n  int [ ] dp = new int [ 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 [ ( int ) str . charAt ( i - 1 ) ] != - 1 ) dp [ i ] = dp [ i ] - dp [ last [ ( int ) str . charAt ( i - 1 ) ] ] ;\n    last [ ( int ) str . charAt ( i - 1 ) ] = ( i - 1 ) ;\n  }\n  return dp [ n ] ;\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_3": "static 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 . charAt ( l ) - '0' ;\n      rsum += str . charAt ( r ) - '0' ;\n      if ( lsum == rsum ) {\n        ans = Math . max ( ans , r - l + 1 ) ;\n      }\n      l -- ;\n      r ++ ;\n    }\n  }\n  return ans ;\n}\n", "MAXIMUM_PATH_SUM_MATRIX": "static int findMaxPath ( int mat [ ] [ ] ) {\n  int res = - 1 ;\n  for ( int i = 0 ;\n  i < M ;\n  i ++ ) res = max ( res , mat [ 0 ] [ i ] ) ;\n  for ( int i = 1 ;\n  i < N ;\n  i ++ ) {\n    res = - 1 ;\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      res = max ( mat [ i ] [ j ] , res ) ;\n    }\n  }\n  return res ;\n}\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING": "static char maxRepeating ( String str ) {\n  int len = str . length ( ) ;\n  int count = 0 ;\n  char res = str . charAt ( 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 . charAt ( i ) != str . charAt ( j ) ) break ;\n      cur_count ++ ;\n    }\n    if ( cur_count > count ) {\n      count = cur_count ;\n      res = str . charAt ( i ) ;\n    }\n  }\n  return res ;\n}\n", "MAXIMUM_LENGTH_SUBSEQUENCE_DIFFERENCE_ADJACENT_ELEMENTS_EITHER_0_1": "public static int maxLenSub ( int arr [ ] , int n ) {\n  int mls [ ] = new int [ 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 ( Math . 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": "static 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 . substring ( 0 , i ) ;\n    int l1 = s . length ( ) ;\n    String t = N . substring ( i , l1 + i ) ;\n    if ( s . charAt ( 0 ) == '0' || t . charAt ( 0 ) == '0' ) continue ;\n    if ( s . compareTo ( t ) == 0 ) count ++ ;\n  }\n  return count ;\n}\n", "PROGRAM_BINARY_DECIMAL_CONVERSION": "static int binaryToDecimal ( int n ) {\n  int num = n ;\n  int dec_value = 0 ;\n  int base = 1 ;\n  int temp = num ;\n  while ( temp > 0 ) {\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": "static 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": "static int findSDSFunc ( int n ) {\n  int DP [ ] = new int [ 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": "static int countSink ( int n , int m , int edgeFrom [ ] , int edgeTo [ ] ) {\n  int [ ] mark = new int [ n + 1 ] ;\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 ] == 0 ) count ++ ;\n  return count ;\n}\n", "BREAK_NUMBER_THREE_PARTS": "static long count_of_ways ( long n ) {\n  long 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": "static 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 ) System . out . print ( arr [ i ] + \" \" ) ;\n  }\n}\n", "MAXIMUM_NUMBER_SEGMENTS_LENGTHS_B_C": "static int maximumSegments ( int n , int a , int b , int c ) {\n  int dp [ ] = new int [ n + 10 ] ;\n  Arrays . fill ( dp , - 1 ) ;\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 ] = Math . max ( dp [ i ] + 1 , dp [ i + a ] ) ;\n      if ( i + b <= n ) dp [ i + b ] = Math . max ( dp [ i ] + 1 , dp [ i + b ] ) ;\n      if ( i + c <= n ) dp [ i + c ] = Math . max ( dp [ i ] + 1 , dp [ i + c ] ) ;\n    }\n  }\n  return dp [ n ] ;\n}\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M": "static boolean isPossible ( int n , int index , int sum , int M , int arr [ ] , int dp [ ] [ ] ) {\n  if ( index == n ) {\n    if ( ( sum % M ) == 0 ) return true ;\n    return false ;\n  }\n  else if ( sum < 0 || sum >= MAX ) return false ;\n  if ( dp [ index ] [ sum ] != - 1 ) {\n    if ( dp [ index ] [ sum ] == 0 ) return false ;\n    return true ;\n  }\n  boolean placeAdd = isPossible ( n , index + 1 , sum + arr [ index ] , M , arr , dp ) ;\n  boolean placeMinus = isPossible ( n , index + 1 , sum - arr [ index ] , M , arr , dp ) ;\n  boolean res = ( placeAdd || placeMinus ) ;\n  dp [ index ] [ sum ] = ( res ) ? 1 : 0 ;\n  return res ;\n}\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY": "static 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 = Math . max ( result , arr [ i ] ) ;\n  return result ;\n}\n", "MAXIMUM_SUBARRAY_SUM_ARRAY_CREATED_REPEATED_CONCATENATION": "static int maxSubArraySumRepeated ( int a [ ] , int n , int k ) {\n  int max_so_far = 0 ;\n  int 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": "static int leonardo ( int n ) {\n  int dp [ ] = new int [ 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": "public static int sumOfSubstrings ( String num ) {\n  int n = num . length ( ) ;\n  int sumofdigit [ ] = new int [ n ] ;\n  sumofdigit [ 0 ] = num . charAt ( 0 ) - '0' ;\n  int res = sumofdigit [ 0 ] ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    int numi = num . charAt ( i ) - '0' ;\n    sumofdigit [ i ] = ( i + 1 ) * numi + 10 * sumofdigit [ i - 1 ] ;\n    res += sumofdigit [ i ] ;\n  }\n  return res ;\n}\n", "PRUFER_CODE_TREE_CREATION": "static void printTreeEdges ( int prufer [ ] , int m ) {\n  int vertices = m + 2 ;\n  int vertex_set [ ] = new int [ 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  System . out . print ( \"\\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        System . out . print ( \"(\" + ( 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      System . out . print ( \"(\" + ( i + 1 ) + \", \" ) ;\n      j ++ ;\n    }\n    else if ( vertex_set [ i ] == 0 && j == 1 ) System . out . print ( ( i + 1 ) + \")\\n\" ) ;\n  }\n}\n", "PROGRAM_FIND_SMALLEST_DIFFERENCE_ANGLES_TWO_PARTS_GIVEN_CIRCLE": "public static 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 = Math . min ( ans , 2 * Math . abs ( 180 - sum ) ) ;\n      sum -= arr [ l ] ;\n      l ++ ;\n    }\n    ans = Math . min ( ans , 2 * Math . abs ( 180 - sum ) ) ;\n  }\n  return ans ;\n}\n", "FIND_MAXIMUM_AVERAGE_SUBARRAY_OF_K_LENGTH": "static 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  return max_end - k + 1 ;\n}\n", "SQUARE_PYRAMIDAL_NUMBER_SUM_SQUARES": "static 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": "static double areaOfInscribedCircle ( float a ) {\n  return ( PI / 4 ) * a * a ;\n}\n", "MINIMUM_NUMBER_CHARACTERS_REMOVED_MAKE_BINARY_STRING_ALTERNATE": "static int countToMake0lternate ( String s ) {\n  int result = 0 ;\n  for ( int i = 0 ;\n  i < ( s . length ( ) - 1 ) ;\n  i ++ ) if ( s . charAt ( i ) == s . charAt ( i + 1 ) ) result ++ ;\n  return result ;\n}\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND": "static 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 ) System . out . print ( a [ i ] + \" \" ) ;\n  }\n}\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM": "static void rearrange ( int [ ] arr , int n ) {\n  int temp [ ] = new int [ n ] ;\n  int small = 0 , large = n - 1 ;\n  boolean 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  arr = temp . clone ( ) ;\n}\n", "DYNAMIC_PROGRAMMING_SET_15_LONGEST_BITONIC_SUBSEQUENCE": "static 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": "static 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": "static int compute ( int [ ] graph , int N ) {\n  int count = 0 ;\n  for ( int i = 1 ;\n  i < 7 ;\n  i ++ ) {\n    if ( graph [ i ] == 0 ) count ++ ;\n  }\n  return count ;\n}\n", "HARDY_RAMANUJAN_THEOREM": "static 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 <= Math . 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": "static int superSeq ( String X , String Y , int m , int n ) {\n  int [ ] [ ] dp = new int [ 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 . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n      else dp [ i ] [ j ] = 1 + Math . min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) ;\n    }\n  }\n  return dp [ m ] [ n ] ;\n}\n", "POWER_SET": "static void printPowerSet ( char [ ] set , int set_size ) {\n  long pow_set_size = ( long ) Math . 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 ) ) > 0 ) System . out . print ( set [ j ] ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "CHECK_ARRAY_MAJORITY_ELEMENT": "static boolean isMajority ( int a [ ] , int n ) {\n  HashMap < Integer , Integer > mp = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( mp . containsKey ( a [ i ] ) ) mp . put ( a [ i ] , mp . get ( a [ i ] ) + 1 ) ;\n  else mp . put ( a [ i ] , 1 ) ;\n  for ( Map . Entry < Integer , Integer > x : mp . entrySet ( ) ) if ( x . getValue ( ) >= n / 2 ) return true ;\n  return false ;\n}\n", "PRINT_GIVEN_MATRIX_COUNTER_CLOCK_WISE_SPIRAL_FORM": "static void counterClockspiralPrint ( int m , int n , int arr [ ] [ ] ) {\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      System . out . print ( arr [ i ] [ l ] + \" \" ) ;\n      cnt ++ ;\n    }\n    l ++ ;\n    if ( cnt == total ) break ;\n    for ( i = l ;\n    i < n ;\n    ++ i ) {\n      System . out . print ( 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        System . out . print ( 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        System . out . print ( arr [ k ] [ i ] + \" \" ) ;\n        cnt ++ ;\n      }\n      k ++ ;\n    }\n  }\n}\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD": "static boolean 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": "static void printMinIndexChar ( String str , String patt ) {\n  int minIndex = Integer . MAX_VALUE ;\n  int m = str . length ( ) ;\n  int n = patt . length ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < m ;\n    j ++ ) {\n      if ( patt . charAt ( i ) == str . charAt ( j ) && j < minIndex ) {\n        minIndex = j ;\n        break ;\n      }\n    }\n  }\n  if ( minIndex != Integer . MAX_VALUE ) System . out . println ( \"Minimum Index Character = \" + str . charAt ( minIndex ) ) ;\n  else System . out . println ( \"No character present\" ) ;\n}\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX_1": "static void transpose ( int A [ ] [ ] , int B [ ] [ ] ) {\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": "static int countNumber ( int n ) {\n  int result = 0 ;\n  for ( int i = 1 ;\n  i <= 9 ;\n  i ++ ) {\n    Stack < Integer > s = new Stack < > ( ) ;\n    if ( i <= n ) {\n      s . push ( i ) ;\n      result ++ ;\n    }\n    while ( ! s . empty ( ) ) {\n      int tp = s . peek ( ) ;\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": "static 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": "static void printEqualSumSets ( int [ ] arr , int n ) {\n  int i , currSum , sum = 0 ;\n  for ( i = 0 ;\n  i < arr . length ;\n  i ++ ) sum += arr [ i ] ;\n  if ( ( sum & 1 ) == 1 ) {\n    System . out . print ( \"-1\" ) ;\n    return ;\n  }\n  int k = sum >> 1 ;\n  boolean [ ] [ ] dp = new boolean [ 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  List < Integer > set1 = new ArrayList < Integer > ( ) ;\n  List < Integer > set2 = new ArrayList < Integer > ( ) ;\n  if ( ! dp [ n ] [ k ] ) {\n    System . out . print ( \"-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 . add ( arr [ i ] ) ;\n    }\n    else if ( dp [ i - 1 ] [ currSum - arr [ i - 1 ] ] ) {\n      i -- ;\n      currSum -= arr [ i ] ;\n      set1 . add ( arr [ i ] ) ;\n    }\n  }\n  System . out . print ( \"Set 1 elements: \" ) ;\n  for ( i = 0 ;\n  i < set1 . size ( ) ;\n  i ++ ) System . out . print ( set1 . get ( i ) + \" \" ) ;\n  System . out . print ( \"\\nSet 2 elements: \" ) ;\n  for ( i = 0 ;\n  i < set2 . size ( ) ;\n  i ++ ) System . out . print ( set2 . get ( i ) + \" \" ) ;\n}\n", "COUNTING_PAIRS_PERSON_CAN_FORM_PAIR_ONE_1": "static int numberOfWays ( int x ) {\n  int dp [ ] = new int [ 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": "static int countNegative ( int M [ ] [ ] , 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": "static int countSetBits ( int n ) {\n  int count = 0 ;\n  while ( n > 0 ) {\n    count += n & 1 ;\n    n >>= 1 ;\n  }\n  return count ;\n}\n", "MODULUS_TWO_FLOAT_DOUBLE_NUMBERS": "static double findMod ( double a , double b ) {\n  if ( a < 0 ) a = - a ;\n  if ( b < 0 ) b = - b ;\n  double mod = a ;\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": "static int findMaxValue ( int N , int mat [ ] [ ] ) {\n  int maxValue = Integer . MIN_VALUE ;\n  int maxArr [ ] [ ] = new int [ 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 ] = Math . max ( mat [ i ] [ j ] , Math . max ( maxArr [ i ] [ j + 1 ] , maxArr [ i + 1 ] [ j ] ) ) ;\n    }\n  }\n  return maxValue ;\n}\n", "MINIMUM_SUM_TWO_NUMBERS_FORMED_DIGITS_ARRAY": "static int solve ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  int a = 0 , b = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( i % 2 != 0 ) 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": "static 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": "static 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": "static int octalToDecimal ( int n ) {\n  int num = n ;\n  int dec_value = 0 ;\n  int base = 1 ;\n  int temp = num ;\n  while ( temp > 0 ) {\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": "static void permutatedRows ( int mat [ ] [ ] , int m , int n , int r ) {\n  LinkedHashSet < Integer > s = new LinkedHashSet < > ( ) ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) s . add ( 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 . contains ( mat [ i ] [ j ] ) ) break ;\n    if ( j != n ) continue ;\n    System . out . print ( i + \", \" ) ;\n  }\n}\n", "PRINT_A_CLOSEST_STRING_THAT_DOES_NOT_CONTAIN_ADJACENT_DUPLICATES": "public static String noAdjacentDup ( String s1 ) {\n  int n = s1 . length ( ) ;\n  char [ ] s = s1 . toCharArray ( ) ;\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 ( new String ( s ) ) ;\n}\n", "SUM_MANHATTAN_DISTANCES_PAIRS_POINTS": "static 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 += ( Math . abs ( x [ i ] - x [ j ] ) + Math . abs ( y [ i ] - y [ j ] ) ) ;\n  return sum ;\n}\n", "PROGRAM_FIND_STRING_START_END_GEEKS": "static boolean isCornerPresent ( String str , String corner ) {\n  int n = str . length ( ) ;\n  int cl = corner . length ( ) ;\n  if ( n < cl ) return false ;\n  return ( str . substring ( 0 , cl ) . equals ( corner ) && str . substring ( n - cl , n ) . equals ( corner ) ) ;\n}\n", "LONGEST_SUBARRAY_COUNT_1S_ONE_COUNT_0S": "static int lenOfLongSubarr ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > um = new HashMap < Integer , Integer > ( ) ;\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 . containsKey ( sum ) ) um . put ( sum , i ) ;\n    if ( um . containsKey ( sum - 1 ) ) {\n      if ( maxLen < ( i - um . get ( sum - 1 ) ) ) maxLen = i - um . get ( sum - 1 ) ;\n    }\n  }\n  return maxLen ;\n}\n", "DIVIDE_CONQUER_SET_6_SEARCH_ROW_WISE_COLUMN_WISE_SORTED_2D_ARRAY": "public static void search ( int [ ] [ ] mat , 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 ) System . out . println ( \"Found \" + key + \" at \" + i + \" \" + j ) ;\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 ) System . out . println ( \"Found \" + key + \" at \" + fromRow + \" \" + toCol ) ;\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": "static int superSeq ( String X , String Y , int m , int n ) {\n  if ( m == 0 ) return n ;\n  if ( n == 0 ) return m ;\n  if ( X . charAt ( m - 1 ) == Y . charAt ( n - 1 ) ) return 1 + superSeq ( X , Y , m - 1 , n - 1 ) ;\n  return 1 + Math . min ( superSeq ( X , Y , m - 1 , n ) , superSeq ( X , Y , m , n - 1 ) ) ;\n}\n", "URLIFY_GIVEN_STRING_REPLACE_SPACES": "static char [ ] replaceSpaces ( char [ ] str ) {\n  int space_count = 0 , i = 0 ;\n  for ( i = 0 ;\n  i < str . length ;\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 ;\n  if ( new_length > MAX ) return str ;\n  int index = new_length - 1 ;\n  char [ ] new_str = str ;\n  str = new char [ new_length ] ;\n  for ( int j = i - 1 ;\n  j >= 0 ;\n  j -- ) {\n    if ( new_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 ] = new_str [ j ] ;\n      index -- ;\n    }\n  }\n  return str ;\n}\n", "MAXIMUM_PATH_SUM_STARTING_CELL_0_TH_ROW_ENDING_CELL_N_1_TH_ROW": "static int MaximumPath ( int Mat [ ] [ ] ) {\n  int result = 0 ;\n  int dp [ ] [ ] = new int [ N ] [ N + 2 ] ;\n  for ( int [ ] rows : dp ) Arrays . fill ( rows , 0 ) ;\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 ] = Math . max ( dp [ i - 1 ] [ j - 1 ] , Math . 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 = Math . max ( result , dp [ N - 1 ] [ i ] ) ;\n  return result ;\n}\n", "COMPUTE_THE_INTEGER_ABSOLUTE_VALUE_ABS_WITHOUT_BRANCHING": "static int getAbs ( int n ) {\n  int mask = n >> ( SIZE_INT * CHAR_BIT - 1 ) ;\n  return ( ( n + mask ) ^ mask ) ;\n}\n", "COUNT_PALINDROMIC_SUBSEQUENCE_GIVEN_STRING_1": "static 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 ( ( i - j == 1 ) || ( i - j == - 1 ) ) {\n    if ( str . charAt ( i ) == str . charAt ( 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 . charAt ( i ) == str . charAt ( 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": "static 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 = Math . max ( a [ i ] , curr_max + a [ i ] ) ;\n    max_so_far = Math . max ( max_so_far , curr_max ) ;\n  }\n  return max_so_far ;\n}\n", "COUNT_MINIMUM_STEPS_GET_GIVEN_DESIRED_ARRAY": "static int countMinOperations ( int n ) {\n  int result = 0 ;\n  while ( true ) {\n    int zero_count = 0 ;\n    int i ;\n    for ( i = 0 ;\n    i < n ;\n    i ++ ) {\n      if ( arr [ i ] % 2 == 1 ) break ;\n      else if ( arr [ 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 ++ ) arr [ j ] = arr [ j ] / 2 ;\n      result ++ ;\n    }\n    for ( int j = i ;\n    j < n ;\n    j ++ ) {\n      if ( arr [ j ] % 2 == 1 ) {\n        arr [ j ] -- ;\n        result ++ ;\n      }\n    }\n  }\n}\n", "PRINT_FIBONACCI_SEQUENCE_USING_2_VARIABLES_1": "static void fib ( int n ) {\n  int a = 0 , b = 1 ;\n  if ( n >= 0 ) System . out . print ( a + \" \" ) ;\n  if ( n >= 1 ) System . out . print ( b + \" \" ) ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) {\n    System . out . print ( a + b + \" \" ) ;\n    b = a + b ;\n    a = b - a ;\n  }\n}\n", "PROGRAM_CHECK_INPUT_INTEGER_STRING": "static boolean isNumber ( String s ) {\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) if ( Character . isDigit ( s . charAt ( i ) ) == false ) return false ;\n  return true ;\n}\n", "MINIMUM_HEIGHT_TRIANGLE_GIVEN_BASE_AREA": "static double minHeight ( double base , double area ) {\n  double d = ( 2 * area ) / base ;\n  return Math . ceil ( d ) ;\n}\n", "FIND_POSITION_GIVEN_NUMBER_AMONG_NUMBERS_MADE_4_7": "static int findpos ( String n ) {\n  int k = 0 , pos = 0 , i = 0 ;\n  while ( k != n . length ( ) ) {\n    switch ( n . charAt ( i ) ) {\n      case '4' : pos = pos * 2 + 1 ;\n      break ;\n      case '7' : pos = pos * 2 + 2 ;\n      break ;\n    }\n    i ++ ;\n    k ++ ;\n  }\n  return pos ;\n}\n", "MINIMUM_OPERATIONS_REQUIRED_SET_ELEMENTS_BINARY_MATRIX": "static int minOperation ( boolean arr [ ] [ ] ) {\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 ] == false ) {\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 ] == true ) {\n              arr [ k ] [ h ] = false ;\n            }\n            else {\n              arr [ k ] [ h ] = true ;\n            }\n          }\n        }\n      }\n    }\n  }\n  return ans ;\n}\n", "LONGEST_EVEN_LENGTH_SUBSTRING_SUM_FIRST_SECOND_HALF_2": "static int findLength ( String str , int n ) {\n  int sum [ ] = new int [ n + 1 ] ;\n  sum [ 0 ] = 0 ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) sum [ i ] = ( sum [ i - 1 ] + str . charAt ( 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 = Math . max ( ans , len ) ;\n    }\n  }\n  return ans ;\n}\n", "MULTIPLY_LARGE_NUMBERS_REPRESENTED_AS_STRINGS": "static String multiply ( String num1 , String num2 ) {\n  int len1 = num1 . length ( ) ;\n  int len2 = num2 . length ( ) ;\n  if ( len1 == 0 || len2 == 0 ) return \"0\" ;\n  int result [ ] = new int [ len1 + len2 ] ;\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 . charAt ( i ) - '0' ;\n    i_n2 = 0 ;\n    for ( int j = len2 - 1 ;\n    j >= 0 ;\n    j -- ) {\n      int n2 = num2 . charAt ( 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 . length - 1 ;\n  while ( i >= 0 && result [ i ] == 0 ) i -- ;\n  if ( i == - 1 ) return \"0\" ;\n  String s = \"\" ;\n  while ( i >= 0 ) s += ( result [ i -- ] ) ;\n  return s ;\n}\n", "PARTITION_NUMBER_TWO_DIVISBLE_PARTS": "static void findDivision ( String str , int a , int b ) {\n  int len = str . length ( ) ;\n  int [ ] lr = new int [ len + 1 ] ;\n  lr [ 0 ] = ( ( int ) str . charAt ( 0 ) - ( int ) '0' ) % a ;\n  for ( int i = 1 ;\n  i < len ;\n  i ++ ) lr [ i ] = ( ( lr [ i - 1 ] * 10 ) % a + ( ( int ) str . charAt ( i ) - ( int ) '0' ) ) % a ;\n  int [ ] rl = new int [ len + 1 ] ;\n  rl [ len - 1 ] = ( ( int ) str . charAt ( len - 1 ) - ( int ) '0' ) % b ;\n  int power10 = 10 ;\n  for ( int i = len - 2 ;\n  i >= 0 ;\n  i -- ) {\n    rl [ i ] = ( rl [ i + 1 ] + ( ( int ) str . charAt ( i ) - ( int ) '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      System . out . println ( \"YES\" ) ;\n      for ( int k = 0 ;\n      k <= i ;\n      k ++ ) System . out . print ( str . charAt ( k ) ) ;\n      System . out . print ( \", \" ) ;\n      for ( int k = i + 1 ;\n      k < len ;\n      k ++ ) System . out . print ( str . charAt ( k ) ) ;\n      return ;\n    }\n  }\n  System . out . println ( \"NO\" ) ;\n}\n", "PROGRAM_BEST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "static void bestFit ( int blockSize [ ] , int m , int processSize [ ] , int n ) {\n  int allocation [ ] = new int [ n ] ;\n  for ( int i = 0 ;\n  i < allocation . length ;\n  i ++ ) allocation [ i ] = - 1 ;\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  System . out . println ( \"\\nProcess No.\\tProcess Size\\tBlock no.\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( \"   \" + ( i + 1 ) + \"\\t\\t\" + processSize [ i ] + \"\\t\\t\" ) ;\n    if ( allocation [ i ] != - 1 ) System . out . print ( allocation [ i ] + 1 ) ;\n    else System . out . print ( \"Not Allocated\" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "FINDING_THE_MAXIMUM_SQUARE_SUB_MATRIX_WITH_ALL_EQUAL_ELEMENTS": "static int largestKSubmatrix ( int [ ] [ ] a ) {\n  int [ ] [ ] dp = new int [ Row ] [ Col ] ;\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 ] ) {\n          dp [ i ] [ j ] = ( dp [ i - 1 ] [ j ] > dp [ i ] [ j - 1 ] && dp [ i - 1 ] [ j ] > dp [ i - 1 ] [ j - 1 ] + 1 ) ? dp [ i - 1 ] [ j ] : ( dp [ i ] [ j - 1 ] > dp [ i - 1 ] [ j ] && dp [ i ] [ j - 1 ] > dp [ i - 1 ] [ j - 1 ] + 1 ) ? dp [ i ] [ j - 1 ] : dp [ i - 1 ] [ j - 1 ] + 1 ;\n        }\n        else dp [ i ] [ j ] = 1 ;\n      }\n      result = result > dp [ i ] [ j ] ? result : dp [ i ] [ j ] ;\n    }\n  }\n  return result ;\n}\n", "FRIENDS_PAIRING_PROBLEM_1": "static 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": "static int firstElement ( int arr [ ] , int n , int k ) {\n  HashMap < Integer , Integer > count_map = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int a = 0 ;\n    if ( count_map . get ( arr [ i ] ) != null ) {\n      a = count_map . get ( arr [ i ] ) ;\n    }\n    count_map . put ( arr [ i ] , a + 1 ) ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( count_map . get ( arr [ i ] ) == k ) {\n      return arr [ i ] ;\n    }\n  }\n  return - 1 ;\n}\n", "SUM_SERIES_0_6_0_06_0_006_0_0006_N_TERMS": "static double sumOfSeries ( int n ) {\n  return ( 0.666 ) * ( 1 - 1 / Math . pow ( 10 , n ) ) ;\n}\n", "COUNT_WORDS_IN_A_GIVEN_STRING": "static int countWords ( String str ) {\n  int state = OUT ;\n  int wc = 0 ;\n  int i = 0 ;\n  while ( i < str . length ( ) ) {\n    if ( str . charAt ( i ) == ' ' || str . charAt ( i ) == '\\n' || str . charAt ( i ) == '\\t' ) state = OUT ;\n    else if ( state == OUT ) {\n      state = IN ;\n      ++ wc ;\n    }\n    ++ i ;\n  }\n  return wc ;\n}\n", "PARTITION_INTO_TWO_SUBARRAYS_OF_LENGTHS_K_AND_N_K_SUCH_THAT_THE_DIFFERENCE_OF_SUMS_IS_MAXIMUM": "static 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  int temp ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) {\n    for ( int j = i + 1 ;\n    j < N ;\n    j ++ ) {\n      if ( arr [ i ] < arr [ j ] ) {\n        temp = arr [ i ] ;\n        arr [ i ] = arr [ j ] ;\n        arr [ j ] = temp ;\n      }\n    }\n  }\n  M = Math . 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": "static void printNos ( int n ) {\n  if ( n > 0 ) {\n    printNos ( n - 1 ) ;\n    System . out . print ( n + \" \" ) ;\n  }\n  return ;\n}\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM_1": "static 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": "static 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": "static int cassini ( int n ) {\n  return ( n & 1 ) != 0 ? - 1 : 1 ;\n}\n", "DISTRIBUTING_ALL_BALLS_WITHOUT_REPETITION": "static boolean distributingBalls ( long k , long n , String str ) {\n  int [ ] a = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    a [ str . charAt ( 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": "static boolean 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": "static int findMaxValue ( int [ ] arr , int n ) {\n  if ( n < 4 ) {\n    System . out . println ( \"The array should have\" + \" atleast 4 elements\" ) ;\n  }\n  int table1 [ ] = new int [ n + 1 ] ;\n  int table2 [ ] = new int [ n ] ;\n  int table3 [ ] = new int [ n - 1 ] ;\n  int table4 [ ] = new int [ n - 2 ] ;\n  Arrays . fill ( table1 , Integer . MIN_VALUE ) ;\n  Arrays . fill ( table2 , Integer . MIN_VALUE ) ;\n  Arrays . fill ( table3 , Integer . MIN_VALUE ) ;\n  Arrays . fill ( table4 , Integer . MIN_VALUE ) ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    table1 [ i ] = Math . max ( table1 [ i + 1 ] , arr [ i ] ) ;\n  }\n  for ( int i = n - 2 ;\n  i >= 0 ;\n  i -- ) {\n    table2 [ i ] = Math . max ( table2 [ i + 1 ] , table1 [ i + 1 ] - arr [ i ] ) ;\n  }\n  for ( int i = n - 3 ;\n  i >= 0 ;\n  i -- ) table3 [ i ] = Math . max ( table3 [ i + 1 ] , table2 [ i + 1 ] + arr [ i ] ) ;\n  for ( int i = n - 4 ;\n  i >= 0 ;\n  i -- ) table4 [ i ] = Math . 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": "static int countNegative ( int M [ ] [ ] , 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": "static void sort012 ( int a [ ] , int arr_size ) {\n  int lo = 0 ;\n  int hi = arr_size - 1 ;\n  int mid = 0 , temp = 0 ;\n  while ( mid <= hi ) {\n    switch ( a [ mid ] ) {\n      case 0 : {\n        temp = a [ lo ] ;\n        a [ lo ] = a [ mid ] ;\n        a [ mid ] = temp ;\n        lo ++ ;\n        mid ++ ;\n        break ;\n      }\n      case 1 : mid ++ ;\n      break ;\n      case 2 : {\n        temp = a [ mid ] ;\n        a [ mid ] = a [ hi ] ;\n        a [ hi ] = temp ;\n        hi -- ;\n        break ;\n      }\n    }\n  }\n}\n", "NTH_EVEN_FIBONACCI_NUMBER": "static long 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": "static 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    System . out . println ( arr [ i ] + \" -- \" + next ) ;\n  }\n}\n", "CHECK_WHETHER_GIVEN_CIRCLE_RESIDE_BOUNDARY_MAINTAINED_OUTER_CIRCLE_INNER_CIRCLE": "static void fitOrNotFit ( int R , int r , int x , int y , int rad ) {\n  double val = Math . sqrt ( Math . pow ( x , 2 ) + Math . pow ( y , 2 ) ) ;\n  if ( val + rad <= R && val - rad >= R - r ) System . out . println ( \"Fits\" ) ;\n  else System . out . println ( \"Doesn't Fit\" ) ;\n}\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS_1": "public static 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 = 1 , y1 = 1 ;\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": "static void findSmallestRange ( int arr [ ] [ ] , int n , int k ) {\n  int i , minval , maxval , minrange , minel = 0 , maxel = 0 , flag , minind ;\n  for ( i = 0 ;\n  i <= k ;\n  i ++ ) {\n    ptr [ i ] = 0 ;\n  }\n  minrange = Integer . MAX_VALUE ;\n  while ( true ) {\n    minind = - 1 ;\n    minval = Integer . MAX_VALUE ;\n    maxval = Integer . MIN_VALUE ;\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 == 1 ) {\n      break ;\n    }\n    ptr [ minind ] ++ ;\n    if ( ( maxval - minval ) < minrange ) {\n      minel = minval ;\n      maxel = maxval ;\n      minrange = maxel - minel ;\n    }\n  }\n  System . out . 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": "static int minCost ( int cost [ ] [ ] ) {\n  int dist [ ] = new int [ 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": "public static 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": "static boolean 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 . charAt ( i ) - '0' ) ;\n    else evenDigSum += ( str . charAt ( i ) - '0' ) ;\n  }\n  return ( ( oddDigSum - evenDigSum ) % 11 == 0 ) ;\n}\n", "COMPUTE_MODULUS_DIVISION_BY_A_POWER_OF_2_NUMBER": "static int getModulo ( int n , int d ) {\n  return ( n & ( d - 1 ) ) ;\n}\n", "COUNT_BINARY_STRINGS_K_TIMES_APPEARING_ADJACENT_TWO_SET_BITS": "static int countStrings ( int n , int k ) {\n  int dp [ ] [ ] [ ] = new int [ n + 1 ] [ k + 1 ] [ 2 ] ;\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 && j < k + 1 ;\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 ) {\n        dp [ i ] [ j ] [ 1 ] += dp [ i - 1 ] [ j - 1 ] [ 1 ] ;\n      }\n    }\n  }\n  return dp [ n ] [ k ] [ 0 ] + dp [ n ] [ k ] [ 1 ] ;\n}\n", "FINDING_K_MODULUS_ARRAY_ELEMENT": "static void printEqualModNumbers ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  int d = arr [ n - 1 ] - arr [ 0 ] ;\n  Vector < Integer > v = new Vector < > ( ) ;\n  for ( int i = 1 ;\n  i * i <= d ;\n  i ++ ) {\n    if ( d % i == 0 ) {\n      v . add ( i ) ;\n      if ( i != d / i ) v . add ( d / i ) ;\n    }\n  }\n  for ( int i = 0 ;\n  i < v . size ( ) ;\n  i ++ ) {\n    int temp = arr [ 0 ] % v . get ( i ) ;\n    int j ;\n    for ( j = 1 ;\n    j < n ;\n    j ++ ) if ( arr [ j ] % v . get ( i ) != temp ) break ;\n    if ( j == n ) System . out . print ( v . get ( i ) + \" \" ) ;\n  }\n}\n", "CIRCULAR_MATRIX_CONSTRUCT_A_MATRIX_WITH_NUMBERS_1_TO_MN_IN_SPIRAL_WAY": "static void spiralFill ( int m , int n , int a [ ] [ ] ) {\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 ) {\n      a [ k ] [ i ] = val ++ ;\n    }\n    k ++ ;\n    for ( int i = k ;\n    i < m ;\n    ++ i ) {\n      a [ i ] [ n - 1 ] = val ++ ;\n    }\n    n -- ;\n    if ( k < m ) {\n      for ( int i = n - 1 ;\n      i >= l ;\n      -- i ) {\n        a [ m - 1 ] [ i ] = val ++ ;\n      }\n      m -- ;\n    }\n    if ( l < n ) {\n      for ( int i = m - 1 ;\n      i >= k ;\n      -- i ) {\n        a [ i ] [ l ] = val ++ ;\n      }\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    int a = arr [ i ] & set_bit_no ;\n    if ( a != 0 ) x = x ^ arr [ i ] ;\n    else y = y ^ arr [ i ] ;\n  }\n  for ( i = 1 ;\n  i <= n ;\n  i ++ ) {\n    int a = i & set_bit_no ;\n    if ( a != 0 ) x = x ^ i ;\n    else y = y ^ i ;\n  }\n  System . out . println ( \"The two reppeated elements are :\" ) ;\n  System . out . println ( x + \" \" + y ) ;\n}\n", "COUNT_POSSIBLE_WAYS_TO_CONSTRUCT_BUILDINGS": "static 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": "static int factorial ( int n ) {\n  return ( n == 1 || n == 0 ) ? 1 : n * factorial ( n - 1 ) ;\n}\n", "CHECK_GIVEN_MATRIX_SPARSE_NOT": "static boolean isSparse ( int array [ ] [ ] , 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": "static 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": "static void findMinAvgSubarray ( 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  System . out . println ( \"Subarray between [\" + res_index + \", \" + ( res_index + k - 1 ) + \"] has minimum average\" ) ;\n}\n", "QUERIES_FOR_CHARACTERS_IN_A_REPEATED_STRING": "static void query ( String s , int i , int j ) {\n  int n = s . length ( ) ;\n  i %= n ;\n  j %= n ;\n  if ( s . charAt ( i ) == s . charAt ( j ) ) System . out . println ( \"Yes\" ) ;\n  else System . out . println ( \"No\" ) ;\n}\n", "A_PRODUCT_ARRAY_PUZZLE_1": "void productArray ( int arr [ ] , int n ) {\n  if ( n == 1 ) {\n    System . out . print ( \"0\" ) ;\n    return ;\n  }\n  int i , temp = 1 ;\n  int prod [ ] = new int [ n ] ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) prod [ j ] = 1 ;\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 ++ ) System . out . print ( prod [ i ] + \" \" ) ;\n  return ;\n}\n", "FIND_PAIRS_GIVEN_SUM_ELEMENTS_PAIR_DIFFERENT_ROWS": "static void pairSum ( int mat [ ] [ ] , int n , int sum ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) Arrays . sort ( mat [ i ] ) ;\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          System . out . print ( \"(\" + 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": "static boolean 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 . substring ( len - 2 , len ) + str2 . substring ( 0 , len - 2 ) ;\n  clock_rot = clock_rot + str2 . substring ( 2 ) + str2 . substring ( 0 , 2 ) ;\n  return ( str1 . equals ( clock_rot ) || str1 . equals ( anticlock_rot ) ) ;\n}\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN": "public static 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}\n", "PROGRAM_FIND_SLOPE_LINE": "static float slope ( float x1 , float y1 , float x2 , float y2 ) {\n  return ( y2 - y1 ) / ( x2 - x1 ) ;\n}\n", "GCD_ELEMENTS_GIVEN_RANGE": "static int rangeGCD ( int n , int m ) {\n  return ( n == m ) ? n : 1 ;\n}\n", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY_1": "static void alternateSubarray ( boolean arr [ ] , int n ) {\n  int count = 1 ;\n  boolean prev = arr [ 0 ] ;\n  for ( int i = 1 ;\n  i < n ;\n  ++ i ) {\n    if ( ( arr [ i ] ^ prev ) == false ) {\n      while ( count > 0 ) {\n        System . out . print ( count -- + \" \" ) ;\n      }\n    }\n    ++ count ;\n    prev = arr [ i ] ;\n  }\n  while ( count != 0 ) {\n    System . out . print ( count -- + \" \" ) ;\n  }\n}\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y": "static 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": "static long moduloMultiplication ( long a , long b , long mod ) {\n  long res = 0 ;\n  a %= mod ;\n  while ( b > 0 ) {\n    if ( ( b & 1 ) > 0 ) {\n      res = ( res + a ) % mod ;\n    }\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": "static void findSmallest ( int m , int s ) {\n  if ( s == 0 ) {\n    System . out . print ( m == 1 ? \"Smallest number is 0\" : \"Not possible\" ) ;\n    return ;\n  }\n  if ( s > 9 * m ) {\n    System . out . println ( \"Not possible\" ) ;\n    return ;\n  }\n  int [ ] res = new int [ 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  System . out . print ( \"Smallest number is \" ) ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) System . out . print ( res [ i ] ) ;\n}\n", "C_PROGRAM_FIND_LARGEST_ELEMENT_ARRAY": "static int largest ( ) {\n  int i ;\n  int max = arr [ 0 ] ;\n  for ( i = 1 ;\n  i < arr . length ;\n  i ++ ) if ( arr [ i ] > max ) max = arr [ i ] ;\n  return max ;\n}\n", "COUNT_NUMBERS_CAN_CONSTRUCTED_USING_TWO_NUMBERS": "static int countNums ( int n , int x , int y ) {\n  boolean [ ] arr = new boolean [ n + 1 ] ;\n  if ( x <= n ) arr [ x ] = true ;\n  if ( y <= n ) arr [ y ] = true ;\n  int result = 0 ;\n  for ( int i = Math . 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": "static void bubbleSort ( int arr [ ] , int n ) {\n  int i , j , temp ;\n  boolean 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        temp = arr [ j ] ;\n        arr [ j ] = arr [ j + 1 ] ;\n        arr [ j + 1 ] = temp ;\n        swapped = true ;\n      }\n    }\n    if ( swapped == false ) break ;\n  }\n}\n", "MAXIMUM_SUM_2_X_N_GRID_NO_TWO_ELEMENTS_ADJACENT": "public static int maxSum ( int grid [ ] [ ] , int n ) {\n  int incl = Math . 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 = Math . max ( excl , incl ) ;\n    incl = excl + Math . max ( grid [ 0 ] [ i ] , grid [ 1 ] [ i ] ) ;\n    excl = excl_new ;\n  }\n  return Math . max ( excl , incl ) ;\n}\n", "GCD_FACTORIALS_TWO_NUMBERS": "static int gcdOfFactorial ( int m , int n ) {\n  int min = m < n ? m : n ;\n  return factorial ( min ) ;\n}\n", "AREA_OF_A_SECTOR": "static void SectorArea ( double radius , double angle ) {\n  if ( angle >= 360 ) System . out . println ( \"Angle not possible\" ) ;\n  else {\n    double sector = ( ( 22 * radius * radius ) / 7 ) * ( angle / 360 ) ;\n    System . out . println ( sector ) ;\n  }\n}\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS_1": "static 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": "static int findLength ( String str ) {\n  int n = str . length ( ) ;\n  int maxlen = 0 ;\n  int sum [ ] [ ] = new int [ n ] [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum [ i ] [ i ] = str . charAt ( 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": "static int swapBits ( int x ) {\n  int even_bits = x & 0xAAAAAAAA ;\n  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  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i += 2 ) swap ( arr , i , i + 1 ) ;\n}\n", "FIND_HARMONIC_MEAN_USING_ARITHMETIC_MEAN_GEOMETRIC_MEAN": "static double compute ( int a , int b ) {\n  double AM , GM , HM ;\n  AM = ( a + b ) / 2 ;\n  GM = Math . sqrt ( a * b ) ;\n  HM = ( GM * GM ) / AM ;\n  return HM ;\n}\n", "COUNT_BALANCED_BINARY_TREES_HEIGHT_H": "public static long countBT ( int h ) {\n  long [ ] dp = new long [ h + 1 ] ;\n  dp [ 0 ] = 1 ;\n  dp [ 1 ] = 1 ;\n  for ( int i = 2 ;\n  i <= h ;\n  ++ i ) dp [ i ] = ( dp [ i - 1 ] * ( ( 2 * dp [ i - 2 ] ) % MOD + dp [ i - 1 ] ) % MOD ) % MOD ;\n  return dp [ h ] ;\n}\n", "MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME_WITH_PERMUTATIONS_ALLOWED": "static int minInsertion ( String str ) {\n  int n = str . length ( ) ;\n  int res = 0 ;\n  int [ ] count = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) count [ str . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < 26 ;\n  i ++ ) {\n    if ( count [ i ] % 2 == 1 ) res ++ ;\n  }\n  return ( res == 0 ) ? 0 : res - 1 ;\n}\n", "SHUFFLE_A_GIVEN_ARRAY": "static void randomize ( int arr [ ] , int n ) {\n  Random r = new Random ( ) ;\n  for ( int i = n - 1 ;\n  i > 0 ;\n  i -- ) {\n    int j = r . nextInt ( i + 1 ) ;\n    int temp = arr [ i ] ;\n    arr [ i ] = arr [ j ] ;\n    arr [ j ] = temp ;\n  }\n  System . out . println ( Arrays . toString ( arr ) ) ;\n}\n", "UGLY_NUMBERS": "int getNthUglyNo ( int n ) {\n  int ugly [ ] = new int [ n ] ;\n  int i2 = 0 , i3 = 0 , i5 = 0 ;\n  int next_multiple_of_2 = 2 ;\n  int next_multiple_of_3 = 3 ;\n  int next_multiple_of_5 = 5 ;\n  int next_ugly_no = 1 ;\n  ugly [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    next_ugly_no = Math . min ( next_multiple_of_2 , Math . 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": "static int minimumCostOfBreaking ( Integer X [ ] , Integer Y [ ] , int m , int n ) {\n  int res = 0 ;\n  Arrays . sort ( X , Collections . reverseOrder ( ) ) ;\n  Arrays . sort ( Y , Collections . reverseOrder ( ) ) ;\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": "static int knapSack ( int W , int wt [ ] , int val [ ] , int n ) {\n  int i , w ;\n  int K [ ] [ ] = new int [ 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": "static boolean checkStackPermutation ( int ip [ ] , int op [ ] , int n ) {\n  Queue < Integer > input = new LinkedList < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    input . add ( ip [ i ] ) ;\n  }\n  Queue < Integer > output = new LinkedList < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    output . add ( op [ i ] ) ;\n  }\n  Stack < Integer > tempStack = new Stack < > ( ) ;\n  while ( ! input . isEmpty ( ) ) {\n    int ele = input . poll ( ) ;\n    if ( ele == output . peek ( ) ) {\n      output . poll ( ) ;\n      while ( ! tempStack . isEmpty ( ) ) {\n        if ( tempStack . peek ( ) == output . peek ( ) ) {\n          tempStack . pop ( ) ;\n          output . poll ( ) ;\n        }\n        else break ;\n      }\n    }\n    else {\n      tempStack . push ( ele ) ;\n    }\n  }\n  return ( input . isEmpty ( ) && tempStack . isEmpty ( ) ) ;\n}\n", "PROBABILITY_THREE_RANDOMLY_CHOSEN_NUMBERS_AP": "static double procal ( int n ) {\n  return ( 3.0 * n ) / ( 4.0 * ( n * n ) - 1 ) ;\n}\n", "REMOVE_BRACKETS_ALGEBRAIC_STRING_CONTAINING_OPERATORS": "static String simplify ( String str ) {\n  int len = str . length ( ) ;\n  char res [ ] = new char [ len ] ;\n  int index = 0 , i = 0 ;\n  Stack < Integer > s = new Stack < Integer > ( ) ;\n  s . push ( 0 ) ;\n  while ( i < len ) {\n    if ( str . charAt ( i ) == '+' ) {\n      if ( s . peek ( ) == 1 ) res [ index ++ ] = '-' ;\n      if ( s . peek ( ) == 0 ) res [ index ++ ] = '+' ;\n    }\n    else if ( str . charAt ( i ) == '-' ) {\n      if ( s . peek ( ) == 1 ) res [ index ++ ] = '+' ;\n      else if ( s . peek ( ) == 0 ) res [ index ++ ] = '-' ;\n    }\n    else if ( str . charAt ( i ) == '(' && i > 0 ) {\n      if ( str . charAt ( i - 1 ) == '-' ) {\n        int x = ( s . peek ( ) == 1 ) ? 0 : 1 ;\n        s . push ( x ) ;\n      }\n      else if ( str . charAt ( i - 1 ) == '+' ) s . push ( s . peek ( ) ) ;\n    }\n    else if ( str . charAt ( i ) == ')' ) s . pop ( ) ;\n    else res [ index ++ ] = str . charAt ( i ) ;\n    i ++ ;\n  }\n  return new String ( res ) ;\n}\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS": "static 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": "static int minDiff ( int arr [ ] , int n , int k ) {\n  int result = Integer . MAX_VALUE ;\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i <= n - k ;\n  i ++ ) result = Math . min ( result , arr [ i + k - 1 ] - arr [ i ] ) ;\n  return result ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_13_NOT": "static boolean checkDivisibility ( String num ) {\n  int length = num . length ( ) ;\n  if ( length == 1 && num . charAt ( 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 . charAt ( i -- ) - '0' ;\n    group += ( num . charAt ( i -- ) - '0' ) * 10 ;\n    group += ( num . charAt ( i ) - '0' ) * 100 ;\n    sum = sum + group * p ;\n    p *= ( - 1 ) ;\n  }\n  sum = Math . abs ( sum ) ;\n  return ( sum % 13 == 0 ) ;\n}\n", "GIVEN_N_X_N_SQUARE_MATRIX_FIND_SUM_SUB_SQUARES_SIZE_K_X_K": "static void printSumSimple ( int mat [ ] [ ] , 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      System . out . print ( sum + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "FIND_THE_POINT_WHERE_MAXIMUM_INTERVALS_OVERLAP_1": "public static void maxOverlap ( int [ ] start , int [ ] end , int n ) {\n  int maxa = Arrays . stream ( start ) . max ( ) . getAsInt ( ) ;\n  int maxb = Arrays . stream ( end ) . max ( ) . getAsInt ( ) ;\n  int maxc = Math . max ( maxa , maxb ) ;\n  int [ ] x = new int [ maxc + 2 ] ;\n  Arrays . fill ( x , 0 ) ;\n  int cur = 0 , idx = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    ++ x [ start [ i ] ] ;\n    -- x [ end [ i ] + 1 ] ;\n  }\n  int maxy = Integer . MIN_VALUE ;\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  System . out . println ( \"Maximum value is:\" + maxy + \" at position: \" + idx + \"\" ) ;\n}\n", "MAXIMUM_SUBSEQUENCE_SUM_SUCH_THAT_NO_THREE_ARE_CONSECUTIVE_1": "static 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 ] = Math . max ( Math . 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": "static void add ( int A [ ] [ ] , int B [ ] [ ] , int C [ ] [ ] ) {\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": "static 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    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": "static void center ( int x1 , int x2 , int y1 , int y2 ) {\n  System . out . print ( ( float ) ( x1 + x2 ) / 2 + \", \" + ( float ) ( y1 + y2 ) / 2 ) ;\n}\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS": "static int countNonDecreasing ( int n ) {\n  int dp [ ] [ ] = new int [ 10 ] [ n + 1 ] ;\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  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": "static void replaceOriginal ( String s , int n ) {\n  char r [ ] = new char [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    r [ i ] = s . charAt ( n - 1 - i ) ;\n    if ( s . charAt ( i ) != 'a' && s . charAt ( i ) != 'e' && s . charAt ( i ) != 'i' && s . charAt ( i ) != 'o' && s . charAt ( i ) != 'u' ) {\n      System . out . print ( r [ i ] ) ;\n    }\n  }\n  System . out . println ( \"\" ) ;\n}\n", "FIND_ELEMENTS_PRESENT_FIRST_ARRAY_NOT_SECOND_1": "static void findMissing ( int a [ ] , int b [ ] , int n , int m ) {\n  HashSet < Integer > s = new HashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) s . add ( b [ i ] ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( ! s . contains ( a [ i ] ) ) System . out . print ( a [ i ] + \" \" ) ;\n}\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS": "static 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": "static int getMaxGold ( int gold [ ] [ ] , int m , int n ) {\n  int goldTable [ ] [ ] = new int [ m ] [ n ] ;\n  for ( int [ ] rows : goldTable ) Arrays . fill ( rows , 0 ) ;\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 ] + Math . max ( right , Math . max ( right_up , right_down ) ) ;\n      ;\n    }\n  }\n  int res = goldTable [ 0 ] [ 0 ] ;\n  for ( int i = 1 ;\n  i < m ;\n  i ++ ) res = Math . max ( res , goldTable [ i ] [ 0 ] ) ;\n  return res ;\n}\n", "COUNT_WAYS_BUILD_STREET_GIVEN_CONSTRAINTS": "static long countWays ( int n ) {\n  long dp [ ] [ ] = new long [ 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": "static void maxProduct ( int arr [ ] , int n ) {\n  if ( n < 2 ) {\n    System . out . println ( \"No pairs exists\" ) ;\n    return ;\n  }\n  if ( n == 2 ) {\n    System . out . println ( arr [ 0 ] + \" \" + arr [ 1 ] ) ;\n    return ;\n  }\n  int posa = Integer . MIN_VALUE , posb = Integer . MIN_VALUE ;\n  int nega = Integer . MIN_VALUE , negb = Integer . MIN_VALUE ;\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 && Math . abs ( arr [ i ] ) > Math . abs ( nega ) ) {\n      negb = nega ;\n      nega = arr [ i ] ;\n    }\n    else if ( arr [ i ] < 0 && Math . abs ( arr [ i ] ) > Math . abs ( negb ) ) negb = arr [ i ] ;\n  }\n  if ( nega * negb > posa * posb ) System . out . println ( \"Max product pair is {\n\" + nega + \", \" + negb + \"}\" ) ;\n    else System . out . println ( \"Max product pair is {\n\" + posa + \", \" + posb + \"}\" ) ;\n    }\n    ", "POSITION_OF_RIGHTMOST_SET_BIT": "public static int getFirstSetBitPos ( int n ) {\n  return ( int ) ( ( Math . log10 ( n & - n ) ) / Math . log10 ( 2 ) ) + 1 ;\n}\n", "LONGEST_SUBSEQUENCE_WHERE_EVERY_CHARACTER_APPEARS_AT_LEAST_K_TIMES": "static void longestSubseqWithK ( String str , int k ) {\n  int n = str . length ( ) ;\n  int freq [ ] = new int [ MAX_CHARS ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    freq [ str . charAt ( i ) - 'a' ] ++ ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( freq [ str . charAt ( i ) - 'a' ] >= k ) {\n      System . out . print ( str . charAt ( i ) ) ;\n    }\n  }\n}\n", "POSSIBLE_TO_MAKE_A_DIVISIBLE_BY_3_NUMBER_USING_ALL_DIGITS_IN_AN_ARRAY": "public static boolean 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": "static int find_Area ( int r ) {\n  return ( 2 * r * r ) ;\n}\n", "FIND_MAXIMUM_DOT_PRODUCT_TWO_ARRAYS_INSERTION_0S": "static int MaxDotProduct ( int A [ ] , int B [ ] , int m , int n ) {\n  int dp [ ] [ ] = new int [ n + 1 ] [ m + 1 ] ;\n  for ( int [ ] row : dp ) Arrays . fill ( row , 0 ) ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) for ( int j = i ;\n  j <= m ;\n  j ++ ) dp [ i ] [ j ] = Math . 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": "static void printDistSum ( int arr [ ] , int n ) {\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum += arr [ i ] ;\n  boolean [ ] [ ] dp = new boolean [ n + 1 ] [ sum + 1 ] ;\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 ) System . out . print ( j + \" \" ) ;\n}\n", "SPLIT_NUMERIC_ALPHABETIC_AND_SPECIAL_SYMBOLS_FROM_A_STRING": "static void splitString ( String str ) {\n  StringBuffer alpha = new StringBuffer ( ) , num = new StringBuffer ( ) , special = new StringBuffer ( ) ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( Character . isDigit ( str . charAt ( i ) ) ) num . append ( str . charAt ( i ) ) ;\n    else if ( Character . isAlphabetic ( str . charAt ( i ) ) ) alpha . append ( str . charAt ( i ) ) ;\n    else special . append ( str . charAt ( i ) ) ;\n  }\n  System . out . println ( alpha ) ;\n  System . out . println ( num ) ;\n  System . out . println ( special ) ;\n}\n", "MAXIMUM_SUM_ALTERNATING_SUBSEQUENCE_SUM": "static int maxAlternateSum ( int arr [ ] , int n ) {\n  if ( n == 1 ) return arr [ 0 ] ;\n  int dec [ ] = new int [ n ] ;\n  int inc [ ] = new int [ n ] ;\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 ] = Math . max ( dec [ i ] , inc [ j ] + arr [ i ] ) ;\n        flag = 1 ;\n      }\n      else if ( arr [ j ] < arr [ i ] && flag == 1 ) inc [ i ] = Math . max ( inc [ i ] , dec [ j ] + arr [ i ] ) ;\n    }\n  }\n  int result = Integer . MIN_VALUE ;\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": "public static int findMaxGCD ( int arr [ ] , int n ) {\n  int high = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) high = Math . max ( high , arr [ i ] ) ;\n  int divisors [ ] = new int [ high + 1 ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= Math . 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  return 1 ;\n}\n", "FIND_MINIMUM_NUMBER_OF_COINS_THAT_MAKE_A_CHANGE_1": "static int minCoins ( int coins [ ] , int m , int V ) {\n  int table [ ] = new int [ V + 1 ] ;\n  table [ 0 ] = 0 ;\n  for ( int i = 1 ;\n  i <= V ;\n  i ++ ) table [ i ] = Integer . MAX_VALUE ;\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 != Integer . MAX_VALUE && 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": "static 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 . charAt ( i ) == '(' ) level ++ ;\n    else if ( tree . charAt ( i ) == ')' ) level -- ;\n    else {\n      if ( level == k ) sum += ( tree . charAt ( 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": "static boolean checkSentence ( char [ ] str ) {\n  int len = str . length ;\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 ( index <= str . length ) {\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 ( index + 1 == str . length ) ;\n    index ++ ;\n    prev_state = curr_state ;\n  }\n  return false ;\n}\n", "CHECK_DIVISIBILITY_LARGE_NUMBER_999": "static boolean isDivisible999 ( String num ) {\n  int n = num . length ( ) ;\n  if ( n == 0 && num . charAt ( 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 . charAt ( i ++ ) - '0' ) * 100 ;\n    group += ( num . charAt ( i ++ ) - '0' ) * 10 ;\n    group += num . charAt ( i ) - '0' ;\n    gSum += group ;\n  }\n  if ( gSum > 1000 ) {\n    num = Integer . toString ( gSum ) ;\n    n = num . length ( ) ;\n    gSum = isDivisible999 ( num ) ? 1 : 0 ;\n  }\n  return ( gSum == 999 ) ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_9_NOT": "static boolean check ( String str ) {\n  int n = str . length ( ) ;\n  int digitSum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) digitSum += ( str . charAt ( i ) - '0' ) ;\n  return ( digitSum % 9 == 0 ) ;\n}\n", "NUMBER_OF_BINARY_TREES_FOR_GIVEN_PREORDER_SEQUENCE_LENGTH": "static int countTrees ( int n ) {\n  int BT [ ] = new int [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) BT [ i ] = 0 ;\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": "static void swapUpperToLower ( int arr [ ] [ ] ) {\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 ++ ) System . out . print ( arr [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER_1": "static 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": "static int xorZero ( String s ) {\n  int one_count = 0 , zero_count = 0 ;\n  char [ ] str = s . toCharArray ( ) ;\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": "static 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": "static int minSum ( int [ ] arr , int n ) {\n  int [ ] dp = new int [ n ] ;\n  if ( n == 1 ) return arr [ 0 ] ;\n  if ( n == 2 ) return Math . min ( arr [ 0 ] , arr [ 1 ] ) ;\n  if ( n == 3 ) return Math . min ( arr [ 0 ] , Math . min ( arr [ 1 ] , arr [ 2 ] ) ) ;\n  if ( n == 4 ) return Math . min ( Math . min ( arr [ 0 ] , arr [ 1 ] ) , Math . 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 ] + Math . min ( Math . min ( dp [ i - 1 ] , dp [ i - 2 ] ) , Math . min ( dp [ i - 3 ] , dp [ i - 4 ] ) ) ;\n  return Math . min ( Math . min ( dp [ n - 1 ] , dp [ n - 2 ] ) , Math . min ( dp [ n - 4 ] , dp [ n - 3 ] ) ) ;\n}\n", "MAXIMUM_PATH_SUM_TRIANGLE": "static int maxPathSum ( int tri [ ] [ ] , 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": "static boolean 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": "static int fib ( int n , int a , int b ) {\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": "static boolean isLucky ( int n ) {\n  boolean arr [ ] = new boolean [ 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": "static void printSumTricky ( int mat [ ] [ ] , int k ) {\n  if ( k > n ) return ;\n  int stripSum [ ] [ ] = new int [ 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    System . out . print ( 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      System . out . print ( sum + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "SCHEDULE_ELEVATOR_TO_REDUCE_THE_TOTAL_TIME_TAKEN": "static int minTime ( int n , int k , int a [ ] ) {\n  int temp ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( int j = i + 1 ;\n    j < n ;\n    j ++ ) {\n      if ( a [ i ] < a [ j ] ) {\n        temp = a [ i ] ;\n        a [ i ] = a [ j ] ;\n        a [ j ] = temp ;\n      }\n    }\n  }\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": "public static void oddEvenSort ( int arr [ ] , int n ) {\n  boolean isSorted = false ;\n  while ( ! isSorted ) {\n    isSorted = true ;\n    int temp = 0 ;\n    for ( int i = 1 ;\n    i <= n - 2 ;\n    i = i + 2 ) {\n      if ( arr [ i ] > arr [ i + 1 ] ) {\n        temp = arr [ i ] ;\n        arr [ i ] = arr [ i + 1 ] ;\n        arr [ i + 1 ] = temp ;\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        temp = arr [ i ] ;\n        arr [ i ] = arr [ i + 1 ] ;\n        arr [ i + 1 ] = temp ;\n        isSorted = false ;\n      }\n    }\n  }\n  return ;\n}\n", "RETURN_MAXIMUM_OCCURRING_CHARACTER_IN_THE_INPUT_STRING": "static char getMaxOccuringChar ( String str ) {\n  int count [ ] = new int [ ASCII_SIZE ] ;\n  int len = str . length ( ) ;\n  for ( int i = 0 ;\n  i < len ;\n  i ++ ) count [ str . charAt ( i ) ] ++ ;\n  int max = - 1 ;\n  char result = ' ' ;\n  for ( int i = 0 ;\n  i < len ;\n  i ++ ) {\n    if ( max < count [ str . charAt ( i ) ] ) {\n      max = count [ str . charAt ( i ) ] ;\n      result = str . charAt ( i ) ;\n    }\n  }\n  return result ;\n}\n", "COUNT_NUMBER_PAIRS_N_B_N_GCD_B_B": "static 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": "static int printKDistinct ( int arr [ ] , int n , int k ) {\n  Map < Integer , Integer > h = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( h . containsKey ( arr [ i ] ) ) h . put ( arr [ i ] , h . get ( arr [ i ] ) + 1 ) ;\n    else h . put ( arr [ i ] , 1 ) ;\n  }\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 . get ( 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": "static void generate ( int ones , int zeroes , String str , int len ) {\n  if ( len == str . length ( ) ) {\n    System . out . print ( str + \" \" ) ;\n    return ;\n  }\n  generate ( ones + 1 , zeroes , str + \"1\" , len ) ;\n  if ( ones > zeroes ) {\n    generate ( ones , zeroes + 1 , str + \"0\" , len ) ;\n  }\n}\n", "SEARCH_INSERT_AND_DELETE_IN_AN_UNSORTED_ARRAY": "static int findElement ( int arr [ ] , int n , int key ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( arr [ i ] == key ) return i ;\n  return - 1 ;\n}\n", "LCS_LONGEST_COMMON_SUBSEQUENCE_THREE_STRINGS": "static int lcsOf3 ( String X , String Y , String Z , int m , int n , int o ) {\n  int [ ] [ ] [ ] L = new int [ 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 . charAt ( i - 1 ) == Y . charAt ( j - 1 ) && X . charAt ( i - 1 ) == Z . charAt ( k - 1 ) ) L [ i ] [ j ] [ k ] = L [ i - 1 ] [ j - 1 ] [ k - 1 ] + 1 ;\n        else L [ i ] [ j ] [ k ] = Math . max ( Math . 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": "static int maxSumSubarrayRemovingOneEle ( int arr [ ] , int n ) {\n  int fw [ ] = new int [ n ] ;\n  int bw [ ] = new int [ 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 = Math . max ( arr [ i ] , cur_max + arr [ i ] ) ;\n    max_so_far = Math . 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 = Math . max ( arr [ i ] , cur_max + arr [ i ] ) ;\n    max_so_far = Math . 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 = Math . 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": "static int countWays ( int n , int m ) {\n  int count [ ] = new int [ n + 1 ] ;\n  count [ 0 ] = 0 ;\n  int i ;\n  for ( 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": "public static 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": "static int LCIS ( int arr1 [ ] , int n , int arr2 [ ] , int m ) {\n  int table [ ] = new int [ 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": "static int maxSumWO3Consec ( int arr [ ] , int n ) {\n  int sum [ ] = new int [ 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 ] = Math . max ( sum [ 1 ] , Math . max ( arr [ 1 ] + arr [ 2 ] , arr [ 0 ] + arr [ 2 ] ) ) ;\n  for ( int i = 3 ;\n  i < n ;\n  i ++ ) sum [ i ] = Math . max ( Math . 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": "public static int eulerian ( int n , int m ) {\n  int [ ] [ ] dp = new int [ n + 1 ] [ m + 1 ] ;\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": "static long doublefactorial ( long n ) {\n  if ( n == 0 || n == 1 ) return 1 ;\n  return n * doublefactorial ( n - 2 ) ;\n}\n", "REARRANGE_POSITIVE_AND_NEGATIVE_NUMBERS_PUBLISH": "static void rearrange ( int arr [ ] , int n ) {\n  int i = - 1 , temp = 0 ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) {\n    if ( arr [ j ] < 0 ) {\n      i ++ ;\n      temp = arr [ i ] ;\n      arr [ i ] = arr [ j ] ;\n      arr [ j ] = temp ;\n    }\n  }\n  int pos = i + 1 , neg = 0 ;\n  while ( pos < n && neg < pos && arr [ neg ] < 0 ) {\n    temp = arr [ neg ] ;\n    arr [ neg ] = arr [ pos ] ;\n    arr [ pos ] = temp ;\n    pos ++ ;\n    neg += 2 ;\n  }\n}\n", "MAXIMIZE_ARRAY_SUN_AFTER_K_NEGATION_OPERATIONS": "static int maximumSum ( int arr [ ] , int n , int k ) {\n  for ( int i = 1 ;\n  i <= k ;\n  i ++ ) {\n    int min = + 2147483647 ;\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": "static int pre_compute ( int a [ ] , int n , int index , int k ) {\n  int dp [ ] [ ] = new int [ n ] [ n ] ;\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": "static void myCopy ( char s1 [ ] , char s2 [ ] ) {\n  int i = 0 ;\n  for ( i = 0 ;\n  i < s1 . length ;\n  i ++ ) s2 [ i ] = s1 [ i ] ;\n}\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND_1": "static boolean isSubSequence ( String str1 , String str2 , int m , int n ) {\n  int j = 0 ;\n  for ( int i = 0 ;\n  i < n && j < m ;\n  i ++ ) if ( str1 . charAt ( j ) == str2 . charAt ( i ) ) j ++ ;\n  return ( j == m ) ;\n}\n", "FIND_UNIT_DIGIT_X_RAISED_POWER_Y_1": "static int unitnumber ( int x , int y ) {\n  x = x % 10 ;\n  if ( y != 0 ) y = y % 4 + 4 ;\n  return ( ( ( int ) ( Math . pow ( x , y ) ) ) % 10 ) ;\n}\n", "PROGRAM_NEXT_FIT_ALGORITHM_MEMORY_MANAGEMENT": "static void NextFit ( int blockSize [ ] , int m , int processSize [ ] , int n ) {\n  int allocation [ ] = new int [ n ] , j = 0 ;\n  Arrays . fill ( allocation , - 1 ) ;\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  System . out . print ( \"\\nProcess No.\\tProcess Size\\tBlock no.\\n\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( i + 1 + \"\\t\\t\" + processSize [ i ] + \"\\t\\t\" ) ;\n    if ( allocation [ i ] != - 1 ) {\n      System . out . print ( allocation [ i ] + 1 ) ;\n    }\n    else {\n      System . out . print ( \"Not Allocated\" ) ;\n    }\n    System . out . println ( \"\" ) ;\n  }\n}\n", "NOBLE_INTEGERS_IN_AN_ARRAY_COUNT_OF_GREATER_ELEMENTS_IS_EQUAL_TO_VALUE": "public static int nobleInteger ( int arr [ ] ) {\n  int size = arr . length ;\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": "static int minimumflip ( int mat [ ] [ ] , int n ) {\n  int transpose [ ] [ ] = new int [ 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": "static void arrayEvenAndOdd ( int arr [ ] , int n ) {\n  int i = - 1 , j = 0 ;\n  while ( j != n ) {\n    if ( arr [ j ] % 2 == 0 ) {\n      i ++ ;\n      int temp = arr [ i ] ;\n      arr [ i ] = arr [ j ] ;\n      arr [ j ] = temp ;\n    }\n    j ++ ;\n  }\n  for ( int k = 0 ;\n  k < n ;\n  k ++ ) System . out . print ( arr [ k ] + \" \" ) ;\n}\n", "DFS_N_ARY_TREE_ACYCLIC_GRAPH_REPRESENTED_ADJACENCY_LIST": "public static void dfs ( LinkedList < Integer > list [ ] , int node , int arrival ) {\n  System . out . println ( node ) ;\n  for ( int i = 0 ;\n  i < list [ node ] . size ( ) ;\n  i ++ ) {\n    if ( list [ node ] . get ( i ) != arrival ) dfs ( list , list [ node ] . get ( i ) , node ) ;\n  }\n}\n", "HOW_TO_TURN_OFF_A_PARTICULAR_BIT_IN_A_NUMBER": "static 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": "static int count ( String s , int len ) {\n  int MAX = 1000 ;\n  int cur = 0 , dig = 0 ;\n  int [ ] sum = new int [ MAX ] ;\n  int [ ] [ ] dp = new int [ MAX ] [ 3 ] ;\n  dp [ 0 ] [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i <= len ;\n  i ++ ) {\n    dig = ( int ) ( s . charAt ( 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 . charAt ( i - 1 ) ) - 48 ;\n    if ( dig == 8 ) ans ++ ;\n    if ( i - 2 >= 0 ) {\n      dprev = ( int ) ( s . charAt ( 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 . charAt ( i - 3 ) ) - 48 ;\n      dprev = ( int ) ( s . charAt ( 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": "static int addOne ( int x ) {\n  return ( - ( ~ x ) ) ;\n}\n", "CHECK_STRING_FOLLOWS_ANBN_PATTERN_NOT": "public static boolean isAnBn ( String s ) {\n  int l = s . length ( ) ;\n  if ( l % 2 == 1 ) {\n    return false ;\n  }\n  int i = 0 ;\n  int j = l - 1 ;\n  while ( i < j ) {\n    if ( s . charAt ( i ) != 'a' || s . charAt ( j ) != 'b' ) {\n      return false ;\n    }\n    i ++ ;\n    j -- ;\n  }\n  return true ;\n}\n", "FIND_FIRST_REPEATING_ELEMENT_ARRAY_INTEGERS": "static void printFirstRepeating ( int arr [ ] ) {\n  int min = - 1 ;\n  HashSet < Integer > set = new HashSet < > ( ) ;\n  for ( int i = arr . length - 1 ;\n  i >= 0 ;\n  i -- ) {\n    if ( set . contains ( arr [ i ] ) ) min = i ;\n    else set . add ( arr [ i ] ) ;\n  }\n  if ( min != - 1 ) System . out . println ( \"The first repeating element is \" + arr [ min ] ) ;\n  else System . out . println ( \"There are no repeating elements\" ) ;\n}\n", "COST_BALANCE_PARANTHESES": "static int costToBalance ( String s ) {\n  if ( s . length ( ) == 0 ) System . out . println ( 0 ) ;\n  int ans = 0 ;\n  int o = 0 , c = 0 ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    if ( s . charAt ( i ) == '(' ) o ++ ;\n    if ( s . charAt ( i ) == ')' ) c ++ ;\n  }\n  if ( o != c ) return - 1 ;\n  int [ ] a = new int [ s . length ( ) ] ;\n  if ( s . charAt ( 0 ) == '(' ) a [ 0 ] = 1 ;\n  else a [ 0 ] = - 1 ;\n  if ( a [ 0 ] < 0 ) ans += Math . abs ( a [ 0 ] ) ;\n  for ( int i = 1 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    if ( s . charAt ( i ) == '(' ) a [ i ] = a [ i - 1 ] + 1 ;\n    else a [ i ] = a [ i - 1 ] - 1 ;\n    if ( a [ i ] < 0 ) ans += Math . abs ( a [ i ] ) ;\n  }\n  return ans ;\n}\n", "COIN_GAME_WINNER_EVERY_PLAYER_THREE_CHOICES": "static boolean findWinner ( int x , int y , int n ) {\n  boolean [ ] dp = new boolean [ n + 1 ] ;\n  Arrays . fill ( dp , false ) ;\n  dp [ 0 ] = false ;\n  dp [ 1 ] = true ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) {\n    if ( i - 1 >= 0 && dp [ i - 1 ] == false ) dp [ i ] = true ;\n    else if ( i - x >= 0 && dp [ i - x ] == false ) dp [ i ] = true ;\n    else if ( i - y >= 0 && dp [ i - y ] == false ) dp [ i ] = true ;\n    else dp [ i ] = false ;\n  }\n  return dp [ n ] ;\n}\n", "SEQUENCES_GIVEN_LENGTH_EVERY_ELEMENT_EQUAL_TWICE_PREVIOUS": "static 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": "private static void printDuplicates ( int [ ] arr , int n ) {\n  Map < Integer , Integer > map = new HashMap < > ( ) ;\n  int count = 0 ;\n  boolean dup = false ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( map . containsKey ( arr [ i ] ) ) {\n      count = map . get ( arr [ i ] ) ;\n      map . put ( arr [ i ] , count + 1 ) ;\n    }\n    else {\n      map . put ( arr [ i ] , 1 ) ;\n    }\n  }\n  for ( Entry < Integer , Integer > entry : map . entrySet ( ) ) {\n    if ( entry . getValue ( ) > 1 ) {\n      System . out . print ( entry . getKey ( ) + \" \" ) ;\n      dup = true ;\n    }\n  }\n  if ( ! dup ) {\n    System . out . println ( \"-1\" ) ;\n  }\n}\n", "LONGEST_REPEATING_SUBSEQUENCE_1": "static int findLongestRepeatingSubSeq ( char X [ ] , int m , int n ) {\n  if ( dp [ m ] [ n ] != - 1 ) {\n    return dp [ m ] [ n ] ;\n  }\n  if ( m == 0 || n == 0 ) {\n    return dp [ m ] [ n ] = 0 ;\n  }\n  if ( X [ m - 1 ] == X [ n - 1 ] && m != n ) {\n    return dp [ m ] [ n ] = findLongestRepeatingSubSeq ( X , m - 1 , n - 1 ) + 1 ;\n  }\n  return dp [ m ] [ n ] = Math . 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": "private static void findCount ( int n , int sum ) {\n  int start = ( int ) Math . pow ( 10 , n - 1 ) ;\n  int end = ( int ) Math . 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  System . out . println ( count ) ;\n}\n", "MINIMUM_COST_CONNECT_WEIGHTED_NODES_REPRESENTED_ARRAY": "static int minimum_cost ( int a [ ] , int n ) {\n  int mn = Integer . MAX_VALUE ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    mn = Math . 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": "static void printDivisors ( int n ) {\n  Vector < Integer > v = new Vector < > ( ) ;\n  for ( int i = 1 ;\n  i <= Math . sqrt ( n ) ;\n  i ++ ) {\n    if ( n % i == 0 ) {\n      if ( n / i == i ) System . out . printf ( \"%d \" , i ) ;\n      else {\n        System . out . printf ( \"%d \" , i ) ;\n        v . add ( n / i ) ;\n      }\n    }\n  }\n  for ( int i = v . size ( ) - 1 ;\n  i >= 0 ;\n  i -- ) System . out . printf ( \"%d \" , v . get ( i ) ) ;\n}\n", "SQUARES_OF_MATRIX_DIAGONAL_ELEMENTS_1": "static void diagonalsquare ( int mat [ ] [ ] , int row , int column ) {\n  System . out . print ( \" Diagonal one : \" ) ;\n  for ( int i = 0 ;\n  i < row ;\n  i ++ ) {\n    System . out . print ( mat [ i ] [ i ] * mat [ i ] [ i ] + \" \" ) ;\n  }\n  System . out . println ( ) ;\n  System . out . print ( \" Diagonal two : \" ) ;\n  for ( int i = 0 ;\n  i < row ;\n  i ++ ) {\n    System . out . print ( mat [ i ] [ row - i - 1 ] * mat [ i ] [ row - i - 1 ] + \" \" ) ;\n  }\n}\n", "C_PROGRAM_FIND_AREA_TRIANGLE_1": "static 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 Math . abs ( area / 2.0 ) ;\n}\n", "RANGE_QUERIES_FOR_FREQUENCIES_OF_ARRAY_ELEMENTS": "public static 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": "static void print_sequence ( int n , int k ) {\n  int b = n / ( k * ( k + 1 ) / 2 ) ;\n  if ( b == 0 ) {\n    System . out . println ( \"-1\" ) ;\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 ++ ) System . out . print ( r * i + \" \" ) ;\n    int res = n - ( r * ( k * ( k - 1 ) / 2 ) ) ;\n    System . out . println ( res ) ;\n  }\n}\n", "FIND_THREE_ELEMENT_FROM_DIFFERENT_THREE_ARRAYS_SUCH_THAT_THAT_A_B_C_K_1": "static boolean findTriplet ( int a1 [ ] , int a2 [ ] , int a3 [ ] , int n1 , int n2 , int n3 , int sum ) {\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n1 ;\n  i ++ ) {\n    s . add ( a1 [ i ] ) ;\n  }\n  ArrayList < Integer > al = new ArrayList < > ( s ) ;\n  for ( int i = 0 ;\n  i < n2 ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < n3 ;\n    j ++ ) {\n      if ( al . contains ( sum - a2 [ i ] - a3 [ j ] ) & al . indexOf ( sum - a2 [ i ] - a3 [ j ] ) != al . get ( al . size ( ) - 1 ) ) {\n        return true ;\n      }\n    }\n  }\n  return false ;\n}\n", "FIND_THE_MAXIMUM_ELEMENT_IN_AN_ARRAY_WHICH_IS_FIRST_INCREASING_AND_THEN_DECREASING_1": "static 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": "static int power ( int x , int y , int p ) {\n  int res = 1 ;\n  x = x % p ;\n  while ( y > 0 ) {\n    if ( ( y & 1 ) == 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": "static boolean isPowerOfTwo ( int x ) {\n  return x != 0 && ( ( x & ( x - 1 ) ) == 0 ) ;\n}\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_PERMUTATIONS_ALLOWED": "static void longestString ( String str1 , String str2 ) {\n  int count1 [ ] = new int [ 26 ] , count2 [ ] = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < str1 . length ( ) ;\n  i ++ ) {\n    count1 [ str1 . charAt ( i ) - 'a' ] ++ ;\n  }\n  for ( int i = 0 ;\n  i < str2 . length ( ) ;\n  i ++ ) {\n    count2 [ str2 . charAt ( i ) - 'a' ] ++ ;\n  }\n  String result = \"\" ;\n  for ( int i = 0 ;\n  i < 26 ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= Math . min ( count1 [ i ] , count2 [ i ] ) ;\n    j ++ ) {\n      result += ( char ) ( 'a' + i ) ;\n    }\n  }\n  System . out . println ( result ) ;\n}\n", "DIFFERENCE_MAXIMUM_SUM_MINIMUM_SUM_N_M_ELEMENTSIN_REVIEW": "static int find_difference ( int arr [ ] , int n , int m ) {\n  int max = 0 , min = 0 ;\n  Arrays . sort ( arr ) ;\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": "private static String printNumbers ( int [ ] numbers ) {\n  ArrayList < Integer > array = new ArrayList < > ( ) ;\n  for ( int number : numbers ) {\n    if ( findContainsOneTwoThree ( number ) ) array . add ( number ) ;\n  }\n  Collections . sort ( array ) ;\n  StringBuffer strbuf = new StringBuffer ( ) ;\n  Iterator it = array . iterator ( ) ;\n  while ( it . hasNext ( ) ) {\n    int value = ( int ) it . next ( ) ;\n    if ( strbuf . length ( ) > 0 ) strbuf . append ( \", \" ) ;\n    strbuf . append ( Integer . toString ( value ) ) ;\n  }\n  return ( strbuf . length ( ) > 0 ) ? strbuf . toString ( ) : \"-1\" ;\n}\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE": "static int lis ( int arr [ ] , int n ) {\n  max_ref = 1 ;\n  _lis ( arr , n ) ;\n  return max_ref ;\n}\n", "MINIMUM_REVOLUTIONS_MOVE_CENTER_CIRCLE_TARGET": "static double minRevolutions ( double r , int x1 , int y1 , int x2 , int y2 ) {\n  double d = Math . sqrt ( ( x1 - x2 ) * ( x1 - x2 ) + ( y1 - y2 ) * ( y1 - y2 ) ) ;\n  return Math . ceil ( d / ( 2 * r ) ) ;\n}\n", "CHECK_TWO_GIVEN_SETS_DISJOINT": "boolean aredisjoint ( int set1 [ ] , int set2 [ ] ) {\n  for ( int i = 0 ;\n  i < set1 . length ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < set2 . length ;\n    j ++ ) {\n      if ( set1 [ i ] == set2 [ j ] ) return false ;\n    }\n  }\n  return true ;\n}\n", "FIND_MINIMUM_SUM_FACTORS_NUMBER": "static 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": "static int mostFrequent ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  int max_count = 1 , res = arr [ 0 ] ;\n  int 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": "static int minXOR ( int arr [ ] , int n ) {\n  Arrays . parallelSort ( arr ) ;\n  int minXor = Integer . MAX_VALUE ;\n  int val = 0 ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    val = arr [ i ] ^ arr [ i + 1 ] ;\n    minXor = Math . min ( minXor , val ) ;\n  }\n  return minXor ;\n}\n", "MINIMUM_SUM_PRODUCT_TWO_ARRAYS": "static int minproduct ( int a [ ] , int b [ ] , int n , int k ) {\n  int diff = 0 , res = 0 ;\n  int temp = 0 ;\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 = Math . 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": "static int russianPeasant ( int a , int b ) {\n  int res = 0 ;\n  while ( b > 0 ) {\n    if ( ( b & 1 ) != 0 ) res = res + a ;\n    a = a << 1 ;\n    b = b >> 1 ;\n  }\n  return res ;\n}\n", "DIVISIBILITY_9_USING_BITWISE_OPERATORS": "static boolean 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": "static boolean isInorder ( int [ ] arr , int n ) {\n  if ( n == 0 || n == 1 ) {\n    return true ;\n  }\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( arr [ i - 1 ] > arr [ i ] ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X": "static 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 ) System . out . println ( arr1 [ i ] + \" \" + arr2 [ j ] ) ;\n}\n", "BINARY_REPRESENTATION_OF_NEXT_NUMBER": "static String nextGreater ( String num ) {\n  int l = num . length ( ) ;\n  int i ;\n  for ( i = l - 1 ;\n  i >= 0 ;\n  i -- ) {\n    if ( num . charAt ( i ) == '0' ) {\n      num = num . substring ( 0 , i ) + '1' + num . substring ( i + 1 ) ;\n      break ;\n    }\n    else {\n      num = num . substring ( 0 , i ) + '0' + num . substring ( i + 1 ) ;\n    }\n  }\n  if ( i < 0 ) {\n    num = \"1\" + num ;\n  }\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 = 0 ;\n  int endindex = 0 ;\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      if ( arr [ j ] == 0 ) sum += - 1 ;\n      else sum += 1 ;\n      if ( sum == 0 && maxsize < j - i + 1 ) {\n        maxsize = j - i + 1 ;\n        startindex = i ;\n      }\n    }\n  }\n  endindex = startindex + maxsize - 1 ;\n  if ( maxsize == - 1 ) System . out . println ( \"No such subarray\" ) ;\n  else System . out . println ( startindex + \" to \" + endindex ) ;\n  return maxsize ;\n}\n", "COUNT_PAIRS_WHOSE_PRODUCTS_EXIST_IN_ARRAY_1": "static int countPairs ( int arr [ ] , int n ) {\n  int result = 0 ;\n  HashSet < Integer > Hash = new HashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    Hash . add ( arr [ i ] ) ;\n  }\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 . contains ( product ) ) {\n        result ++ ;\n      }\n    }\n  }\n  return result ;\n}\n", "DYNAMIC_PROGRAMMING_SET_12_LONGEST_PALINDROMIC_SUBSEQUENCE": "static int lps ( String seq ) {\n  int n = seq . length ( ) ;\n  int i , j , cl ;\n  int L [ ] [ ] = new int [ 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 ( seq . charAt ( i ) == seq . charAt ( j ) && cl == 2 ) L [ i ] [ j ] = 2 ;\n      else if ( seq . charAt ( i ) == seq . charAt ( 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 = 0 ;\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": "static boolean isDivisibleBy10 ( String bin ) {\n  int n = bin . length ( ) ;\n  if ( bin . charAt ( n - 1 ) == '1' ) return false ;\n  int sum = 0 ;\n  for ( int i = n - 2 ;\n  i >= 0 ;\n  i -- ) {\n    if ( bin . charAt ( 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": "static boolean isSubset ( int arr1 [ ] , int arr2 [ ] , int m , int n ) {\n  int i = 0 , j = 0 ;\n  if ( m < n ) return false ;\n  Arrays . sort ( arr1 ) ;\n  Arrays . sort ( arr2 ) ;\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 false ;\n  }\n  if ( i < n ) return false ;\n  else return true ;\n}\n", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM_1": "static boolean isSubsetSum ( int set [ ] , int n , int sum ) {\n  boolean subset [ ] [ ] = new boolean [ sum + 1 ] [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) subset [ 0 ] [ i ] = true ;\n  for ( int i = 1 ;\n  i <= sum ;\n  i ++ ) subset [ i ] [ 0 ] = false ;\n  for ( int i = 1 ;\n  i <= sum ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= n ;\n    j ++ ) {\n      subset [ i ] [ j ] = subset [ i ] [ j - 1 ] ;\n      if ( i >= set [ j - 1 ] ) subset [ i ] [ j ] = subset [ i ] [ j ] || subset [ i - set [ j - 1 ] ] [ j - 1 ] ;\n    }\n  }\n  return subset [ sum ] [ n ] ;\n}\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS_1": "public static int kthgroupsum ( int k ) {\n  return k * k * k ;\n}\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS": "static void thirdLargest ( int arr [ ] , int arr_size ) {\n  if ( arr_size < 3 ) {\n    System . out . 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 = Integer . MIN_VALUE ;\n  for ( int i = 0 ;\n  i < arr_size ;\n  i ++ ) if ( arr [ i ] > second && arr [ i ] < first ) second = arr [ i ] ;\n  int third = Integer . MIN_VALUE ;\n  for ( int i = 0 ;\n  i < arr_size ;\n  i ++ ) if ( arr [ i ] > third && arr [ i ] < second ) third = arr [ i ] ;\n  System . out . printf ( \"The third Largest \" + \"element is %d\\n\" , third ) ;\n}\n", "FIND_SUM_NODES_GIVEN_PERFECT_BINARY_TREE_1": "static double sumNodes ( int l ) {\n  double leafNodeCount = Math . pow ( 2 , l - 1 ) ;\n  double sumLastLevel = 0 ;\n  sumLastLevel = ( leafNodeCount * ( leafNodeCount + 1 ) ) / 2 ;\n  double sum = sumLastLevel * l ;\n  return sum ;\n}\n", "MIDDLE_OF_THREE_USING_MINIMUM_COMPARISONS_2": "public static 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": "static int maxTripletSum ( int arr [ ] , int n ) {\n  int maxA = - 100000000 , maxB = - 100000000 ;\n  int maxC = - 100000000 ;\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": "static int countPairs ( int arr1 [ ] , int arr2 [ ] , int m , int n , int x ) {\n  int count = 0 ;\n  HashSet < Integer > us = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) us . add ( arr1 [ i ] ) ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) if ( us . contains ( x - arr2 [ j ] ) ) count ++ ;\n  return count ;\n}\n", "MINIMUM_STEPS_REACH_END_ARRAY_CONSTRAINTS": "static int getMinStepToReachEnd ( int arr [ ] , int N ) {\n  boolean [ ] visit = new boolean [ N ] ;\n  int [ ] distance = new int [ N ] ;\n  Vector < Integer > [ ] digit = new Vector [ 10 ] ;\n  for ( int i = 0 ;\n  i < 10 ;\n  i ++ ) digit [ i ] = new Vector < > ( ) ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) visit [ i ] = false ;\n  for ( int i = 1 ;\n  i < N ;\n  i ++ ) digit [ arr [ i ] ] . add ( i ) ;\n  distance [ 0 ] = 0 ;\n  visit [ 0 ] = true ;\n  Queue < Integer > q = new LinkedList < > ( ) ;\n  q . add ( 0 ) ;\n  while ( ! q . isEmpty ( ) ) {\n    int idx = q . peek ( ) ;\n    q . remove ( ) ;\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 ] . get ( i ) ;\n      if ( ! visit [ nextidx ] ) {\n        visit [ nextidx ] = true ;\n        q . add ( 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 . add ( 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 . add ( idx + 1 ) ;\n      distance [ idx + 1 ] = distance [ idx ] + 1 ;\n    }\n  }\n  return distance [ N - 1 ] ;\n}\n", "LEXICOGRAPHICALLY_SMALLEST_ARRAY_K_CONSECUTIVE_SWAPS": "static 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    int temp ;\n    for ( int j = pos ;\n    j > i ;\n    -- j ) {\n      temp = arr [ j ] ;\n      arr [ j ] = arr [ j - 1 ] ;\n      arr [ j - 1 ] = temp ;\n    }\n    k -= pos - i ;\n  }\n}\n", "CONVERT_SENTENCE_EQUIVALENT_MOBILE_NUMERIC_KEYPAD_SEQUENCE": "static 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 . charAt ( i ) == ' ' ) output = output + \"0\" ;\n    else {\n      int position = input . charAt ( i ) - 'A' ;\n      output = output + arr [ position ] ;\n    }\n  }\n  return output ;\n}\n", "PROGRAM_CHECK_ARRAY_SORTED_NOT_ITERATIVE_RECURSIVE": "static 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": "static 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": "static int nextPowerOf2 ( 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": "static 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": "public static boolean check ( String s ) {\n  if ( s . length ( ) >= 10 ) return true ;\n  for ( int i = 1 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    for ( int j = i + 1 ;\n    j < s . length ( ) ;\n    j ++ ) {\n      for ( int k = j + 1 ;\n      k < s . length ( ) ;\n      k ++ ) {\n        String s1 = \"\" , s2 = \"\" , s3 = \"\" , s4 = \"\" ;\n        try {\n          s1 = s . substring ( 0 , i ) ;\n          s2 = s . substring ( i , j - i ) ;\n          s3 = s . substring ( j , k - j ) ;\n          s4 = s . substring ( k , s . length ( ) - k ) ;\n        }\n        catch ( StringIndexOutOfBoundsException e ) {\n        }\n        if ( strcheck ( s1 , s2 ) && strcheck ( s1 , s3 ) && strcheck ( s1 , s4 ) && strcheck ( s2 , s3 ) && strcheck ( s2 , s4 ) && strcheck ( s3 , s4 ) ) return true ;\n      }\n    }\n  }\n  return false ;\n}\n", "PERMUTE_TWO_ARRAYS_SUM_EVERY_PAIR_GREATER_EQUAL_K": "static boolean isPossible ( Integer a [ ] , int b [ ] , int n , int k ) {\n  Arrays . sort ( a , Collections . reverseOrder ( ) ) ;\n  Arrays . sort ( b ) ;\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": "static 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 == 1 ) times = 1 ;\n    }\n    else times += 1 ;\n    if ( times >= k ) return best ;\n  }\n  return best ;\n}\n", "DIRECTION_LAST_SQUARE_BLOCK": "static void direction ( int R , int C ) {\n  if ( R != C && R % 2 == 0 && C % 2 != 0 && R < C ) {\n    System . out . println ( \"Left\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 == 0 && R > C ) {\n    System . out . println ( \"Up\" ) ;\n    return ;\n  }\n  if ( R == C && R % 2 != 0 && C % 2 != 0 ) {\n    System . out . println ( \"Right\" ) ;\n    return ;\n  }\n  if ( R == C && R % 2 == 0 && C % 2 == 0 ) {\n    System . out . println ( \"Left\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 != 0 && R < C ) {\n    System . out . println ( \"Right\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 != 0 && R > C ) {\n    System . out . println ( \"Down\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 == 0 && R < C ) {\n    System . out . println ( \"Left\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 == 0 && R > C ) {\n    System . out . println ( \"Up\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 == 0 && C % 2 != 0 && R > C ) {\n    System . out . println ( \"Down\" ) ;\n    return ;\n  }\n  if ( R != C && R % 2 != 0 && C % 2 == 0 && R < C ) {\n    System . out . println ( \"Right\" ) ;\n    return ;\n  }\n}\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N": "static 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": "static void swapDiagonal ( int matrix [ ] [ ] ) {\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) {\n    int temp = matrix [ i ] [ i ] ;\n    matrix [ i ] [ i ] = matrix [ i ] [ N - i - 1 ] ;\n    matrix [ i ] [ N - i - 1 ] = temp ;\n  }\n}\n", "MINIMUM_OPERATIONS_MAKE_GCD_ARRAY_MULTIPLE_K": "static 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 + Math . 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": "static int maxDecimalValue ( int mat [ ] [ ] , int i , int j , int p ) {\n  if ( i >= N || j >= N ) {\n    return 0 ;\n  }\n  int result = Math . max ( maxDecimalValue ( mat , i , j + 1 , p + 1 ) , maxDecimalValue ( mat , i + 1 , j , p + 1 ) ) ;\n  if ( mat [ i ] [ j ] == 1 ) {\n    return ( int ) ( Math . pow ( 2 , p ) + result ) ;\n  }\n  else {\n    return result ;\n  }\n}\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE_1": "static long squareRoot ( int n ) {\n  int x = n ;\n  int y = 1 ;\n  while ( x > y ) {\n    x = ( x + y ) / 2 ;\n    y = n / x ;\n  }\n  return ( long ) x ;\n}\n", "FIND_MINIMUM_SHIFT_LONGEST_COMMON_PREFIX": "static void KMP ( int m , int n , String str2 , String str1 ) {\n  int pos = 0 , len = 0 ;\n  int [ ] p = new int [ m + 1 ] ;\n  int k = 0 ;\n  char [ ] ch1 = str1 . toCharArray ( ) ;\n  char [ ] ch2 = str2 . toCharArray ( ) ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) {\n    while ( k > 0 && ch1 [ k ] != ch1 [ i - 1 ] ) k = p [ k ] ;\n    if ( ch1 [ k ] == ch1 [ i - 1 ] ) ++ k ;\n    p [ i ] = k ;\n  }\n  for ( int j = 0 , i = 0 ;\n  i < m ;\n  i ++ ) {\n    while ( j > 0 && j < n && ch1 [ j ] != ch2 [ i ] ) j = p [ j ] ;\n    if ( j < n && ch1 [ j ] == ch2 [ i ] ) j ++ ;\n    if ( j > len ) {\n      len = j ;\n      pos = i - j + 1 ;\n    }\n  }\n  System . out . println ( \"Shift = \" + pos ) ;\n  System . out . println ( \"Prefix = \" + str1 . substring ( 0 , len ) ) ;\n}\n", "SORTED_ORDER_PRINTING_OF_AN_ARRAY_THAT_REPRESENTS_A_BST": "private static void printSorted ( int [ ] arr , int start , int end ) {\n  if ( start > end ) return ;\n  printSorted ( arr , start * 2 + 1 , end ) ;\n  System . out . print ( arr [ start ] + \" \" ) ;\n  printSorted ( arr , start * 2 + 2 , end ) ;\n}\n", "CHECK_WHETHER_GIVEN_DEGREES_VERTICES_REPRESENT_GRAPH_TREE": "static boolean check ( int degree [ ] , int n ) {\n  int deg_sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    deg_sum += degree [ i ] ;\n  }\n  return ( 2 * ( n - 1 ) == deg_sum ) ;\n}\n", "MOVE_ZEROES_END_ARRAY": "static 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": "static 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": "static int sumOfLargePrimeFactor ( int n ) {\n  int prime [ ] = new int [ n + 1 ] , sum = 0 ;\n  Arrays . fill ( prime , 0 ) ;\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 ] != 0 ) sum += prime [ p ] ;\n    else sum += p ;\n  }\n  return sum ;\n}\n", "REARRANGE_A_STRING_IN_SORTED_ORDER_FOLLOWED_BY_THE_INTEGER_SUM": "static String arrangeString ( String str ) {\n  int char_count [ ] = new int [ MAX_CHAR ] ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( Character . isUpperCase ( str . charAt ( i ) ) ) char_count [ str . charAt ( i ) - 'A' ] ++ ;\n    else sum = sum + ( str . charAt ( 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 ] -- != 0 ) res = res + ch ;\n  }\n  if ( sum > 0 ) res = res + sum ;\n  return res ;\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_1": "static int numberOfPaths ( int m , int n ) {\n  int count [ ] [ ] = new int [ 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": "static int editDistDP ( String str1 , String str2 , int m , int n ) {\n  int dp [ ] [ ] = new int [ 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 . charAt ( i - 1 ) == str2 . charAt ( 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": "static 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": "static 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    int t = a [ small ] ;\n    a [ small ] = a [ index ] ;\n    a [ index ] = t ;\n    minheapify ( a , small ) ;\n  }\n}\n", "SEARCHING_FOR_PATTERNS_SET_2_KMP_ALGORITHM": "void computeLPSArray ( String pat , int M , int lps [ ] ) {\n  int len = 0 ;\n  int i = 1 ;\n  lps [ 0 ] = 0 ;\n  while ( i < M ) {\n    if ( pat . charAt ( i ) == pat . charAt ( 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 ] = len ;\n        i ++ ;\n      }\n    }\n  }\n}\n", "FIND_MINIMUM_DIFFERENCE_PAIR": "static int findMinDiff ( int [ ] arr , int n ) {\n  int diff = Integer . MAX_VALUE ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) for ( int j = i + 1 ;\n  j < n ;\n  j ++ ) if ( Math . abs ( ( arr [ i ] - arr [ j ] ) ) < diff ) diff = Math . abs ( ( arr [ i ] - arr [ j ] ) ) ;\n  return diff ;\n}\n", "PRINT_FIRST_K_DIGITS_1N_N_POSITIVE_INTEGER": "static void print ( int n , int k ) {\n  int rem = 1 ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) {\n    System . out . print ( ( 10 * rem ) / n ) ;\n    rem = ( 10 * rem ) % n ;\n  }\n}\n", "GROUP_MULTIPLE_OCCURRENCE_OF_ARRAY_ELEMENTS_ORDERED_BY_FIRST_OCCURRENCE": "static void groupElements ( int arr [ ] , int n ) {\n  boolean visited [ ] = new boolean [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    visited [ i ] = false ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! visited [ i ] ) {\n      System . out . print ( arr [ i ] + \" \" ) ;\n      for ( int j = i + 1 ;\n      j < n ;\n      j ++ ) {\n        if ( arr [ i ] == arr [ j ] ) {\n          System . out . print ( arr [ i ] + \" \" ) ;\n          visited [ j ] = true ;\n        }\n      }\n    }\n  }\n}\n", "CHECK_WHETHER_ARITHMETIC_PROGRESSION_CAN_FORMED_GIVEN_ARRAY": "static boolean checkIsAP ( int arr [ ] , int n ) {\n  if ( n == 1 ) return true ;\n  Arrays . sort ( arr ) ;\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": "public static int findPosition ( int k , int n ) {\n  long f1 = 0 , f2 = 1 , f3 ;\n  int i = 2 ;\n  while ( i != 0 ) {\n    f3 = f1 + f2 ;\n    f1 = f2 ;\n    f2 = f3 ;\n    if ( f2 % k == 0 ) {\n      return n * i ;\n    }\n    i ++ ;\n  }\n  return 0 ;\n}\n", "COUNT_PAIRS_DIFFERENCE_EQUAL_K_1": "static int countPairsWithDiffK ( int arr [ ] , int n , int k ) {\n  int count = 0 ;\n  Arrays . sort ( arr ) ;\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": "static int countNum ( int [ ] arr , int n ) {\n  int count = 0 ;\n  Arrays . sort ( arr ) ;\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": "static String maximumPalinUsingKChanges ( String str , int k ) {\n  char palin [ ] = str . toCharArray ( ) ;\n  String ans = \"\" ;\n  int l = 0 ;\n  int r = str . length ( ) - 1 ;\n  while ( l < r ) {\n    if ( str . charAt ( l ) != str . charAt ( r ) ) {\n      palin [ l ] = palin [ r ] = ( char ) Math . max ( str . charAt ( l ) , str . charAt ( r ) ) ;\n      k -- ;\n    }\n    l ++ ;\n    r -- ;\n  }\n  if ( k < 0 ) {\n    return \"Not possible\" ;\n  }\n  l = 0 ;\n  r = str . length ( ) - 1 ;\n  while ( l <= r ) {\n    if ( l == r ) {\n      if ( k > 0 ) {\n        palin [ l ] = '9' ;\n      }\n    }\n    if ( palin [ l ] < '9' ) {\n      if ( k >= 2 && palin [ l ] == str . charAt ( l ) && palin [ r ] == str . charAt ( r ) ) {\n        k -= 2 ;\n        palin [ l ] = palin [ r ] = '9' ;\n      }\n      else if ( k >= 1 && ( palin [ l ] != str . charAt ( l ) || palin [ r ] != str . charAt ( r ) ) ) {\n        k -- ;\n        palin [ l ] = palin [ r ] = '9' ;\n      }\n    }\n    l ++ ;\n    r -- ;\n  }\n  for ( int i = 0 ;\n  i < palin . length ;\n  i ++ ) ans += palin [ i ] ;\n  return ans ;\n}\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM": "static void subArray ( 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 ++ ) System . out . print ( arr [ k ] + \" \" ) ;\n    }\n  }\n}\n", "MAXIMUM_SUM_INCREASING_ORDER_ELEMENTS_N_ARRAYS": "static int maximumSum ( int a [ ] [ ] , int n ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sort ( a , i , n ) ;\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": "static int factorial ( int n ) {\n  if ( n == 0 ) return 1 ;\n  return n * factorial ( n - 1 ) ;\n}\n", "PRINT_SQUARES_FIRST_N_NATURAL_NUMBERS_WITHOUT_USING": "static 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    System . out . print ( square + \" \" ) ;\n    prev_x = x ;\n  }\n}\n", "ROPES_DATA_STRUCTURE_FAST_STRING_CONCATENATION": "static void concatenate ( char a [ ] , char b [ ] , char c [ ] , int n1 , int n2 ) {\n  int i ;\n  for ( i = 0 ;\n  i < n1 ;\n  i ++ ) {\n    c [ i ] = a [ i ] ;\n  }\n  for ( int j = 0 ;\n  j < n2 ;\n  j ++ ) {\n    c [ i ++ ] = b [ j ] ;\n  }\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 = Integer . MAX_VALUE ;\n  int res_l = 0 , res_r = 0 ;\n  int l = 0 , r = n - 1 ;\n  while ( l < m && r >= 0 ) {\n    if ( Math . abs ( ar1 [ l ] + ar2 [ r ] - x ) < diff ) {\n      res_l = l ;\n      res_r = r ;\n      diff = Math . abs ( ar1 [ l ] + ar2 [ r ] - x ) ;\n    }\n    if ( ar1 [ l ] + ar2 [ r ] > x ) r -- ;\n    else l ++ ;\n  }\n  System . out . print ( \"The closest pair is [\" + ar1 [ res_l ] + \", \" + ar2 [ res_r ] + \"]\" ) ;\n}\n", "CONVERT_STRICTLY_INCREASING_ARRAY_MINIMUM_CHANGES": "static int minRemove ( int arr [ ] , int n ) {\n  int LIS [ ] = new int [ n ] ;\n  int 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 ] ) ) LIS [ i ] = Math . max ( LIS [ i ] , LIS [ j ] + 1 ) ;\n    }\n    len = Math . max ( len , LIS [ i ] ) ;\n  }\n  return n - len ;\n}\n", "TAIL_RECURSION": "static int fact ( int n ) {\n  if ( n == 0 ) return 1 ;\n  return n * fact ( n - 1 ) ;\n}\n", "RECURSIVE_FUNCTIONS": "static void tower ( int n , char sourcePole , char destinationPole , char auxiliaryPole ) {\n  if ( 0 == n ) return ;\n  tower ( n - 1 , sourcePole , auxiliaryPole , destinationPole ) ;\n  System . out . printf ( \"Move the disk %d from %c to %c\\n\" , n , sourcePole , destinationPole ) ;\n  tower ( n - 1 , auxiliaryPole , destinationPole , sourcePole ) ;\n}\n", "FIND_X_Y_SATISFYING_AX_N": "static 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      System . out . println ( \"x = \" + i + \", y = \" + ( n - ( i * a ) ) / b ) ;\n      return ;\n    }\n  }\n  System . out . println ( \"No solution\" ) ;\n}\n", "EXPONENTIAL_SQUARING_FAST_MODULO_MULTIPLICATION_1": "static 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": "static boolean checkIfAllTogether ( String s , char c ) {\n  boolean oneSeen = false ;\n  int i = 0 , n = s . length ( ) ;\n  while ( i < n ) {\n    if ( s . charAt ( i ) == c ) {\n      if ( oneSeen == true ) return false ;\n      while ( i < n && s . charAt ( i ) == c ) i ++ ;\n      oneSeen = true ;\n    }\n    else i ++ ;\n  }\n  return true ;\n}\n", "MAXIMUM_AREA_RECTANGLE_PICKING_FOUR_SIDES_ARRAY": "static int findArea ( Integer arr [ ] , int n ) {\n  Arrays . sort ( arr , Collections . reverseOrder ( ) ) ;\n  int [ ] dimension = {\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": "public static 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      int temp = item ;\n      item = arr [ pos ] ;\n      arr [ pos ] = temp ;\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        int temp = item ;\n        item = arr [ pos ] ;\n        arr [ pos ] = temp ;\n        writes ++ ;\n      }\n    }\n  }\n}\n", "SELECT_A_RANDOM_NUMBER_FROM_STREAM_WITH_O1_SPACE": "static int selectRandom ( int x ) {\n  count ++ ;\n  if ( count == 1 ) res = x ;\n  else {\n    Random r = new Random ( ) ;\n    int i = r . nextInt ( count ) ;\n    if ( i == count - 1 ) res = x ;\n  }\n  return res ;\n}\n", "HOSOYAS_TRIANGLE": "static void printHosoya ( int n ) {\n  int dp [ ] [ ] = new int [ N ] [ N ] ;\n  dp [ 0 ] [ 0 ] = dp [ 1 ] [ 0 ] = 1 ;\n  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 ++ ) System . out . print ( dp [ i ] [ j ] + \"\" ) ;\n    System . out . println ( \"\" ) ;\n  }\n}\n", "DISTRIBUTING_M_ITEMS_CIRCLE_SIZE_N_STARTING_K_TH_POSITION": "static 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": "public static void longestSubsequence ( int [ ] a , int n ) {\n  HashMap < Integer , Integer > mp = new HashMap < > ( ) ;\n  int [ ] dp = new int [ n ] ;\n  int maximum = Integer . MIN_VALUE ;\n  int index = - 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( mp . get ( a [ i ] - 1 ) != null ) {\n      int lastIndex = mp . get ( a [ i ] - 1 ) - 1 ;\n      dp [ i ] = 1 + dp [ lastIndex ] ;\n    }\n    else dp [ i ] = 1 ;\n    mp . put ( 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 ++ ) System . out . print ( curr + \" \" ) ;\n}\n", "NUMBER_OF_TRIANGLES_IN_DIRECTED_AND_UNDIRECTED_GRAPHS": "int countTriangle ( int graph [ ] [ ] , boolean 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 ] == 1 && graph [ j ] [ k ] == 1 && graph [ k ] [ i ] == 1 ) count_Triangle ++ ;\n      }\n    }\n  }\n  if ( isDirected == true ) {\n    count_Triangle /= 3 ;\n  }\n  else {\n    count_Triangle /= 6 ;\n  }\n  return count_Triangle ;\n}\n", "CHECK_GIVEN_ARRAY_CONTAINS_DUPLICATE_ELEMENTS_WITHIN_K_DISTANCE": "static boolean checkDuplicatesWithinK ( int arr [ ] , int k ) {\n  HashSet < Integer > set = new HashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    if ( set . contains ( arr [ i ] ) ) return true ;\n    set . add ( arr [ i ] ) ;\n    if ( i >= k ) set . remove ( arr [ i - k ] ) ;\n  }\n  return false ;\n}\n", "MINIMUM_INSERTIONS_SORT_ARRAY": "static int minInsertionStepToSortArray ( int arr [ ] , int N ) {\n  int [ ] lis = new int [ 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": "static void printDuo ( String str ) {\n  int countChar [ ] = new int [ MAX_CHAR ] ;\n  int n = str . length ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    countChar [ str . charAt ( i ) - 'a' ] ++ ;\n  }\n  String str1 = \"\" , str2 = \"\" ;\n  for ( int i = 0 ;\n  i < MAX_CHAR ;\n  i ++ ) {\n    if ( countChar [ i ] > 1 ) {\n      str2 = str2 + ( char ) ( i + 'a' ) ;\n    }\n    else if ( countChar [ i ] == 1 ) {\n      str1 = str1 + ( char ) ( i + 'a' ) ;\n    }\n  }\n  System . out . print ( \"String with characters occurring \" + \"once:\\n\" ) ;\n  System . out . print ( str1 + \"\\n\" ) ;\n  System . out . print ( \"String with characters occurring \" + \"multiple times:\\n\" ) ;\n  System . out . print ( str2 + \"\\n\" ) ;\n  System . out . print ( \"\" ) ;\n}\n", "NUMBER_DIGITS_PRODUCT_TWO_NUMBERS_1": "public static int countDigits ( int a , int b ) {\n  if ( a == 0 || b == 0 ) return 1 ;\n  return ( int ) Math . floor ( Math . log10 ( Math . abs ( a ) ) + Math . log10 ( Math . abs ( b ) ) ) + 1 ;\n}\n", "TOTAL_NUMBER_OF_NON_DECREASING_NUMBERS_WITH_N_DIGITS_1": "static long countNonDecreasing ( int n ) {\n  int N = 10 ;\n  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": "static long countStrs ( int n ) {\n  long [ ] [ ] dp = new long [ n + 1 ] [ 27 ] ;\n  for ( int i = 0 ;\n  i < n + 1 ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < 27 ;\n    j ++ ) {\n      dp [ i ] [ j ] = 0 ;\n    }\n  }\n  for ( int i = 0 ;\n  i <= 25 ;\n  i ++ ) {\n    dp [ 1 ] [ i ] = 1 ;\n  }\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j <= 25 ;\n    j ++ ) {\n      if ( j == 0 ) {\n        dp [ i ] [ j ] = dp [ i - 1 ] [ j + 1 ] ;\n      }\n      else {\n        dp [ i ] [ j ] = ( dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] ) ;\n      }\n    }\n  }\n  long sum = 0 ;\n  for ( int i = 0 ;\n  i <= 25 ;\n  i ++ ) {\n    sum = ( sum + dp [ n ] [ i ] ) ;\n  }\n  return sum ;\n}\n", "PROGRAM_TO_EFFICIENTLY_CALCULATE_EX": "static float exponential ( int n , float x ) {\n  float sum = 1 ;\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": "static void printDiagonalSums ( int [ ] [ ] mat , 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  System . out . println ( \"Principal Diagonal:\" + principal ) ;\n  System . out . println ( \"Secondary Diagonal:\" + secondary ) ;\n}\n", "PRINT_WAYS_BREAK_STRING_BRACKET_FORM": "static void findCombinations ( String str , int index , String out ) {\n  if ( index == str . length ( ) ) System . out . println ( out ) ;\n  for ( int i = index ;\n  i < str . length ( ) ;\n  i ++ ) findCombinations ( str , i + 1 , out + \"(\" + str . substring ( index , i + 1 ) + \")\" ) ;\n}\n", "LINEAR_SEARCH": "public static int search ( int arr [ ] , int x ) {\n  int n = arr . length ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( arr [ i ] == x ) return i ;\n  }\n  return - 1 ;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_2": "static int singleNumber ( int a [ ] , int n ) {\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( int i : a ) {\n    s . add ( i ) ;\n  }\n  int arr_sum = 0 ;\n  for ( int i : a ) {\n    arr_sum += i ;\n  }\n  int set_sum = 0 ;\n  for ( int i : s ) {\n    set_sum += i ;\n  }\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": "static void computeTotient ( int n ) {\n  long phi [ ] = new long [ 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 ++ ) System . out . println ( \"Totient of \" + i + \" is \" + phi [ i ] ) ;\n}\n", "FIND_MINIMUM_NUMBER_DIVIDED_MAKE_NUMBER_PERFECT_SQUARE": "static 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 == 1 ) ans *= 2 ;\n  for ( int i = 3 ;\n  i <= Math . sqrt ( n ) ;\n  i += 2 ) {\n    count = 0 ;\n    while ( n % i == 0 ) {\n      count ++ ;\n      n /= i ;\n    }\n    if ( count % 2 == 1 ) ans *= i ;\n  }\n  if ( n > 2 ) ans *= n ;\n  return ans ;\n}\n", "COUNT_NUMBER_WAYS_JUMP_REACH_END": "static void countWaysToJump ( int arr [ ] , int n ) {\n  int count_jump [ ] = new int [ n ] ;\n  Arrays . fill ( count_jump , 0 ) ;\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 ++ ) System . out . print ( count_jump [ i ] + \" \" ) ;\n}\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL_1": "static void substringConversions ( String str , int k , int b ) {\n  int i = 0 , sum = 0 , counter = k - 1 ;\n  for ( i = 0 ;\n  i < k ;\n  i ++ ) {\n    sum = ( int ) ( sum + ( ( str . charAt ( i ) - '0' ) * Math . pow ( b , counter ) ) ) ;\n    counter -- ;\n  }\n  System . out . print ( sum + \" \" ) ;\n  int prev = sum ;\n  sum = 0 ;\n  counter = 0 ;\n  for ( ;\n  i < str . length ( ) ;\n  i ++ ) {\n    sum = ( int ) ( prev - ( ( str . charAt ( i - k ) - '0' ) * Math . pow ( b , k - 1 ) ) ) ;\n    sum = sum * b ;\n    sum = sum + ( str . charAt ( i ) - '0' ) ;\n    System . out . print ( sum + \" \" ) ;\n    prev = sum ;\n    counter ++ ;\n  }\n}\n", "TWO_ELEMENTS_WHOSE_SUM_IS_CLOSEST_TO_ZERO": "static 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    System . out . println ( \"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 ( Math . abs ( min_sum ) > Math . abs ( sum ) ) {\n        min_sum = sum ;\n        min_l = l ;\n        min_r = r ;\n      }\n    }\n  }\n  System . out . println ( \" 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": "static int findoptimal ( int N ) {\n  if ( N <= 6 ) return N ;\n  int [ ] screen = new int [ 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 ] = Math . max ( 2 * screen [ n - 4 ] , Math . max ( 3 * screen [ n - 5 ] , 4 * screen [ n - 6 ] ) ) ;\n  }\n  return screen [ N - 1 ] ;\n}\n", "PROGRAM_DECIMAL_BINARY_CONVERSION_2": "static int decimalToBinary ( int N ) {\n  int B_Number = 0 ;\n  int cnt = 0 ;\n  while ( N != 0 ) {\n    int rem = N % 2 ;\n    double c = Math . 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": "static int countPaths ( int n , int m ) {\n  int dp [ ] [ ] = new int [ 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": "static int sumBetweenTwoKth ( int arr [ ] , int k1 , int k2 ) {\n  Arrays . sort ( arr ) ;\n  int result = 0 ;\n  for ( int i = k1 ;\n  i < k2 - 1 ;\n  i ++ ) result += arr [ i ] ;\n  return result ;\n}\n", "SMALLEST_SUBARRAY_K_DISTINCT_NUMBERS": "static 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    Set < Integer > s = new HashSet < Integer > ( ) ;\n    int j ;\n    for ( j = i ;\n    j < n ;\n    j ++ ) {\n      s . add ( 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 ) System . out . println ( \"Invalid k\" ) ;\n  else System . out . println ( l + \" \" + r ) ;\n}\n", "AREA_OF_A_HEXAGON": "public static double hexagonArea ( double s ) {\n  return ( ( 3 * Math . sqrt ( 3 ) * ( s * s ) ) / 2 ) ;\n}\n", "NEXT_POWER_OF_2_2": "static int nextPowerOf2 ( 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": "static int countOfSubstringWithKOnes ( String s , int K ) {\n  int N = s . length ( ) ;\n  int res = 0 ;\n  int countOfOne = 0 ;\n  int [ ] freq = new int [ N + 1 ] ;\n  freq [ 0 ] = 1 ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) {\n    countOfOne += ( s . charAt ( 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": "static 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": "static int check_duck ( String num ) {\n  int len = num . length ( ) ;\n  int count_zero = 0 ;\n  char ch ;\n  for ( int i = 1 ;\n  i < len ;\n  i ++ ) {\n    ch = num . charAt ( i ) ;\n    if ( ch == '0' ) count_zero ++ ;\n  }\n  return count_zero ;\n}\n", "NUMBER_NON_NEGATIVE_INTEGRAL_SOLUTIONS_B_C_N_1": "static 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": "static int maxProfit ( int price [ ] , int n , int k ) {\n  int profit [ ] [ ] = new int [ 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 = Integer . MIN_VALUE ;\n    for ( int j = 1 ;\n    j < n ;\n    j ++ ) {\n      prevDiff = Math . max ( prevDiff , profit [ i - 1 ] [ j - 1 ] - price [ j - 1 ] ) ;\n      profit [ i ] [ j ] = Math . max ( profit [ i ] [ j - 1 ] , price [ j ] + prevDiff ) ;\n    }\n  }\n  return profit [ k ] [ n - 1 ] ;\n}\n", "COUNT_CHARACTERS_POSITION_ENGLISH_ALPHABETS": "static int findCount ( String str ) {\n  int result = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( i == ( str . charAt ( i ) - 'a' ) || i == ( str . charAt ( i ) - 'A' ) ) {\n      result ++ ;\n    }\n  }\n  return result ;\n}\n", "COUNT_GFG_SUBSEQUENCES_GIVEN_STRING": "static void countSubsequence ( String 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 . charAt ( 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  System . out . println ( result ) ;\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": "static int findMaxPoints ( int A [ ] [ ] ) {\n  int [ ] [ ] P1S = new int [ M + 2 ] [ N + 2 ] ;\n  int [ ] [ ] P1E = new int [ M + 2 ] [ N + 2 ] ;\n  int [ ] [ ] P2S = new int [ M + 2 ] [ N + 2 ] ;\n  int [ ] [ ] P2E = new int [ M + 2 ] [ N + 2 ] ;\n  for ( int i = 1 ;\n  i <= N ;\n  i ++ ) for ( int j = 1 ;\n  j <= M ;\n  j ++ ) P1S [ i ] [ j ] = Math . 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 ] = Math . 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 ] = Math . 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 ] = Math . 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 = Math . max ( ans , Math . max ( op1 , op2 ) ) ;\n    }\n  }\n  return ans ;\n}\n", "PROGRAM_FIND_CIRCUMFERENCE_CIRCLE": "static double circumference ( double r ) {\n  double PI = 3.1415 ;\n  double cir = 2 * PI * r ;\n  return cir ;\n}\n", "QUICKLY_FIND_MULTIPLE_LEFT_ROTATIONS_OF_AN_ARRAY": "static void leftRotate ( int arr [ ] , int n , int k ) {\n  for ( int i = k ;\n  i < k + n ;\n  i ++ ) System . out . print ( arr [ i % n ] + \" \" ) ;\n}\n", "MINIMUM_SUM_CHOOSING_MINIMUM_PAIRS_ARRAY": "static int minSum ( int [ ] A , int n ) {\n  int min_val = Arrays . stream ( A ) . min ( ) . getAsInt ( ) ;\n  return ( min_val * ( n - 1 ) ) ;\n}\n", "RECURSIVE_PROGRAM_PRIME_NUMBER": "static boolean isPrime ( int n , int i ) {\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": "static 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": "static 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 . charAt ( m - 1 ) == b . charAt ( 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": "static boolean 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": "static int maxOnesIndex ( int arr [ ] , int n ) {\n  int max_count = 0 ;\n  int max_index = 0 ;\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": "static int maxProduct ( int arr [ ] , int n ) {\n  if ( n < 3 ) {\n    return - 1 ;\n  }\n  Arrays . sort ( arr ) ;\n  return Math . 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": "static void printRect ( Integer X [ ] , Integer Y [ ] , int n ) {\n  int Xmax = Collections . max ( Arrays . asList ( X ) ) ;\n  int Xmin = Collections . min ( Arrays . asList ( X ) ) ;\n  int Ymax = Collections . max ( Arrays . asList ( Y ) ) ;\n  int Ymin = Collections . min ( Arrays . asList ( Y ) ) ;\n  System . out . println ( \"{\" + Xmin + \", \" + Ymin + \"}\" ) ;\n  System . out . println ( \"{\" + Xmin + \", \" + Ymax + \"}\" ) ;\n  System . out . println ( \"{\" + Xmax + \", \" + Ymax + \"}\" ) ;\n  System . out . println ( \"{\" + Xmax + \", \" + Ymin + \"}\" ) ;\n}\n", "COUNT_BINARY_DIGIT_NUMBERS_SMALLER_N": "static int countOfBinaryNumberLessThanN ( int N ) {\n  Queue < Integer > q = new LinkedList < > ( ) ;\n  q . add ( 1 ) ;\n  int cnt = 0 ;\n  int t ;\n  while ( q . size ( ) > 0 ) {\n    t = q . peek ( ) ;\n    q . remove ( ) ;\n    if ( t <= N ) {\n      cnt ++ ;\n      q . add ( t * 10 ) ;\n      q . add ( t * 10 + 1 ) ;\n    }\n  }\n  return cnt ;\n}\n", "CONVERT_DECIMAL_FRACTION_BINARY_NUMBER": "static String decimalToBinary ( double num , int k_prec ) {\n  String binary = \"\" ;\n  int Integral = ( int ) num ;\n  double fractional = num - Integral ;\n  while ( Integral > 0 ) {\n    int rem = Integral % 2 ;\n    binary += ( ( char ) ( rem + '0' ) ) ;\n    Integral /= 2 ;\n  }\n  binary = reverse ( binary ) ;\n  binary += ( '.' ) ;\n  while ( k_prec -- > 0 ) {\n    fractional *= 2 ;\n    int fract_bit = ( int ) fractional ;\n    if ( fract_bit == 1 ) {\n      fractional -= fract_bit ;\n      binary += ( char ) ( 1 + '0' ) ;\n    }\n    else {\n      binary += ( char ) ( 0 + '0' ) ;\n    }\n  }\n  return binary ;\n}\n", "MAXIMUM_NUMBER_OF_TRAILING_ZEROS_IN_THE_PRODUCT_OF_THE_SUBSETS_OF_SIZE_K": "static int maximumZeros ( int arr [ ] , int n , int k ) {\n  int subset [ ] [ ] = new int [ k + 1 ] [ MAX5 + 5 ] ;\n  for ( int [ ] row : subset ) {\n    Arrays . fill ( row , - 1 ) ;\n  }\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 -- ) {\n      for ( int j = 0 ;\n      j < MAX5 ;\n      j ++ ) {\n        if ( subset [ i ] [ j ] != - 1 ) {\n          subset [ i + 1 ] [ j + pw5 ] = Math . max ( subset [ i + 1 ] [ j + pw5 ] , subset [ i ] [ j ] + pw2 ) ;\n        }\n      }\n    }\n  }\n  int ans = 0 ;\n  for ( int i = 0 ;\n  i < MAX5 ;\n  i ++ ) {\n    ans = Math . max ( ans , Math . min ( i , subset [ k ] [ i ] ) ) ;\n  }\n  return ans ;\n}\n", "SEARCH_AN_ELEMENT_IN_A_SORTED_AND_PIVOTED_ARRAY": "static 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": "static 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 ) * ( float ) Math . sin ( ( angle * pi ) / 180 ) ;\n  return area_of_sector - area_of_triangle ;\n}\n", "K_SMALLEST_ELEMENTS_ORDER_USING_O1_EXTRA_SPACE": "public static 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 ++ ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "NTH_NON_FIBONACCI_NUMBER": "static 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": "static 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 ) {\n      return i ;\n    }\n  }\n  return - 1 ;\n}\n", "ZECKENDORFS_THEOREM_NON_NEIGHBOURING_FIBONACCI_REPRESENTATION": "public static 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": "static int find_maximum ( int a [ ] , int n , int k ) {\n  HashMap < Integer , Integer > b = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int x = a [ i ] ;\n    int d = Math . min ( 1 + i , n - i ) ;\n    if ( ! b . containsKey ( x ) ) b . put ( x , d ) ;\n    else {\n      b . put ( x , Math . min ( d , b . get ( x ) ) ) ;\n    }\n  }\n  int ans = Integer . MAX_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int x = a [ i ] ;\n    if ( x != k - x && b . containsKey ( k - x ) ) ans = Math . min ( Math . max ( b . get ( x ) , b . get ( k - x ) ) , ans ) ;\n  }\n  return ans ;\n}\n", "GENERATING_DISTINCT_SUBSEQUENCES_OF_A_GIVEN_STRING_IN_LEXICOGRAPHIC_ORDER": "static void generate ( Set < String > st , String s ) {\n  if ( s . length ( ) == 0 ) {\n    return ;\n  }\n  if ( ! st . contains ( s ) ) {\n    st . add ( s ) ;\n    for ( int i = 0 ;\n    i < s . length ( ) ;\n    i ++ ) {\n      String t = s ;\n      t = t . substring ( 0 , i ) + t . substring ( i + 1 ) ;\n      generate ( st , t ) ;\n    }\n  }\n  return ;\n}\n", "WRITE_YOU_OWN_POWER_WITHOUT_USING_MULTIPLICATION_AND_DIVISION": "static 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": "static 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": "static 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": "static int minTime ( int [ ] arr , int n , int m ) {\n  int t = 0 ;\n  while ( true ) {\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": "public static int difference ( int arr [ ] [ ] , 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 Math . abs ( d1 - d2 ) ;\n}\n", "SHORTEST_UNCOMMON_SUBSEQUENCE": "static int shortestSeq ( char [ ] S , char [ ] T ) {\n  int m = S . length , n = T . length ;\n  int dp [ ] [ ] = new int [ m + 1 ] [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= m ;\n  i ++ ) {\n    dp [ i ] [ 0 ] = 1 ;\n  }\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) {\n    dp [ 0 ] [ i ] = MAX ;\n  }\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 -- ) {\n        if ( T [ k ] == ch ) {\n          break ;\n        }\n      }\n      if ( k == - 1 ) {\n        dp [ i ] [ j ] = 1 ;\n      }\n      else {\n        dp [ i ] [ j ] = Math . min ( dp [ i - 1 ] [ j ] , dp [ i - 1 ] [ k ] + 1 ) ;\n      }\n    }\n  }\n  int ans = dp [ m ] [ n ] ;\n  if ( ans >= MAX ) {\n    ans = - 1 ;\n  }\n  return ans ;\n}\n", "MIN_FLIPS_OF_CONTINUOUS_CHARACTERS_TO_MAKE_ALL_CHARACTERS_SAME_IN_A_STRING": "static int findFlips ( String str , int n ) {\n  char last = ' ' ;\n  int res = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( last != str . charAt ( i ) ) res ++ ;\n    last = str . charAt ( i ) ;\n  }\n  return res / 2 ;\n}\n", "DYNAMIC_PROGRAMMING_SET_28_MINIMUM_INSERTIONS_TO_FORM_A_PALINDROME": "static int findMinInsertions ( char str [ ] , int l , int h ) {\n  if ( l > h ) return Integer . MAX_VALUE ;\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 ) : ( Integer . min ( findMinInsertions ( str , l , h - 1 ) , findMinInsertions ( str , l + 1 , h ) ) + 1 ) ;\n}\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS": "static 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 ( Math . abs ( str . charAt ( i ) - str . charAt ( j ) ) == Math . abs ( i - j ) ) result ++ ;\n  return result ;\n}\n", "MULTISTAGE_GRAPH_SHORTEST_PATH": "public static int shortestDist ( int [ ] [ ] graph ) {\n  int [ ] dist = new int [ 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 ) {\n        continue ;\n      }\n      dist [ i ] = Math . 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": "static void printMaxSubSquare ( int M [ ] [ ] ) {\n  int i , j ;\n  int R = M . length ;\n  int C = M [ 0 ] . length ;\n  int S [ ] [ ] = new int [ 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 ] = Math . min ( S [ i ] [ j - 1 ] , Math . 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  System . out . println ( \"Maximum size sub-matrix is: \" ) ;\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      System . out . print ( M [ i ] [ j ] + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "GIVEN_SORTED_ARRAY_NUMBER_X_FIND_PAIR_ARRAY_WHOSE_SUM_CLOSEST_X": "static void printClosest ( int arr [ ] , int n , int x ) {\n  int res_l = 0 , res_r = 0 ;\n  int l = 0 , r = n - 1 , diff = Integer . MAX_VALUE ;\n  while ( r > l ) {\n    if ( Math . abs ( arr [ l ] + arr [ r ] - x ) < diff ) {\n      res_l = l ;\n      res_r = r ;\n      diff = Math . abs ( arr [ l ] + arr [ r ] - x ) ;\n    }\n    if ( arr [ l ] + arr [ r ] > x ) r -- ;\n    else l ++ ;\n  }\n  System . out . println ( \" The closest pair is \" + arr [ res_l ] + \" and \" + arr [ res_r ] ) ;\n}\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS_1": "static int sortedAfterSwap ( int [ ] A , int [ ] B , int n ) {\n  int t = 0 ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    if ( B [ i ] != 0 ) {\n      if ( A [ i ] != i + 1 ) t = A [ i ] ;\n      A [ i ] = A [ i + 1 ] ;\n      A [ i + 1 ] = t ;\n    }\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( A [ i ] != i + 1 ) return 0 ;\n  }\n  return 1 ;\n}\n", "TILE_STACKING_PROBLEM": "static int possibleWays ( int n , int m , int k ) {\n  int [ ] [ ] dp = new int [ N ] [ N ] ;\n  int [ ] [ ] presum = new int [ N ] [ N ] ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < N ;\n    j ++ ) {\n      dp [ i ] [ j ] = 0 ;\n      presum [ i ] [ j ] = 0 ;\n    }\n  }\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 ++ ) {\n    presum [ i ] [ 0 ] = dp [ i ] [ 0 ] = 1 ;\n  }\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 ++ ) {\n      presum [ i ] [ j ] = dp [ i ] [ j ] + presum [ i ] [ j - 1 ] ;\n    }\n  }\n  return dp [ m ] [ n ] ;\n}\n", "NUMBER_OF_PAIRS_IN_AN_ARRAY_HAVING_SUM_EQUAL_TO_PRODUCT": "static 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": "static int minPalPartion ( String str ) {\n  int n = str . length ( ) ;\n  int [ ] [ ] C = new int [ n ] [ n ] ;\n  boolean [ ] [ ] P = new boolean [ 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 . charAt ( i ) == str . charAt ( j ) ) ;\n      else P [ i ] [ j ] = ( str . charAt ( i ) == str . charAt ( j ) ) && P [ i + 1 ] [ j - 1 ] ;\n      if ( P [ i ] [ j ] == true ) C [ i ] [ j ] = 0 ;\n      else {\n        C [ i ] [ j ] = Integer . MAX_VALUE ;\n        for ( k = i ;\n        k <= j - 1 ;\n        k ++ ) C [ i ] [ j ] = Integer . 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": "static int findRepeatingNumber ( int [ ] arr , int n ) {\n  int sq = ( int ) Math . sqrt ( n ) ;\n  int range = ( n / sq ) + 1 ;\n  int [ ] count = new int [ range ] ;\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  HashMap < Integer , Integer > m = new HashMap < > ( ) ;\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 . put ( arr [ i ] , 1 ) ;\n      if ( m . get ( arr [ i ] ) == 1 ) return arr [ i ] ;\n    }\n  }\n  return - 1 ;\n}\n", "MINIMUM_SUM_PATH_TRIANGLE": "static int minSumPath ( ) {\n  int [ ] memo = new int [ A . length ] ;\n  int n = A . length - 1 ;\n  for ( int i = 0 ;\n  i < A [ n ] . length ;\n  i ++ ) memo [ i ] = A [ n ] [ i ] ;\n  for ( int i = A . length - 2 ;\n  i >= 0 ;\n  i -- ) for ( int j = 0 ;\n  j < A [ i ] . length ;\n  j ++ ) memo [ j ] = A [ i ] [ j ] + ( int ) Math . 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": "static 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": "static void printFun ( int test ) {\n  if ( test < 1 ) return ;\n  else {\n    System . out . printf ( \"%d \" , test ) ;\n    printFun ( test - 1 ) ;\n    System . out . printf ( \"%d \" , test ) ;\n    return ;\n  }\n}\n", "MAXIMUM_TRIPLET_SUM_ARRAY": "static int maxTripletSum ( int arr [ ] , int n ) {\n  int sum = - 1000000 ;\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": "private static int minJumps ( int [ ] arr , int n ) {\n  int jumps [ ] = new int [ n ] ;\n  int i , j ;\n  if ( n == 0 || arr [ 0 ] == 0 ) return Integer . MAX_VALUE ;\n  jumps [ 0 ] = 0 ;\n  for ( i = 1 ;\n  i < n ;\n  i ++ ) {\n    jumps [ i ] = Integer . MAX_VALUE ;\n    for ( j = 0 ;\n    j < i ;\n    j ++ ) {\n      if ( i <= j + arr [ j ] && jumps [ j ] != Integer . MAX_VALUE ) {\n        jumps [ i ] = Math . min ( jumps [ i ] , jumps [ j ] + 1 ) ;\n        break ;\n      }\n    }\n  }\n  return jumps [ n - 1 ] ;\n}\n", "MAXIMIZE_ARRAY_ELEMENTS_UPTO_GIVEN_NUMBER": "static int findMaxVal ( int [ ] arr , int n , int num , int maxLimit ) {\n  int ind ;\n  int val ;\n  int [ ] [ ] dp = new int [ 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          if ( dp [ ind - 1 ] [ val - arr [ ind ] ] == 1 || dp [ ind - 1 ] [ val + arr [ ind ] ] == 1 ) dp [ ind ] [ val ] = 1 ;\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 ] == 1 ) {\n      return val ;\n    }\n  }\n  return - 1 ;\n}\n", "PROGRAM_FOR_DEADLOCK_FREE_CONDITION_IN_OPERATING_SYSTEM": "static 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": "static int countDigits ( int a , int b ) {\n  int count = 0 ;\n  int p = Math . 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": "static 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": "public static int checkValidity ( int a , int b , int c ) {\n  if ( a + b <= c || a + c <= b || b + c <= a ) return 0 ;\n  else return 1 ;\n}\n", "PRINT_N_X_N_SPIRAL_MATRIX_USING_O1_EXTRA_SPACE": "static 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 = Math . min ( Math . min ( i , j ) , Math . min ( n - 1 - i , n - 1 - j ) ) ;\n      if ( i <= j ) System . out . print ( ( n - 2 * x ) * ( n - 2 * x ) - ( i - x ) - ( j - x ) + \"\\t\" ) ;\n      else System . out . print ( ( n - 2 * x - 2 ) * ( n - 2 * x - 2 ) + ( i - x ) + ( j - x ) + \"\\t\" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "POSITION_ELEMENT_STABLE_SORT": "static 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": "static 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 . charAt ( i ) - '0' ) ;\n  int seg_len_pow = ( int ) Math . 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 . charAt ( i - 1 ) - '0' ) * seg_len_pow ;\n    curr_val = curr_val * 10 + ( s . charAt ( i + seg_len - 1 ) - '0' ) ;\n    res = Math . max ( res , curr_val ) ;\n  }\n  return res ;\n}\n", "FINDING_POWER_PRIME_NUMBER_P_N_1": "static 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": "static 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 ) System . out . print ( 1 + \" \" ) ;\n      else System . out . print ( 0 + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n  return 0 ;\n}\n", "SUM_MATRIX_ELEMENT_ELEMENT_INTEGER_DIVISION_ROW_COLUMN": "static 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": "static int countWays ( int n ) {\n  int [ ] A = new int [ n + 1 ] ;\n  int [ ] B = new int [ n + 1 ] ;\n  A [ 0 ] = 1 ;\n  A [ 1 ] = 0 ;\n  B [ 0 ] = 0 ;\n  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": "static 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": "static void countFreq ( int a [ ] , int n ) {\n  int hm [ ] = new int [ n ] ;\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 ] ] != 0 ) {\n      System . out . println ( a [ i ] + \"->\" + cumul ) ;\n    }\n    hm [ a [ i ] ] = 0 ;\n  }\n}\n", "MINIMIZE_THE_SUM_OF_DIGITS_OF_A_AND_B_SUCH_THAT_A_B_N": "static 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": "static 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  System . out . println ( side + \" \" + num ) ;\n}\n", "CHECK_NUMBER_POWER_K_USING_BASE_CHANGING_METHOD": "static boolean isPowerOfK ( int n , int k ) {\n  boolean 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": "static int PositionRightmostSetbit ( int n ) {\n  int position = 1 ;\n  int m = 1 ;\n  while ( ( n & m ) == 0 ) {\n    m = m << 1 ;\n    position ++ ;\n  }\n  return position ;\n}\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY_1": "static 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": "static void printMaxOfMin ( int n ) {\n  Stack < Integer > s = new Stack < > ( ) ;\n  int left [ ] = new int [ n + 1 ] ;\n  int right [ ] = new int [ 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 . peek ( ) ] >= arr [ i ] ) s . pop ( ) ;\n    if ( ! s . empty ( ) ) left [ i ] = s . peek ( ) ;\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 . peek ( ) ] >= arr [ i ] ) s . pop ( ) ;\n    if ( ! s . empty ( ) ) right [ i ] = s . peek ( ) ;\n    s . push ( i ) ;\n  }\n  int ans [ ] = new int [ 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 ] = Math . max ( ans [ len ] , arr [ i ] ) ;\n  }\n  for ( int i = n - 1 ;\n  i >= 1 ;\n  i -- ) ans [ i ] = Math . max ( ans [ i ] , ans [ i + 1 ] ) ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) System . out . print ( ans [ i ] + \" \" ) ;\n}\n", "MAXIMUM_DECIMAL_VALUE_PATH_IN_A_BINARY_MATRIX_1": "static int MaximumDecimalValue ( int mat [ ] [ ] , int n ) {\n  int dp [ ] [ ] = new int [ n ] [ n ] ;\n  if ( mat [ 0 ] [ 0 ] == 1 ) {\n    dp [ 0 ] [ 0 ] = 1 ;\n  }\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( mat [ 0 ] [ i ] == 1 ) {\n      dp [ 0 ] [ i ] = ( int ) ( dp [ 0 ] [ i - 1 ] + Math . pow ( 2 , i ) ) ;\n    }\n    else {\n      dp [ 0 ] [ i ] = dp [ 0 ] [ i - 1 ] ;\n    }\n  }\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( mat [ i ] [ 0 ] == 1 ) {\n      dp [ i ] [ 0 ] = ( int ) ( dp [ i - 1 ] [ 0 ] + Math . pow ( 2 , i ) ) ;\n    }\n    else {\n      dp [ i ] [ 0 ] = dp [ i - 1 ] [ 0 ] ;\n    }\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 ) {\n        dp [ i ] [ j ] = ( int ) ( Math . max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] ) + Math . pow ( 2 , i + j ) ) ;\n      }\n      else {\n        dp [ i ] [ j ] = Math . max ( dp [ i ] [ j - 1 ] , dp [ i - 1 ] [ j ] ) ;\n      }\n    }\n  }\n  return dp [ n - 1 ] [ n - 1 ] ;\n}\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE": "static 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": "static void segregateElements ( int arr [ ] , int n ) {\n  int temp [ ] = new int [ 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  for ( int i = 0 ;\n  i < n ;\n  i ++ ) arr [ i ] = temp [ i ] ;\n}\n", "MINIMUM_PERIMETER_N_BLOCKS": "public static long minPerimeter ( int n ) {\n  int l = ( int ) Math . sqrt ( n ) ;\n  int sq = l * l ;\n  if ( sq == n ) return l * 4 ;\n  else {\n    long row = n / l ;\n    long 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": "static 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 = Math . max ( max_val , Math . max ( i * ( n - i ) , maxProd ( n - i ) * i ) ) ;\n  return max_val ;\n}\n", "LONGEST_COMMON_SUBSTRING_SPACE_OPTIMIZED_DP_SOLUTION": "static int LCSubStr ( String X , String Y ) {\n  int m = X . length ( ) ;\n  int n = Y . length ( ) ;\n  int result = 0 ;\n  int [ ] [ ] len = new int [ 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 . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) {\n        len [ currRow ] [ j ] = len [ ( 1 - currRow ) ] [ ( j - 1 ) ] + 1 ;\n        result = Math . 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": "static boolean isPalindrome ( String str ) {\n  int l = 0 ;\n  int h = str . length ( ) - 1 ;\n  while ( h > l ) if ( str . charAt ( l ++ ) != str . charAt ( h -- ) ) return false ;\n  return true ;\n}\n", "FIND_NUMBER_OF_SOLUTIONS_OF_A_LINEAR_EQUATION_OF_N_VARIABLES_1": "static int countSol ( int coeff [ ] , int n , int rhs ) {\n  int dp [ ] = new int [ rhs + 1 ] ;\n  Arrays . fill ( dp , 0 ) ;\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": "static int findLargestSumPair ( ) {\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 < arr . length ;\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": "static 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": "static void printDistinct ( String str ) {\n  int n = str . length ( ) ;\n  int [ ] count = new int [ MAX_CHAR ] ;\n  int [ ] index = new int [ 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 . charAt ( i ) ;\n    ++ count [ x ] ;\n    if ( count [ x ] == 1 && x != ' ' ) index [ x ] = i ;\n    if ( count [ x ] == 2 ) index [ x ] = n ;\n  }\n  Arrays . sort ( index ) ;\n  for ( int i = 0 ;\n  i < MAX_CHAR && index [ i ] != n ;\n  i ++ ) System . out . print ( str . charAt ( index [ i ] ) ) ;\n}\n", "FIND_TWO_SIDES_RIGHT_ANGLE_TRIANGLE": "static void printOtherSides ( int n ) {\n  if ( n % 2 != 0 ) {\n    if ( n == 1 ) System . out . println ( \"-1\" ) ;\n    else {\n      int b = ( n * n - 1 ) / 2 ;\n      int c = ( n * n + 1 ) / 2 ;\n      System . out . println ( \"b = \" + b + \", c = \" + c ) ;\n    }\n  }\n  else {\n    if ( n == 2 ) System . out . println ( \"-1\" ) ;\n    else {\n      int b = n * n / 4 - 1 ;\n      int c = n * n / 4 + 1 ;\n      System . out . println ( \"b = \" + b + \", c = \" + c ) ;\n    }\n  }\n}\n", "COUNT_NUMBER_OF_STRINGS_MADE_OF_R_G_AND_B_USING_GIVEN_COMBINATION": "static int possibleStrings ( int n , int r , int b , int g ) {\n  int fact [ ] = new int [ 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": "public static 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": "public static int calculateSum ( String arr [ ] , int n ) {\n  if ( n == 0 ) return 0 ;\n  String s = arr [ 0 ] ;\n  int value = Integer . parseInt ( s ) ;\n  int sum = value ;\n  for ( int i = 2 ;\n  i < n ;\n  i = i + 2 ) {\n    s = arr [ i ] ;\n    value = Integer . parseInt ( s ) ;\n    char operation = arr [ i - 1 ] . charAt ( 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": "static 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": "public static void shuffle ( int card [ ] , int n ) {\n  Random rand = new Random ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int r = i + rand . nextInt ( 52 - i ) ;\n    int temp = card [ r ] ;\n    card [ r ] = card [ i ] ;\n    card [ i ] = temp ;\n  }\n}\n", "DOOLITTLE_ALGORITHM_LU_DECOMPOSITION": "static void luDecomposition ( int [ ] [ ] mat , int n ) {\n  int [ ] [ ] lower = new int [ n ] [ n ] ;\n  int [ ] [ ] upper = new int [ n ] [ n ] ;\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  System . out . println ( setw ( 2 ) + \"     Lower Triangular\" + setw ( 10 ) + \"Upper Triangular\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < n ;\n    j ++ ) System . out . print ( setw ( 4 ) + lower [ i ] [ j ] + \"\\t\" ) ;\n    System . out . print ( \"\\t\" ) ;\n    for ( int j = 0 ;\n    j < n ;\n    j ++ ) System . out . print ( setw ( 4 ) + upper [ i ] [ j ] + \"\\t\" ) ;\n    System . out . print ( \"\\n\" ) ;\n  }\n}\n", "PROGRAM_NTH_CATALAN_NUMBER": "int catalan ( int n ) {\n  int res = 0 ;\n  if ( n <= 1 ) {\n    return 1 ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    res += catalan ( i ) * catalan ( n - i - 1 ) ;\n  }\n  return res ;\n}\n", "NUMBER_DIGITS_REMOVED_MAKE_NUMBER_DIVISIBLE_3": "static int divisible ( String num ) {\n  int n = num . length ( ) ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum += ( int ) ( num . charAt ( i ) ) ;\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 . charAt ( 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": "static boolean isPower ( int x , int y ) {\n  int res1 = ( int ) Math . log ( y ) / ( int ) Math . log ( x ) ;\n  double res2 = Math . log ( y ) / Math . log ( x ) ;\n  return ( res1 == res2 ) ;\n}\n", "LARGEST_SUBSEQUENCE_GCD_GREATER_1": "static int largestGCDSubsequence ( int arr [ ] , int n ) {\n  int ans = 0 ;\n  int maxele = Arrays . stream ( arr ) . max ( ) . getAsInt ( ) ;\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 = Math . max ( ans , count ) ;\n  }\n  return ans ;\n}\n", "FIND_COMMON_ELEMENT_ROWS_ROW_WISE_SORTED_MATRIX": "static int findCommon ( int mat [ ] [ ] ) {\n  int column [ ] = new int [ 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": "public static boolean checkcircle ( int r , int R , int r1 , int x1 , int y1 ) {\n  int dis = ( int ) Math . 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": "static int countSetBits ( int n ) {\n  int i = 0 ;\n  int ans = 0 ;\n  while ( ( 1 << i ) <= n ) {\n    boolean k = false ;\n    int change = 1 << i ;\n    for ( int j = 0 ;\n    j <= n ;\n    j ++ ) {\n      if ( k == true ) ans += 1 ;\n      else ans += 0 ;\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": "static int findLongestRepeatingSubSeq ( String str ) {\n  int n = str . length ( ) ;\n  int [ ] [ ] dp = new int [ n + 1 ] [ n + 1 ] ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= n ;\n    j ++ ) {\n      if ( str . charAt ( i - 1 ) == str . charAt ( j - 1 ) && i != j ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n      else dp [ i ] [ j ] = Math . 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": "public static void sortSquares ( int arr [ ] ) {\n  int n = arr . length ;\n  int k ;\n  for ( k = 0 ;\n  k < n ;\n  k ++ ) {\n    if ( arr [ k ] >= 0 ) break ;\n  }\n  int i = k - 1 ;\n  int j = k ;\n  int ind = 0 ;\n  int [ ] temp = new int [ 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  }\n  while ( j < n ) {\n    temp [ ind ++ ] = arr [ j ] * arr [ j ] ;\n    j ++ ;\n  }\n  for ( int x = 0 ;\n  x < n ;\n  x ++ ) arr [ x ] = temp [ x ] ;\n}\n", "PROGRAM_TO_FIND_REMAINDER_WITHOUT_USING_MODULO_OR_OPERATOR": "static int getRemainder ( int num , int divisor ) {\n  return ( num - divisor * ( num / divisor ) ) ;\n}\n", "MINIMUM_COST_TO_FILL_GIVEN_WEIGHT_IN_A_BAG": "public static int MinimumCost ( int cost [ ] , int n , int W ) {\n  Vector < Integer > val = new Vector < Integer > ( ) ;\n  Vector < Integer > wt = new Vector < Integer > ( ) ;\n  int size = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( cost [ i ] != - 1 ) {\n      val . add ( cost [ i ] ) ;\n      wt . add ( i + 1 ) ;\n      size ++ ;\n    }\n  }\n  n = size ;\n  int min_cost [ ] [ ] = new int [ n + 1 ] [ W + 1 ] ;\n  for ( int i = 0 ;\n  i <= W ;\n  i ++ ) min_cost [ 0 ] [ i ] = Integer . MAX_VALUE ;\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 . get ( i - 1 ) > j ) min_cost [ i ] [ j ] = min_cost [ i - 1 ] [ j ] ;\n      else min_cost [ i ] [ j ] = Math . min ( min_cost [ i - 1 ] [ j ] , min_cost [ i ] [ j - wt . get ( i - 1 ) ] + val . get ( i - 1 ) ) ;\n    }\n  }\n  return ( min_cost [ n ] [ W ] == Integer . MAX_VALUE ) ? - 1 : min_cost [ n ] [ W ] ;\n}\n", "COUNT_CHARACTERS_STRING_DISTANCE_ENGLISH_ALPHABETS_1": "static 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 ( ( Math . abs ( str . charAt ( i + j ) - str . charAt ( i ) ) == j ) ) result ++ ;\n  return result ;\n}\n", "A_PRODUCT_ARRAY_PUZZLE": "void productArray ( int arr [ ] , int n ) {\n  if ( n == 1 ) {\n    System . out . print ( 0 ) ;\n    return ;\n  }\n  int left [ ] = new int [ n ] ;\n  int right [ ] = new int [ n ] ;\n  int prod [ ] = new 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 ++ ) System . out . print ( prod [ i ] + \" \" ) ;\n  return ;\n}\n", "FREQUENT_ELEMENT_ARRAY_1": "static int mostFrequent ( int arr [ ] , int n ) {\n  Map < Integer , Integer > hp = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int key = arr [ i ] ;\n    if ( hp . containsKey ( key ) ) {\n      int freq = hp . get ( key ) ;\n      freq ++ ;\n      hp . put ( key , freq ) ;\n    }\n    else {\n      hp . put ( key , 1 ) ;\n    }\n  }\n  int max_count = 0 , res = - 1 ;\n  for ( Entry < Integer , Integer > val : hp . entrySet ( ) ) {\n    if ( max_count < val . getValue ( ) ) {\n      res = val . getKey ( ) ;\n      max_count = val . getValue ( ) ;\n    }\n  }\n  return res ;\n}\n", "PRINT_UNIQUE_ROWS": "public static void printArray ( int arr [ ] [ ] , int row , int col ) {\n  HashSet < String > set = new HashSet < String > ( ) ;\n  for ( int i = 0 ;\n  i < row ;\n  i ++ ) {\n    String s = \"\" ;\n    for ( int j = 0 ;\n    j < col ;\n    j ++ ) s += String . valueOf ( arr [ i ] [ j ] ) ;\n    if ( ! set . contains ( s ) ) {\n      set . add ( s ) ;\n      System . out . println ( s ) ;\n    }\n  }\n}\n", "COUNT_1S_SORTED_BINARY_ARRAY": "int countOnes ( int 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": "static int findPossibleMoves ( int mat [ ] [ ] , int p , int q ) {\n  int X [ ] = {\n    2 , 1 , - 1 , - 2 , - 2 , - 1 , 1 , 2 };\n    int Y [ ] = {\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": "static void rotatematrix ( int m , int n , int mat [ ] [ ] ) {\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 ++ ) System . out . print ( mat [ i ] [ j ] + \" \" ) ;\n    System . out . print ( \"\\n\" ) ;\n  }\n}\n", "FIND_KTH_CHARACTER_OF_DECRYPTED_STRING": "static char encodedChar ( String str , int k ) {\n  String expand = \"\" ;\n  String temp = \"\" ;\n  int freq = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  ) {\n    temp = \"\" ;\n    freq = 0 ;\n    while ( i < str . length ( ) && str . charAt ( i ) >= 'a' && str . charAt ( i ) <= 'z' ) {\n      temp += str . charAt ( i ) ;\n      i ++ ;\n    }\n    while ( i < str . length ( ) && str . charAt ( i ) >= '1' && str . charAt ( i ) <= '9' ) {\n      freq = freq * 10 + str . charAt ( i ) - '0' ;\n      i ++ ;\n    }\n    for ( int j = 1 ;\n    j <= freq ;\n    j ++ ) expand += temp ;\n  }\n  if ( freq == 0 ) expand += temp ;\n  return expand . charAt ( k - 1 ) ;\n}\n", "EFFICIENT_SEARCH_IN_AN_ARRAY_WHERE_DIFFERENCE_BETWEEN_ADJACENT_IS_1": "static 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 += Math . abs ( arr [ i ] - x ) ;\n  }\n  return - 1 ;\n}\n", "MAXIMUM_POSSIBLE_SUM_WINDOW_ARRAY_ELEMENTS_WINDOW_ARRAY_UNIQUE": "static int returnMaxSum ( int A [ ] , int B [ ] , int n ) {\n  Set < Integer > mp = new HashSet < Integer > ( ) ;\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 . contains ( A [ i ] ) ) {\n      mp . remove ( A [ curr_begin ] ) ;\n      curr_sum -= B [ curr_begin ] ;\n      curr_begin ++ ;\n    }\n    mp . add ( A [ i ] ) ;\n    curr_sum += B [ i ] ;\n    result = Integer . max ( result , curr_sum ) ;\n  }\n  return result ;\n}\n", "WRITE_AN_EFFICIENT_METHOD_TO_CHECK_IF_A_NUMBER_IS_MULTIPLE_OF_3": "static 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 != 0 ) {\n    if ( ( n & 1 ) != 0 ) odd_count ++ ;\n    if ( ( n & 2 ) != 0 ) even_count ++ ;\n    n = n >> 2 ;\n  }\n  return isMultipleOf3 ( Math . abs ( odd_count - even_count ) ) ;\n}\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY_1": "static 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 = Math . max ( res , next_val ) ;\n  }\n  return res ;\n}\n", "DYNAMIC_PROGRAMMING_SET_34_ASSEMBLY_LINE_SCHEDULING": "static int carAssembly ( int a [ ] [ ] , int t [ ] [ ] , int e [ ] , int x [ ] ) {\n  int T1 [ ] = new int [ NUM_STATION ] ;\n  int T2 [ ] = new int [ NUM_STATION ] ;\n  int 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": "static void printSpiral ( int [ ] [ ] mat , 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 ) System . out . print ( 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 ) System . out . print ( 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 ) System . out . print ( 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 ) System . out . print ( mat [ i ] [ low_column ] + \" \" ) ;\n    low_column -= 1 ;\n  }\n  System . out . println ( ) ;\n}\n", "MID_POINT_CIRCLE_DRAWING_ALGORITHM": "static void midPointCircleDraw ( int x_centre , int y_centre , int r ) {\n  int x = r , y = 0 ;\n  System . out . print ( \"(\" + ( x + x_centre ) + \", \" + ( y + y_centre ) + \")\" ) ;\n  if ( r > 0 ) {\n    System . out . print ( \"(\" + ( x + x_centre ) + \", \" + ( - y + y_centre ) + \")\" ) ;\n    System . out . print ( \"(\" + ( y + x_centre ) + \", \" + ( x + y_centre ) + \")\" ) ;\n    System . out . println ( \"(\" + ( - y + x_centre ) + \", \" + ( x + y_centre ) + \")\" ) ;\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    System . out . print ( \"(\" + ( x + x_centre ) + \", \" + ( y + y_centre ) + \")\" ) ;\n    System . out . print ( \"(\" + ( - x + x_centre ) + \", \" + ( y + y_centre ) + \")\" ) ;\n    System . out . print ( \"(\" + ( x + x_centre ) + \", \" + ( - y + y_centre ) + \")\" ) ;\n    System . out . println ( \"(\" + ( - x + x_centre ) + \", \" + ( - y + y_centre ) + \")\" ) ;\n    if ( x != y ) {\n      System . out . print ( \"(\" + ( y + x_centre ) + \", \" + ( x + y_centre ) + \")\" ) ;\n      System . out . print ( \"(\" + ( - y + x_centre ) + \", \" + ( x + y_centre ) + \")\" ) ;\n      System . out . print ( \"(\" + ( y + x_centre ) + \", \" + ( - x + y_centre ) + \")\" ) ;\n      System . out . println ( \"(\" + ( - y + x_centre ) + \", \" + ( - x + y_centre ) + \")\" ) ;\n    }\n  }\n}\n", "SMALLEST_ELEMENT_REPEATED_EXACTLY_K_TIMES_NOT_LIMITED_SMALL_RANGE": "public static int smallestKFreq ( int a [ ] , int n , int k ) {\n  HashMap < Integer , Integer > m = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( m . containsKey ( a [ i ] ) ) m . put ( a [ i ] , m . get ( a [ i ] ) + 1 ) ;\n  else m . put ( a [ i ] , 1 ) ;\n  int res = Integer . MAX_VALUE ;\n  Set < Integer > s = m . keySet ( ) ;\n  for ( int temp : s ) if ( m . get ( temp ) == k ) res = Math . min ( res , temp ) ;\n  return ( res != Integer . MAX_VALUE ) ? res : - 1 ;\n}\n", "MINIMUM_XOR_VALUE_PAIR": "static int minXOR ( int arr [ ] , int n ) {\n  int min_xor = Integer . MAX_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = i + 1 ;\n  j < n ;\n  j ++ ) min_xor = Math . min ( min_xor , arr [ i ] ^ arr [ j ] ) ;\n  return min_xor ;\n}\n", "MIRROR_CHARACTERS_STRING": "static String compute ( String str , int n ) {\n  String reverseAlphabet = \"zyxwvutsrqponmlkjihgfedcba\" ;\n  int l = str . length ( ) ;\n  String answer = \"\" ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) answer = answer + str . charAt ( i ) ;\n  for ( int i = n ;\n  i < l ;\n  i ++ ) answer = answer + reverseAlphabet . charAt ( str . charAt ( i ) - 'a' ) ;\n  return answer ;\n}\n", "PROGRAM_CHECK_PLUS_PERFECT_NUMBER": "static boolean 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 += Math . pow ( x % 10 , n ) ;\n    x /= 10 ;\n  }\n  return ( sum == temp ) ;\n}\n", "ARC_LENGTH_ANGLE": "static double arcLength ( double diameter , double angle ) {\n  double pi = 22.0 / 7.0 ;\n  double arc ;\n  if ( angle >= 360 ) {\n    System . out . println ( \"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": "static int findLastIndex ( String str , Character x ) {\n  int index = - 1 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) if ( str . charAt ( i ) == x ) index = i ;\n  return index ;\n}\n", "COUNT_TRAILING_ZEROES_FACTORIAL_NUMBER": "static 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": "static void rotateMatrix ( int mat [ ] [ ] ) {\n  for ( int i = N - 1 ;\n  i >= 0 ;\n  i -- ) {\n    for ( int j = N - 1 ;\n    j >= 0 ;\n    j -- ) System . out . print ( mat [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "SUM_FIBONACCI_NUMBERS": "static int calculateSum ( int n ) {\n  if ( n <= 0 ) return 0 ;\n  int fibo [ ] = new int [ n + 1 ] ;\n  fibo [ 0 ] = 0 ;\n  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": "static 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 ) SwapInts ( arr , j , j - 1 ) ;\n    k -= indexPosition - i ;\n  }\n}\n", "FIND_WHETHER_GIVEN_INTEGER_POWER_3_NOT": "static boolean 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  System . out . println ( \"Repeated Elements are :\" ) ;\n  for ( i = 0 ;\n  i < size ;\n  i ++ ) {\n    for ( j = i + 1 ;\n    j < size ;\n    j ++ ) {\n      if ( arr [ i ] == arr [ j ] ) System . out . print ( arr [ i ] + \" \" ) ;\n    }\n  }\n}\n", "C_PROGRAM_FIND_AREA_TRIANGLE": "static 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    System . out . println ( \"Not a valid triangle\" ) ;\n    System . exit ( 0 ) ;\n  }\n  float s = ( a + b + c ) / 2 ;\n  return ( float ) Math . sqrt ( s * ( s - a ) * ( s - b ) * ( s - c ) ) ;\n}\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8_1": "static boolean isSubSeqDivisible ( String str ) {\n  int n = str . length ( ) ;\n  int dp [ ] [ ] = new int [ n + 1 ] [ 10 ] ;\n  int arr [ ] = new int [ n + 1 ] ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) arr [ i ] = ( int ) ( str . charAt ( 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": "static void deleteElements ( int arr [ ] , int n , int k ) {\n  Stack < Integer > s = new Stack < > ( ) ;\n  s . push ( arr [ 0 ] ) ;\n  int count = 0 ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    while ( ! s . empty ( ) && s . peek ( ) < arr [ i ] && count < k ) {\n      s . pop ( ) ;\n      count ++ ;\n    }\n    s . push ( arr [ i ] ) ;\n  }\n  int m = s . size ( ) ;\n  Integer [ ] v = new Integer [ m ] ;\n  while ( ! s . empty ( ) ) {\n    v [ -- m ] = s . peek ( ) ;\n    s . pop ( ) ;\n  }\n  for ( Integer x : v ) {\n    System . out . print ( x + \"\" ) ;\n  };\n  System . out . println ( \"\" ) ;\n}\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE": "static 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": "public static void findPair ( int [ ] arr , int n ) {\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( Integer i : arr ) {\n    s . add ( i ) ;\n  }\n  boolean found = false ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    for ( int j = i + 1 ;\n    j < n ;\n    j ++ ) {\n      int sum = arr [ i ] + arr [ j ] ;\n      if ( s . contains ( sum ) ) {\n        found = true ;\n        System . out . println ( arr [ i ] + \" \" + arr [ j ] ) ;\n      }\n    }\n  }\n  if ( found == false ) System . out . println ( \"Not Exist \" ) ;\n}\n", "COUNT_ARITHMETIC_PROGRESSION_SUBSEQUENCES_ARRAY": "static int numofAP ( int a [ ] , int n ) {\n  int minarr = + 2147483647 ;\n  int maxarr = - 2147483648 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    minarr = Math . min ( minarr , a [ i ] ) ;\n    maxarr = Math . max ( maxarr , a [ i ] ) ;\n  }\n  int dp [ ] = new int [ n ] ;\n  int sum [ ] = new int [ MAX ] ;\n  int ans = n + 1 ;\n  for ( int d = ( minarr - maxarr ) ;\n  d <= ( maxarr - minarr ) ;\n  d ++ ) {\n    Arrays . fill ( sum , 0 ) ;\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": "static 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": "static void transpose ( int A [ ] [ ] ) {\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) for ( int j = i + 1 ;\n  j < N ;\n  j ++ ) {\n    int temp = A [ i ] [ j ] ;\n    A [ i ] [ j ] = A [ j ] [ i ] ;\n    A [ j ] [ i ] = temp ;\n  }\n}\n", "SUM_DIAGONALS_SPIRAL_ODD_ORDER_SQUARE_MATRIX": "static 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": "static int sumNodes ( int l ) {\n  int leafNodeCount = ( int ) Math . pow ( 2 , l - 1 ) ;\n  Vector < Vector < Integer >> vec = new Vector < Vector < Integer >> ( ) ;\n  for ( int i = 1 ;\n  i <= l ;\n  i ++ ) vec . add ( new Vector < Integer > ( ) ) ;\n  for ( int i = 1 ;\n  i <= leafNodeCount ;\n  i ++ ) vec . get ( l - 1 ) . add ( i ) ;\n  for ( int i = l - 2 ;\n  i >= 0 ;\n  i -- ) {\n    int k = 0 ;\n    while ( k < vec . get ( i + 1 ) . size ( ) - 1 ) {\n      vec . get ( i ) . add ( vec . get ( i + 1 ) . get ( k ) + vec . get ( i + 1 ) . get ( 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 . get ( i ) . size ( ) ;\n    j ++ ) sum += vec . get ( i ) . get ( j ) ;\n  }\n  return sum ;\n}\n", "SUM_OF_ALL_PROPER_DIVISORS_OF_A_NATURAL_NUMBER": "static int divSum ( int num ) {\n  int result = 0 ;\n  for ( int i = 2 ;\n  i <= Math . 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": "static boolean find3Numbers ( int A [ ] , int arr_size , int sum ) {\n  for ( int i = 0 ;\n  i < arr_size - 2 ;\n  i ++ ) {\n    HashSet < Integer > s = new HashSet < Integer > ( ) ;\n    int curr_sum = sum - A [ i ] ;\n    for ( int j = i + 1 ;\n    j < arr_size ;\n    j ++ ) {\n      if ( s . contains ( curr_sum - A [ j ] ) && curr_sum - A [ j ] != ( int ) s . toArray ( ) [ s . size ( ) - 1 ] ) {\n        System . out . printf ( \"Triplet is %d, %d, %d\" , A [ i ] , A [ j ] , curr_sum - A [ j ] ) ;\n        return true ;\n      }\n      s . add ( A [ j ] ) ;\n    }\n  }\n  return false ;\n}\n", "NTH_EVEN_LENGTH_PALINDROME": "static String evenlength ( String n ) {\n  String res = n ;\n  for ( int j = n . length ( ) - 1 ;\n  j >= 0 ;\n  -- j ) res += n . charAt ( j ) ;\n  return res ;\n}\n", "FINDING_POWER_PRIME_NUMBER_P_N": "static int PowerOFPINnfactorial ( int n , int p ) {\n  int ans = 0 ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    int count = 0 , temp = i ;\n    while ( temp % p == 0 ) {\n      count ++ ;\n      temp = temp / p ;\n    }\n    ans += count ;\n  }\n  return ans ;\n}\n", "MINIMUM_COST_MAKE_LONGEST_COMMON_SUBSEQUENCE_LENGTH_K": "static int solve ( char X [ ] , char Y [ ] , int l , int r , int k , int dp [ ] [ ] [ ] ) {\n  if ( k == 0 ) {\n    return 0 ;\n  }\n  if ( l < 0 | r < 0 ) {\n    return ( int ) 1e9 ;\n  }\n  if ( dp [ l ] [ r ] [ k ] != - 1 ) {\n    return dp [ l ] [ r ] [ k ] ;\n  }\n  int cost = ( X [ l ] - 'a' ) ^ ( Y [ r ] - 'a' ) ;\n  return dp [ l ] [ r ] [ k ] = Math . min ( Math . min ( cost + solve ( X , Y , l - 1 , r - 1 , k - 1 , dp ) , solve ( X , Y , l - 1 , r , k , dp ) ) , solve ( X , Y , l , r - 1 , k , dp ) ) ;\n}\n", "PRINT_STRING_SPECIFIED_CHARACTER_OCCURRED_GIVEN_NO_TIMES": "static void printString ( String str , char ch , int count ) {\n  int occ = 0 , i ;\n  if ( count == 0 ) {\n    System . out . println ( str ) ;\n    return ;\n  }\n  for ( i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( str . charAt ( i ) == ch ) occ ++ ;\n    if ( occ == count ) break ;\n  }\n  if ( i < str . length ( ) - 1 ) System . out . println ( str . substring ( i + 1 ) ) ;\n  else System . out . println ( \"Empty string\" ) ;\n}\n", "SORT_1_N_SWAPPING_ADJACENT_ELEMENTS": "static boolean sortedAfterSwap ( int A [ ] , boolean 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 ] ) {\n        j ++ ;\n      }\n      Arrays . sort ( A , i , 1 + j ) ;\n      i = j ;\n    }\n  }\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( A [ i ] != i + 1 ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "GENERATE_PYTHAGOREAN_TRIPLETS": "static 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      System . out . println ( a + \" \" + b + \" \" + c ) ;\n    }\n    m ++ ;\n  }\n}\n", "COUNT_EVEN_LENGTH_BINARY_SEQUENCES_WITH_SAME_SUM_OF_FIRST_AND_SECOND_HALF_BITS": "static int countSeq ( int n , int diff ) {\n  if ( Math . abs ( diff ) > n ) return 0 ;\n  if ( n == 1 && diff == 0 ) return 2 ;\n  if ( n == 1 && Math . 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": "static boolean isPossibleTriangle ( int [ ] arr , int N ) {\n  if ( N < 3 ) return false ;\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < N - 2 ;\n  i ++ ) if ( arr [ i ] + arr [ i + 1 ] > arr [ i + 2 ] ) return true ;\n  return false ;\n}\n", "PRINT_ARRAY_STRINGS_SORTED_ORDER_WITHOUT_COPYING_ONE_STRING_ANOTHER": "static void printInSortedOrder ( String arr [ ] , int n ) {\n  int index [ ] = new int [ n ] ;\n  int i , j , min ;\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) {\n    index [ i ] = i ;\n  }\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 ] ] . compareTo ( arr [ index [ j ] ] ) > 0 ) {\n        min = j ;\n      }\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 ++ ) {\n    System . out . print ( arr [ index [ i ] ] + \" \" ) ;\n  }\n}\n", "GAME_REPLACING_ARRAY_ELEMENTS": "public static int playGame ( int arr [ ] ) {\n  HashSet < Integer > set = new HashSet < > ( ) ;\n  for ( int i : arr ) set . add ( i ) ;\n  return ( set . size ( ) % 2 == 0 ) ? 1 : 2 ;\n}\n", "BASIC_AND_EXTENDED_EUCLIDEAN_ALGORITHMS": "public static 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 - 1 , i ) ;\n    if ( i < n - 1 && arr [ i ] < arr [ i + 1 ] ) swap ( arr , i , i + 1 ) ;\n  }\n}\n", "MAXIMUM_SUBARRAY_SUM_USING_PREFIX_SUM": "static int maximumSumSubarray ( int arr [ ] , int n ) {\n  int min_prefix_sum = 0 ;\n  int res = Integer . MIN_VALUE ;\n  int prefix_sum [ ] = new int [ 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 = Math . max ( res , prefix_sum [ i ] - min_prefix_sum ) ;\n    min_prefix_sum = Math . min ( min_prefix_sum , prefix_sum [ i ] ) ;\n  }\n  return res ;\n}\n", "STRING_CONTAINING_FIRST_LETTER_EVERY_WORD_GIVEN_STRING_SPACES": "static String firstLetterWord ( String str ) {\n  String result = \"\" ;\n  boolean v = true ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( str . charAt ( i ) == ' ' ) {\n      v = true ;\n    }\n    else if ( str . charAt ( i ) != ' ' && v == true ) {\n      result += ( str . charAt ( i ) ) ;\n      v = false ;\n    }\n  }\n  return result ;\n}\n", "SUM_PAIRWISE_PRODUCTS_1": "static int findSum ( int n ) {\n  int multiTerms = n * ( n + 1 ) / 2 ;\n  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": "static int minCost ( int a [ ] , int n , int k ) {\n  int dp [ ] [ ] = new int [ 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 ] = Math . 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": "static void LeibnizHarmonicTriangle ( int n ) {\n  int C [ ] [ ] = new int [ n + 1 ] [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j <= Math . 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 ++ ) System . out . print ( \"1/\" + i * C [ i - 1 ] [ j - 1 ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "CHECK_WHETHER_SECOND_STRING_CAN_FORMED_FIRST_STRING_USING_COUNT_ARRAY": "static boolean canMakeStr2 ( String str1 , String str2 ) {\n  int [ ] count = new int [ MAX ] ;\n  char [ ] str3 = str1 . toCharArray ( ) ;\n  for ( int i = 0 ;\n  i < str3 . length ;\n  i ++ ) count [ str3 [ i ] ] ++ ;\n  char [ ] str4 = str2 . toCharArray ( ) ;\n  for ( int i = 0 ;\n  i < str4 . length ;\n  i ++ ) {\n    if ( count [ str4 [ i ] ] == 0 ) return false ;\n    count [ str4 [ i ] ] -- ;\n  }\n  return true ;\n}\n", "SUM_MINIMUM_MAXIMUM_ELEMENTS_SUBARRAYS_SIZE_K": "public static int SumOfKsubArray ( int arr [ ] , int k ) {\n  int sum = 0 ;\n  Deque < Integer > S = new LinkedList < > ( ) , G = new LinkedList < > ( ) ;\n  int i = 0 ;\n  for ( i = 0 ;\n  i < k ;\n  i ++ ) {\n    while ( ! S . isEmpty ( ) && arr [ S . peekLast ( ) ] >= arr [ i ] ) S . removeLast ( ) ;\n    while ( ! G . isEmpty ( ) && arr [ G . peekLast ( ) ] <= arr [ i ] ) G . removeLast ( ) ;\n    G . addLast ( i ) ;\n    S . addLast ( i ) ;\n  }\n  for ( ;\n  i < arr . length ;\n  i ++ ) {\n    sum += arr [ S . peekFirst ( ) ] + arr [ G . peekFirst ( ) ] ;\n    while ( ! S . isEmpty ( ) && S . peekFirst ( ) <= i - k ) S . removeFirst ( ) ;\n    while ( ! G . isEmpty ( ) && G . peekFirst ( ) <= i - k ) G . removeFirst ( ) ;\n    while ( ! S . isEmpty ( ) && arr [ S . peekLast ( ) ] >= arr [ i ] ) S . removeLast ( ) ;\n    while ( ! G . isEmpty ( ) && arr [ G . peekLast ( ) ] <= arr [ i ] ) G . removeLast ( ) ;\n    G . addLast ( i ) ;\n    S . addLast ( i ) ;\n  }\n  sum += arr [ S . peekFirst ( ) ] + arr [ G . peekFirst ( ) ] ;\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": "static long findMinSum ( long a [ ] , long b [ ] , long n ) {\n  Arrays . sort ( a ) ;\n  Arrays . sort ( b ) ;\n  long sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum = sum + Math . abs ( a [ i ] - b [ i ] ) ;\n  return sum ;\n}\n", "COUNT_DISTINCT_NON_NEGATIVE_PAIRS_X_Y_SATISFY_INEQUALITY_XX_YY_N_2": "static 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": "static int countOps ( int A [ ] [ ] , int B [ ] [ ] , 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 += Math . abs ( A [ i ] [ 0 ] ) ;\n  for ( int j = 0 ;\n  j < m ;\n  j ++ ) result += Math . 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": "static int FirstRepeated ( String str ) {\n  int checker = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  ++ i ) {\n    int val = ( str . charAt ( 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": "static void find_max ( int [ ] A , int N , int K ) {\n  HashMap < Integer , Integer > Count = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < K - 1 ;\n  i ++ ) if ( Count . containsKey ( A [ i ] ) ) Count . put ( A [ i ] , 1 + Count . get ( A [ i ] ) ) ;\n  else Count . put ( A [ i ] , 1 ) ;\n  TreeSet < Integer > Myset = new TreeSet < Integer > ( ) ;\n  for ( Map . Entry x : Count . entrySet ( ) ) {\n    if ( Integer . parseInt ( String . valueOf ( x . getValue ( ) ) ) == 1 ) Myset . add ( Integer . parseInt ( String . valueOf ( x . getKey ( ) ) ) ) ;\n  }\n  for ( int i = K - 1 ;\n  i < N ;\n  i ++ ) {\n    if ( Count . containsKey ( A [ i ] ) ) Count . put ( A [ i ] , 1 + Count . get ( A [ i ] ) ) ;\n    else Count . put ( A [ i ] , 1 ) ;\n    if ( Integer . parseInt ( String . valueOf ( Count . get ( A [ i ] ) ) ) == 1 ) Myset . add ( A [ i ] ) ;\n    else Myset . remove ( A [ i ] ) ;\n    if ( Myset . size ( ) == 0 ) System . out . println ( \"Nothing\" ) ;\n    else System . out . println ( Myset . last ( ) ) ;\n    int x = A [ i - K + 1 ] ;\n    Count . put ( x , Count . get ( x ) - 1 ) ;\n    if ( Integer . parseInt ( String . valueOf ( Count . get ( x ) ) ) == 1 ) Myset . add ( x ) ;\n    if ( Integer . parseInt ( String . valueOf ( Count . get ( x ) ) ) == 0 ) Myset . remove ( x ) ;\n  }\n}\n", "MINIMUM_COST_SORT_MATRIX_NUMBERS_0_N2_1": "public static int calculateEnergy ( int mat [ ] [ ] , 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 += Math . abs ( i_des - i ) + Math . abs ( j_des - j ) ;\n    }\n  }\n  return tot_energy ;\n}\n", "LONGEST_COMMON_SUBSTRING": "static int LCSubStr ( char X [ ] , char Y [ ] , int m , int n ) {\n  int LCStuff [ ] [ ] = new int [ 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 ) LCStuff [ i ] [ j ] = 0 ;\n      else if ( X [ i - 1 ] == Y [ j - 1 ] ) {\n        LCStuff [ i ] [ j ] = LCStuff [ i - 1 ] [ j - 1 ] + 1 ;\n        result = Integer . max ( result , LCStuff [ i ] [ j ] ) ;\n      }\n      else LCStuff [ i ] [ j ] = 0 ;\n    }\n  }\n  return result ;\n}\n", "MAXIMUM_SUM_BITONIC_SUBARRAY": "static int maxSumBitonicSubArr ( int arr [ ] , int n ) {\n  int [ ] msis = new int [ n ] ;\n  int [ ] msds = new int [ n ] ;\n  int max_sum = Integer . MIN_VALUE ;\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": "static 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": "static void printAllAPTriplets ( int [ ] arr , int n ) {\n  ArrayList < Integer > s = new ArrayList < Integer > ( ) ;\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      boolean exists = s . contains ( arr [ i ] - diff ) ;\n      if ( exists ) System . out . println ( arr [ i ] - diff + \" \" + arr [ i ] + \" \" + arr [ j ] ) ;\n    }\n    s . add ( arr [ i ] ) ;\n  }\n}\n", "QUERIES_COUNTS_ARRAY_ELEMENTS_VALUES_GIVEN_RANGE": "static 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": "static int maxRevenue ( int m , int [ ] x , int [ ] revenue , int n , int t ) {\n  int [ ] maxRev = new int [ m + 1 ] ;\n  for ( int i = 0 ;\n  i < m + 1 ;\n  i ++ ) maxRev [ i ] = 0 ;\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 ] = Math . max ( maxRev [ i - 1 ] , revenue [ nxtbb ] ) ;\n        else maxRev [ i ] = Math . 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": "static void printMat ( int degseq [ ] , int n ) {\n  int [ ] [ ] mat = new int [ n ] [ n ] ;\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  System . out . print ( \"\\n\" + setw ( 3 ) + \"     \" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) System . out . print ( setw ( 3 ) + \"(\" + i + \")\" ) ;\n  System . out . print ( \"\\n\\n\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( setw ( 4 ) + \"(\" + i + \")\" ) ;\n    for ( int j = 0 ;\n    j < n ;\n    j ++ ) System . out . print ( setw ( 5 ) + mat [ i ] [ j ] ) ;\n    System . out . print ( \"\\n\" ) ;\n  }\n}\n", "DETECT_IF_TWO_INTEGERS_HAVE_OPPOSITE_SIGNS": "static boolean oppositeSigns ( int x , int y ) {\n  return ( ( x ^ y ) < 0 ) ;\n}\n", "TRIANGULAR_NUMBERS_1": "static boolean 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 + ( float ) Math . sqrt ( d ) ) / ( 2 * a ) ;\n  float root2 = ( - b - ( float ) Math . sqrt ( d ) ) / ( 2 * a ) ;\n  if ( root1 > 0 && Math . floor ( root1 ) == root1 ) return true ;\n  if ( root2 > 0 && Math . floor ( root2 ) == root2 ) return true ;\n  return false ;\n}\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT": "static int 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": "static 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": "static void sortByPattern ( char [ ] str , char [ ] pat ) {\n  int count [ ] = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < str . length ;\n  i ++ ) {\n    count [ str [ i ] - 'a' ] ++ ;\n  }\n  int index = 0 ;\n  for ( int i = 0 ;\n  i < pat . length ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < count [ pat [ i ] - 'a' ] ;\n    j ++ ) {\n      str [ index ++ ] = pat [ i ] ;\n    }\n  }\n}\n", "NUMBER_VISIBLE_BOXES_PUTTING_ONE_INSIDE_ANOTHER": "static int minimumBox ( int [ ] arr , int n ) {\n  Queue < Integer > q = new LinkedList < > ( ) ;\n  Arrays . sort ( arr ) ;\n  q . add ( arr [ 0 ] ) ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    int now = q . element ( ) ;\n    if ( arr [ i ] >= 2 * now ) q . remove ( ) ;\n    q . add ( arr [ i ] ) ;\n  }\n  return q . size ( ) ;\n}\n", "SEARCH_INSERT_AND_DELETE_IN_A_SORTED_ARRAY": "static 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  System . out . println ( \"The repeating elements are : \" ) ;\n  for ( i = 0 ;\n  i < size ;\n  i ++ ) {\n    if ( arr [ Math . abs ( arr [ i ] ) ] > 0 ) arr [ Math . abs ( arr [ i ] ) ] = - arr [ Math . abs ( arr [ i ] ) ] ;\n    else System . out . print ( Math . abs ( arr [ i ] ) + \" \" ) ;\n  }\n}\n", "COUNT_POSSIBLE_GROUPS_SIZE_2_3_SUM_MULTIPLE_3": "int findgroups ( int arr [ ] , int n ) {\n  int c [ ] = new int [ ] {\n    0 , 0 , 0 };\n    int 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": "static void printStringAlternate ( String str ) {\n  int [ ] occ = new int [ 122 ] ;\n  String s = str . toLowerCase ( ) ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    char temp = s . charAt ( i ) ;\n    occ [ temp ] ++ ;\n    if ( occ [ temp ] % 2 != 0 ) System . out . print ( str . charAt ( i ) ) ;\n  }\n  System . out . println ( ) ;\n}\n", "NUMBER_DAYS_TANK_WILL_BECOME_EMPTY": "static int minDaysToEmpty ( int C , int l ) {\n  if ( l >= C ) return C ;\n  double eq_root = ( Math . sqrt ( 1 + 8 * ( C - l ) ) - 1 ) / 2 ;\n  return ( int ) ( Math . ceil ( eq_root ) + l ) ;\n}\n", "REVERSE_STRING_WITHOUT_USING_ANY_TEMPORARY_VARIABLE": "static String reversingString ( char [ ] 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 String . valueOf ( str ) ;\n}\n", "FREQUENCY_ELEMENT_UNSORTED_ARRAY": "static void countFreq ( int [ ] a , int n ) {\n  HashMap < Integer , Integer > hm = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) hm . put ( a [ i ] , hm . get ( a [ i ] ) == null ? 1 : hm . get ( a [ i ] ) + 1 ) ;\n  SortedMap < Integer , Integer > st = new TreeMap < > ( ) ;\n  for ( HashMap . Entry < Integer , Integer > x : hm . entrySet ( ) ) {\n    st . put ( x . getKey ( ) , x . getValue ( ) ) ;\n  }\n  int cumul = 0 ;\n  for ( SortedMap . Entry < Integer , Integer > x : st . entrySet ( ) ) {\n    cumul += x . getValue ( ) ;\n    System . out . println ( x . getKey ( ) + \" \" + cumul ) ;\n  }\n}\n", "FIND_ROTATION_COUNT_ROTATED_SORTED_ARRAY": "static int countRotations ( int arr [ ] , int n ) {\n  int min = arr [ 0 ] , min_index = - 1 ;\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": "static int lis ( int arr [ ] , int n ) {\n  int lis [ ] = new int [ n ] ;\n  int i , j , max = 0 ;\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  for ( i = 0 ;\n  i < n ;\n  i ++ ) if ( max < lis [ i ] ) max = lis [ i ] ;\n  return max ;\n}\n", "MEDIAN_OF_TWO_SORTED_ARRAYS": "static 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": "static String minLexRotation ( String str ) {\n  int n = str . length ( ) ;\n  String arr [ ] = new String [ n ] ;\n  String concat = str + str ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    arr [ i ] = concat . substring ( i , i + n ) ;\n  }\n  Arrays . sort ( arr ) ;\n  return arr [ 0 ] ;\n}\n", "INTERPOLATION_SEARCH": "static int interpolationSearch ( int x ) {\n  int lo = 0 , hi = ( arr . length - 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 + ( ( ( 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": "static 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": "static int countSubsets ( int arr [ ] , int n ) {\n  HashSet < Integer > us = new HashSet < > ( ) ;\n  int even_count = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( arr [ i ] % 2 == 0 ) us . add ( arr [ i ] ) ;\n  even_count = us . size ( ) ;\n  return ( int ) ( Math . pow ( 2 , even_count ) - 1 ) ;\n}\n", "COUNT_NUMBER_OF_OCCURRENCES_OR_FREQUENCY_IN_A_SORTED_ARRAY": "static 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": "static int [ ] Restore_Tree ( int [ ] S , int [ ] End ) {\n  int [ ] Identity = new int [ N ] ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) Identity [ S [ i ] ] = i ;\n  int [ ] parent = new int [ N ] ;\n  Arrays . fill ( parent , - 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 {\n      parent [ child ] = curr_parent ;\n      while ( parent [ child ] > - 1 && End [ child ] == End [ parent [ child ] ] ) {\n        child = parent [ child ] ;\n        curr_parent = parent [ child ] ;\n        if ( curr_parent == Identity [ 0 ] ) break ;\n      }\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": "static int countOccurrences ( String s , int K ) {\n  int n = s . length ( ) ;\n  int C = 0 , c1 = 0 , c2 = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( s . charAt ( i ) == 'a' ) c1 ++ ;\n    if ( s . charAt ( i ) == 'b' ) {\n      c2 ++ ;\n      C += c1 ;\n    }\n  }\n  return C * K + ( K * ( K - 1 ) / 2 ) * c1 * c2 ;\n}\n", "NUMBER_SUBSTRINGS_STRING": "static int countNonEmptySubstr ( String str ) {\n  int n = str . length ( ) ;\n  return n * ( n + 1 ) / 2 ;\n}\n", "MAXIMUM_NUMBER_CHARACTERS_TWO_CHARACTER_STRING_1": "static int maximumChars ( String str ) {\n  int n = str . length ( ) ;\n  int res = - 1 ;\n  int [ ] firstInd = new int [ 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 . charAt ( i ) ] ;\n    if ( first_ind == - 1 ) firstInd [ str . charAt ( i ) ] = i ;\n    else res = Math . max ( res , Math . abs ( i - first_ind - 1 ) ) ;\n  }\n  return res ;\n}\n", "SUM_SQUARES_BINOMIAL_COEFFICIENTS": "static int sumofsquare ( int n ) {\n  int [ ] [ ] C = new int [ 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 ( 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": "static void printSubsequences ( String s ) {\n  char [ ] str = s . toCharArray ( ) ;\n  int n = str . length ;\n  int opsize = ( int ) ( Math . 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      System . out . print ( str [ j ] ) ;\n      if ( ( counter & ( 1 << j ) ) > 0 ) System . out . print ( \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "NON_REPEATING_ELEMENT": "static 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": "static long calculateSum ( int n ) {\n  long 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": "static boolean arekAnagrams ( String str1 , String str2 , int k ) {\n  int n = str1 . length ( ) ;\n  if ( str2 . length ( ) != n ) return false ;\n  int [ ] count1 = new int [ MAX_CHAR ] ;\n  int [ ] count2 = new int [ MAX_CHAR ] ;\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) count1 [ str1 . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) count2 [ str2 . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < MAX_CHAR ;\n  i ++ ) if ( count1 [ i ] > count2 [ i ] ) count = count + Math . abs ( count1 [ i ] - count2 [ i ] ) ;\n  return ( count <= k ) ;\n}\n", "LONGEST_SPAN_SUM_TWO_BINARY_ARRAYS": "static int longestCommonSum ( 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": "static 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 . length ( ) - 1 ;\n    i >= 0 ;\n    i -- ) {\n      int digit = num . charAt ( 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": "static boolean prevPermutation ( char [ ] str ) {\n  int n = str . length - 1 ;\n  int i = n ;\n  while ( i > 0 && str [ i - 1 ] <= str [ i ] ) {\n    i -- ;\n  }\n  if ( i <= 0 ) {\n    return false ;\n  }\n  int j = i - 1 ;\n  while ( j + 1 <= n && str [ j + 1 ] <= str [ i - 1 ] ) {\n    j ++ ;\n  }\n  swap ( str , i - 1 , j ) ;\n  StringBuilder sb = new StringBuilder ( String . valueOf ( str ) ) ;\n  sb . reverse ( ) ;\n  str = sb . toString ( ) . toCharArray ( ) ;\n  return true ;\n}\n", "NUMBER_SUBSEQUENCES_FORM_AI_BJ_CK": "static int countSubsequences ( String s ) {\n  int aCount = 0 ;\n  int bCount = 0 ;\n  int cCount = 0 ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    if ( s . charAt ( i ) == 'a' ) aCount = ( 1 + 2 * aCount ) ;\n    else if ( s . charAt ( i ) == 'b' ) bCount = ( aCount + 2 * bCount ) ;\n    else if ( s . charAt ( i ) == 'c' ) cCount = ( bCount + 2 * cCount ) ;\n  }\n  return cCount ;\n}\n", "PROGRAM_PRINT_IDENTITY_MATRIX_1": "static boolean isIdentity ( int mat [ ] [ ] , 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": "static int maxDiff ( int [ ] arr , int n ) {\n  int result = 0 ;\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    if ( arr [ i ] != arr [ i + 1 ] ) result += Math . abs ( arr [ i ] ) ;\n    else i ++ ;\n  }\n  if ( arr [ n - 2 ] != arr [ n - 1 ] ) result += Math . abs ( arr [ n - 1 ] ) ;\n  return result ;\n}\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM": "static int summingSeries ( long n ) {\n  int S = 0 ;\n  for ( i = 1 ;\n  i <= n ;\n  i ++ ) S += i * i - ( i - 1 ) * ( i - 1 ) ;\n  return S ;\n}\n", "PREFIX_SUM_2D_ARRAY": "public static void prefixSum2D ( int a [ ] [ ] ) {\n  int R = a . length ;\n  int C = a [ 0 ] . length ;\n  int psa [ ] [ ] = new int [ 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 = 1 ;\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 ++ ) 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  for ( int i = 0 ;\n  i < R ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < C ;\n    j ++ ) System . out . print ( psa [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "MAXIMUM_NUMBER_2X2_SQUARES_CAN_FIT_INSIDE_RIGHT_ISOSCELES_TRIANGLE": "public static 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 [ ] , int n ) {\n  int m = 0 ;\n  for ( int i = 0 ;\n  i < n ;\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": "static boolean 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 < Math . min ( str1 . length ( ) , str2 . length ( ) ) ;\n  i ++ ) {\n    if ( str1 == str2 ) 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 i ;\n  int res = 0 ;\n  for ( i = 0 ;\n  i < ar_size ;\n  i ++ ) {\n    res = res ^ ar [ i ] ;\n  }\n  return res ;\n}\n", "SUM_MIDDLE_ROW_COLUMN_MATRIX": "static void middlesum ( int mat [ ] [ ] , 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  System . out . println ( \"Sum of middle row = \" + row_sum ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) col_sum += mat [ i ] [ n / 2 ] ;\n  System . out . println ( \"Sum of middle column = \" + col_sum ) ;\n}\n", "K_TH_DISTINCT_OR_NON_REPEATING_ELEMENT_IN_AN_ARRAY": "static 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": "public static void mergeIntervals ( Interval arr [ ] ) {\n  Arrays . sort ( arr , new Comparator < Interval > ( ) {\n    public int compare ( Interval i1 , Interval i2 ) {\n      return i2 . start - i1 . start ;\n    }\n  }\n  ) ;\n  int index = 0 ;\n  for ( int i = 1 ;\n  i < arr . length ;\n  i ++ ) {\n    if ( arr [ index ] . end >= arr [ i ] . start ) {\n      arr [ index ] . end = Math . max ( arr [ index ] . end , arr [ i ] . end ) ;\n      arr [ index ] . start = Math . min ( arr [ index ] . start , arr [ i ] . start ) ;\n    }\n    else {\n      arr [ index ] = arr [ i ] ;\n      index ++ ;\n    }\n  }\n  System . out . print ( \"The Merged Intervals are: \" ) ;\n  for ( int i = 0 ;\n  i <= index ;\n  i ++ ) {\n    System . out . print ( \"[\" + arr [ i ] . start + \",\" + arr [ i ] . end + \"]\" ) ;\n  }\n}\n", "FIND_NUMBER_PERFECT_SQUARES_TWO_GIVEN_NUMBERS_1": "double countSquares ( int a , int b ) {\n  return ( Math . floor ( Math . sqrt ( b ) ) - Math . ceil ( Math . sqrt ( a ) ) + 1 ) ;\n}\n", "LARGEST_SUBSET_WHOSE_ALL_ELEMENTS_ARE_FIBONACCI_NUMBERS": "public static void findFibSubset ( Integer [ ] x ) {\n  Integer max = Collections . max ( Arrays . asList ( x ) ) ;\n  List < Integer > fib = new ArrayList < Integer > ( ) ;\n  List < Integer > result = new ArrayList < Integer > ( ) ;\n  Integer a = 0 ;\n  Integer b = 1 ;\n  while ( b < max ) {\n    Integer c = a + b ;\n    a = b ;\n    b = c ;\n    fib . add ( c ) ;\n  }\n  for ( Integer i = 0 ;\n  i < x . length ;\n  i ++ ) {\n    if ( fib . contains ( x [ i ] ) ) {\n      result . add ( x [ i ] ) ;\n    }\n  }\n  System . out . println ( result ) ;\n}\n", "LEXICOGRAPHICAL_CONCATENATION_SUBSTRINGS_STRING": "static String lexicographicSubConcat ( String s ) {\n  int n = s . length ( ) ;\n  int sub_count = n * ( n + 1 ) / 2 ;\n  String [ ] arr = new String [ 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 ++ ) {\n    arr [ index ++ ] = s . substring ( i , i + len ) ;\n  }\n  Arrays . sort ( arr ) ;\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": "static int abFree ( char [ ] s ) {\n  int b_count = 0 ;\n  int res = 0 ;\n  for ( int i = 0 ;\n  i < s . length ;\n  i ++ ) {\n    if ( s [ s . length - 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": "static int MaximumHeight ( int a [ ] , int n ) {\n  return ( int ) Math . floor ( ( - 1 + Math . sqrt ( 1 + ( 8 * n ) ) ) / 2 ) ;\n}\n", "MAXIMIZE_VOLUME_CUBOID_GIVEN_SUM_SIDES": "static 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 = Math . max ( maxvalue , i * j * k ) ;\n    }\n  }\n  return maxvalue ;\n}\n", "PROGRAM_DECIMAL_HEXADECIMAL_CONVERSION": "static void decToHexa ( int n ) {\n  char [ ] hexaDeciNum = new char [ 100 ] ;\n  int i = 0 ;\n  while ( n != 0 ) {\n    int temp = 0 ;\n    temp = n % 16 ;\n    if ( temp < 10 ) {\n      hexaDeciNum [ i ] = ( char ) ( temp + 48 ) ;\n      i ++ ;\n    }\n    else {\n      hexaDeciNum [ i ] = ( char ) ( temp + 55 ) ;\n      i ++ ;\n    }\n    n = n / 16 ;\n  }\n  for ( int j = i - 1 ;\n  j >= 0 ;\n  j -- ) System . out . print ( hexaDeciNum [ j ] ) ;\n}\n", "SMALLEST_SUBARRAY_WITH_ALL_OCCURRENCES_OF_A_MOST_FREQUENT_ELEMENT": "static void smallestSubsegment ( int a [ ] , int n ) {\n  HashMap < Integer , Integer > left = new HashMap < Integer , Integer > ( ) ;\n  HashMap < Integer , Integer > count = new HashMap < Integer , Integer > ( ) ;\n  int mx = 0 ;\n  int mn = - 1 , strindex = - 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int x = a [ i ] ;\n    if ( count . get ( x ) == null ) {\n      left . put ( x , i ) ;\n      count . put ( x , 1 ) ;\n    }\n    else count . put ( x , count . get ( x ) + 1 ) ;\n    if ( count . get ( x ) > mx ) {\n      mx = count . get ( x ) ;\n      mn = i - left . get ( x ) + 1 ;\n      strindex = left . get ( x ) ;\n    }\n    else if ( ( count . get ( x ) == mx ) && ( i - left . get ( x ) + 1 < mn ) ) {\n      mn = i - left . get ( x ) + 1 ;\n      strindex = left . get ( x ) ;\n    }\n  }\n  for ( int i = strindex ;\n  i < strindex + mn ;\n  i ++ ) System . out . print ( a [ i ] + \" \" ) ;\n}\n", "FIND_LAST_INDEX_CHARACTER_STRING_1": "static int findLastIndex ( String str , Character x ) {\n  for ( int i = str . length ( ) - 1 ;\n  i >= 0 ;\n  i -- ) if ( str . charAt ( i ) == x ) return i ;\n  return - 1 ;\n}\n", "RECAMANS_SEQUENCE": "static void recaman ( int n ) {\n  int arr [ ] = new int [ n ] ;\n  arr [ 0 ] = 0 ;\n  System . out . print ( 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    System . out . print ( arr [ i ] + \", \" ) ;\n  }\n}\n", "C_PROGRAM_FIND_SECOND_FREQUENT_CHARACTER": "static char getSecondMostFreq ( String str ) {\n  int [ ] count = new int [ NO_OF_CHARS ] ;\n  int i ;\n  for ( i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) ( count [ str . charAt ( 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 ( char ) second ;\n}\n", "FIND_MAXIMUM_HEIGHT_PYRAMID_FROM_THE_GIVEN_ARRAY_OF_OBJECTS": "static int maxLevel ( int [ ] boxes , int n ) {\n  Arrays . sort ( boxes ) ;\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": "static int getInvCount ( 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": "static void diagonalsquare ( int mat [ ] [ ] , int row , int column ) {\n  System . out . print ( \"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 ) System . out . print ( mat [ i ] [ j ] * mat [ i ] [ j ] + \" \" ) ;\n  }\n  System . out . println ( ) ;\n  System . out . print ( \"Diagonal 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 ) System . out . print ( mat [ i ] [ j ] * mat [ i ] [ j ] + \" \" ) ;\n  }\n}\n", "ROW_WISE_COMMON_ELEMENTS_TWO_DIAGONALS_SQUARE_MATRIX": "static int countCommon ( int mat [ ] [ ] , 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": "public static 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": "static boolean 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": "static 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": "static int maximumDifferenceSum ( int arr [ ] , int N ) {\n  int dp [ ] [ ] = new int [ 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 ] = Math . max ( dp [ i ] [ 0 ] , dp [ i ] [ 1 ] + Math . abs ( 1 - arr [ i ] ) ) ;\n    dp [ i + 1 ] [ 1 ] = Math . max ( dp [ i ] [ 0 ] + Math . abs ( arr [ i + 1 ] - 1 ) , dp [ i ] [ 1 ] + Math . abs ( arr [ i + 1 ] - arr [ i ] ) ) ;\n  }\n  return Math . max ( dp [ N - 1 ] [ 0 ] , dp [ N - 1 ] [ 1 ] ) ;\n}\n", "STERN_BROCOT_SEQUENCE": "static void SternSequenceFunc ( Vector < Integer > BrocotSequence , int n ) {\n  for ( int i = 1 ;\n  BrocotSequence . size ( ) < n ;\n  i ++ ) {\n    int considered_element = BrocotSequence . get ( i ) ;\n    int precedent = BrocotSequence . get ( i - 1 ) ;\n    BrocotSequence . add ( considered_element + precedent ) ;\n    BrocotSequence . add ( considered_element ) ;\n  }\n  for ( int i = 0 ;\n  i < 15 ;\n  ++ i ) System . out . print ( BrocotSequence . get ( i ) + \" \" ) ;\n}\n", "NUMBER_SUBSEQUENCES_STRING_DIVISIBLE_N": "static int countDivisibleSubseq ( String str , int n ) {\n  int len = str . length ( ) ;\n  int dp [ ] [ ] = new int [ len ] [ n ] ;\n  dp [ 0 ] [ ( str . charAt ( 0 ) - '0' ) % n ] ++ ;\n  for ( int i = 1 ;\n  i < len ;\n  i ++ ) {\n    dp [ i ] [ ( str . charAt ( 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 . charAt ( i ) - '0' ) ) % n ] += dp [ i - 1 ] [ j ] ;\n    }\n  }\n  return dp [ len - 1 ] [ 0 ] ;\n}\n", "HOW_TO_BEGIN_WITH_COMPETITIVE_PROGRAMMING": "static 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": "static int getPairsCount ( int n , int sum ) {\n  HashMap < Integer , Integer > hm = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! hm . containsKey ( arr [ i ] ) ) hm . put ( arr [ i ] , 0 ) ;\n    hm . put ( arr [ i ] , hm . get ( arr [ i ] ) + 1 ) ;\n  }\n  int twice_count = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( hm . get ( sum - arr [ i ] ) != null ) twice_count += hm . get ( 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 = Integer . MAX_VALUE ;\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 > Math . abs ( i - j ) ) min_dist = Math . abs ( i - j ) ;\n    }\n  }\n  return min_dist ;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_2": "static 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 shortestPath ( int graph [ ] [ ] , int u , int v , int k ) {\n  int sp [ ] [ ] [ ] = new int [ 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 ] = Math . 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": "static void longest ( int a [ ] , int n , int k ) {\n  int [ ] freq = new int [ 7 ] ;\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 ) {\n      end = i ;\n      start = l ;\n    }\n  }\n  for ( int i = start ;\n  i <= end ;\n  i ++ ) System . out . print ( a [ i ] + \" \" ) ;\n}\n", "MAXIMUM_XOR_VALUE_MATRIX": "static int maxXOR ( int mat [ ] [ ] , 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 ;\n    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 < Math . max ( r_xor , c_xor ) ) max_xor = Math . max ( r_xor , c_xor ) ;\n  }\n  return max_xor ;\n}\n", "LENGTH_LONGEST_SUB_STRING_CAN_MAKE_REMOVED": "static int longestNull ( String str ) {\n  ArrayList < Pair > arr = new ArrayList < > ( ) ;\n  arr . add ( new Pair ( '@' , - 1 ) ) ;\n  int maxlen = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  ++ i ) {\n    arr . add ( new Pair ( str . charAt ( i ) , i ) ) ;\n    while ( arr . size ( ) >= 3 && arr . get ( arr . size ( ) - 3 ) . first == '1' && arr . get ( arr . size ( ) - 2 ) . first == '0' && arr . get ( arr . size ( ) - 1 ) . first == '0' ) {\n      arr . remove ( arr . size ( ) - 3 ) ;\n      arr . remove ( arr . size ( ) - 2 ) ;\n      arr . remove ( arr . size ( ) - 1 ) ;\n    }\n    int tmp = arr . get ( arr . size ( ) - 1 ) . second ;\n    maxlen = Math . max ( maxlen , i - tmp ) ;\n  }\n  return maxlen ;\n}\n", "LONGEST_ALTERNATING_SUB_ARRAY_STARTING_EVERY_INDEX_BINARY_ARRAY": "static void alternateSubarray ( boolean arr [ ] , int n ) {\n  int len [ ] = new int [ n ] ;\n  len [ n - 1 ] = 1 ;\n  for ( int i = n - 2 ;\n  i >= 0 ;\n  -- i ) {\n    if ( arr [ i ] ^ arr [ i + 1 ] == true ) len [ i ] = len [ i + 1 ] + 1 ;\n    else len [ i ] = 1 ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) System . out . print ( len [ i ] + \" \" ) ;\n}\n", "WILDCARD_CHARACTER_MATCHING": "static boolean match ( String first , String second ) {\n  if ( first . length ( ) == 0 && second . length ( ) == 0 ) return true ;\n  if ( first . length ( ) > 1 && first . charAt ( 0 ) == '*' && second . length ( ) == 0 ) return false ;\n  if ( ( first . length ( ) > 1 && first . charAt ( 0 ) == '?' ) || ( first . length ( ) != 0 && second . length ( ) != 0 && first . charAt ( 0 ) == second . charAt ( 0 ) ) ) return match ( first . substring ( 1 ) , second . substring ( 1 ) ) ;\n  if ( first . length ( ) > 0 && first . charAt ( 0 ) == '*' ) return match ( first . substring ( 1 ) , second ) || match ( first , second . substring ( 1 ) ) ;\n  return false ;\n}\n", "FIND_FACTORIAL_NUMBERS_LESS_EQUAL_N": "static void printFactorialNums ( int n ) {\n  int fact = 1 ;\n  int x = 2 ;\n  while ( fact <= n ) {\n    System . out . print ( fact + \" \" ) ;\n    fact = fact * x ;\n    x ++ ;\n  }\n}\n", "FRIENDS_PAIRING_PROBLEM_2": "static 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": "static int maxArea ( int mat [ ] [ ] ) {\n  int hist [ ] [ ] = new int [ 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 ++ ) {\n      hist [ j ] [ i ] = ( mat [ j ] [ i ] == 0 ) ? 0 : hist [ j - 1 ] [ i ] + 1 ;\n    }\n  }\n  for ( int i = 0 ;\n  i < R ;\n  i ++ ) {\n    int count [ ] = new int [ R + 1 ] ;\n    for ( int j = 0 ;\n    j < C ;\n    j ++ ) {\n      count [ hist [ i ] [ j ] ] ++ ;\n    }\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 ) {\n        max_area = curr_area ;\n      }\n    }\n  }\n  return max_area ;\n}\n", "SUM_SEQUENCE_2_22_222": "static double sumOfSeries ( int n ) {\n  return 0.0246 * ( Math . pow ( 10 , n ) - 1 - ( 9 * n ) ) ;\n}\n", "PROGRAM_FIRST_FIT_ALGORITHM_MEMORY_MANAGEMENT": "static void firstFit ( int blockSize [ ] , int m , int processSize [ ] , int n ) {\n  int allocation [ ] = new int [ n ] ;\n  for ( int i = 0 ;\n  i < allocation . length ;\n  i ++ ) allocation [ i ] = - 1 ;\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  System . out . println ( \"\\nProcess No.\\tProcess Size\\tBlock no.\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( \" \" + ( i + 1 ) + \"\\t\\t\" + processSize [ i ] + \"\\t\\t\" ) ;\n    if ( allocation [ i ] != - 1 ) System . out . print ( allocation [ i ] + 1 ) ;\n    else System . out . print ( \"Not Allocated\" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "CHECK_IF_A_NUMBER_IS_POWER_OF_ANOTHER_NUMBER": "public static boolean isPower ( int x , int y ) {\n  if ( x == 1 ) return ( y == 1 ) ;\n  int pow = 1 ;\n  while ( pow < y ) pow = pow * x ;\n  return ( pow == y ) ;\n}\n", "DIVIDE_LARGE_NUMBER_REPRESENTED_STRING": "static String longDivision ( String number , int divisor ) {\n  String ans = \"\" ;\n  int idx = 0 ;\n  char [ ] num = number . toCharArray ( ) ;\n  int temp = num [ idx ] - '0' ;\n  while ( temp < divisor ) temp = temp * 10 + ( num [ ++ idx ] - '0' ) ;\n  idx += 1 ;\n  while ( num . length > idx ) {\n    ans += ( temp / divisor ) ;\n    temp = ( temp % divisor ) * 10 + num [ idx ++ ] - '0' ;\n  }\n  if ( ans . length ( ) == 0 ) return \"0\" ;\n  return ans ;\n}\n", "FIND_ROW_NUMBER_BINARY_MATRIX_MAXIMUM_NUMBER_1S": "static void findMax ( int arr [ ] [ ] ) {\n  int row = 0 , i , j ;\n  for ( i = 0 , j = N - 1 ;\n  i < N ;\n  i ++ ) {\n    while ( j >= 0 && arr [ i ] [ j ] == 1 ) {\n      row = i ;\n      j -- ;\n    }\n  }\n  System . out . print ( \"Row number = \" + ( row + 1 ) ) ;\n  System . out . print ( \", MaxCount = \" + ( N - 1 - j ) ) ;\n}\n", "MINIMUM_ROTATIONS_REQUIRED_GET_STRING": "static 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 . substring ( i , str . length ( ) ) ;\n    if ( str == substring ) return i ;\n  }\n  return n ;\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX": "static 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": "public static 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}\n", "SUM_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING_1": "static int sumAtKthLevel ( String tree , int k , int level ) {\n  if ( tree . charAt ( i ++ ) == '(' ) {\n    if ( tree . charAt ( i ) == ')' ) return 0 ;\n    int sum = 0 ;\n    if ( level == k ) sum = tree . charAt ( i ) - '0' ;\n    ++ i ;\n    int leftsum = sumAtKthLevel ( tree , k , level + 1 ) ;\n    ++ i ;\n    int rightsum = sumAtKthLevel ( tree , k , level + 1 ) ;\n    ++ i ;\n    return sum + leftsum + rightsum ;\n  }\n  return Integer . MIN_VALUE ;\n}\n", "COUNT_OFDIFFERENT_WAYS_EXPRESS_N_SUM_1_3_4": "static int countWays ( int n ) {\n  int DP [ ] = new int [ 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": "static int findMaxSum ( int [ ] arr , int n ) {\n  int res = Integer . MIN_VALUE ;\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 = Math . max ( res , prefix_sum ) ;\n  }\n  return res ;\n}\n", "STEINS_ALGORITHM_FOR_FINDING_GCD_1": "static 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 ) == 1 ) {\n    if ( ( b & 1 ) == 1 ) return gcd ( a >> 1 , b ) ;\n    else return gcd ( a >> 1 , b >> 1 ) << 1 ;\n  }\n  if ( ( ~ b & 1 ) == 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": "static 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": "static boolean isRectangle ( int m [ ] [ ] ) {\n  int rows = m . length ;\n  if ( rows == 0 ) return false ;\n  int columns = m [ 0 ] . length ;\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": "static boolean isPossible ( String str , int n ) {\n  int len = str . length ( ) ;\n  if ( len >= n ) return true ;\n  return false ;\n}\n", "CHECK_STAR_GRAPH": "static boolean checkStar ( int mat [ ] [ ] ) {\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 ] == 1 ) 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": "static void printRoots ( int n ) {\n  double theta = 3.14 * 2 / n ;\n  for ( int k = 0 ;\n  k < n ;\n  k ++ ) {\n    double real = Math . cos ( k * theta ) ;\n    double img = Math . sin ( k * theta ) ;\n    System . out . println ( real ) ;\n    if ( img >= 0 ) System . out . println ( \" + i \" ) ;\n    else System . out . println ( \" - i \" ) ;\n    System . out . println ( Math . abs ( img ) ) ;\n  }\n}\n", "FIND_LARGEST_D_IN_ARRAY_SUCH_THAT_A_B_C_D": "static int findLargestd ( int [ ] S , int n ) {\n  boolean found = false ;\n  Arrays . sort ( S ) ;\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 Integer . MAX_VALUE ;\n  return - 1 ;\n}\n", "GIVEN_NUMBER_STRING_FIND_NUMBER_CONTIGUOUS_SUBSEQUENCES_RECURSIVELY_ADD_9_SET_2": "static int count9s ( char number [ ] ) {\n  int n = number . length ;\n  int d [ ] = new int [ 9 ] ;\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 ( ( number [ i ] - '0' ) == 0 ) {\n      continuous_zero ++ ;\n    }\n    else {\n      continuous_zero = 0 ;\n    }\n    mod_sum += ( 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": "static String LexicographicalMaxString ( String str ) {\n  String mx = \"\" ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  ++ i ) {\n    if ( mx . compareTo ( str . substring ( i ) ) <= 0 ) {\n      mx = str . substring ( i ) ;\n    }\n  }\n  return mx ;\n}\n", "CHECK_TWO_GIVEN_SETS_DISJOINT_1": "boolean aredisjoint ( int set1 [ ] , int set2 [ ] ) {\n  int i = 0 , j = 0 ;\n  Arrays . sort ( set1 ) ;\n  Arrays . sort ( set2 ) ;\n  while ( i < set1 . length && j < set2 . length ) {\n    if ( set1 [ i ] < set2 [ j ] ) i ++ ;\n    else if ( set1 [ i ] > set2 [ j ] ) 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": "static float areacircumscribed ( float a ) {\n  float PI = 3.14159265f ;\n  return ( a * a * ( PI / 2 ) ) ;\n}\n", "LONGEST_REPEATING_AND_NON_OVERLAPPING_SUBSTRING": "static String longestRepeatedSubstring ( String str ) {\n  int n = str . length ( ) ;\n  int LCSRe [ ] [ ] = new int [ n + 1 ] [ n + 1 ] ;\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 . charAt ( i - 1 ) == str . charAt ( 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 = Math . max ( i , index ) ;\n        }\n      }\n      else {\n        LCSRe [ i ] [ j ] = 0 ;\n      }\n    }\n  }\n  if ( res_length > 0 ) {\n    for ( i = index - res_length + 1 ;\n    i <= index ;\n    i ++ ) {\n      res += str . charAt ( i - 1 ) ;\n    }\n  }\n  return res ;\n}\n", "HOW_TO_AVOID_OVERFLOW_IN_MODULAR_MULTIPLICATION": "static long mulmod ( long a , long b , long mod ) {\n  long res = 0 ;\n  a = a % mod ;\n  while ( b > 0 ) {\n    if ( b % 2 == 1 ) {\n      res = ( res + a ) % mod ;\n    }\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": "static boolean isProduct ( int arr [ ] , int n , int x ) {\n  HashSet < Integer > hset = new HashSet < > ( ) ;\n  if ( n < 2 ) return false ;\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 ( hset . contains ( x / arr [ i ] ) ) return true ;\n      hset . add ( arr [ i ] ) ;\n    }\n  }\n  return false ;\n}\n", "SUM_K_TH_GROUP_ODD_POSITIVE_NUMBERS": "public static int kthgroupsum ( int k ) {\n  int cur = ( k * ( k - 1 ) ) + 1 ;\n  int sum = 0 ;\n  while ( k -- > 0 ) {\n    sum += cur ;\n    cur += 2 ;\n  }\n  return sum ;\n}\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS_1": "static void findElements ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < n - 2 ;\n  i ++ ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "MINIMUM_STEPS_TO_DELETE_A_STRING_AFTER_REPEATED_DELETION_OF_PALINDROME_SUBSTRINGS": "static int minStepToDeleteString ( String str ) {\n  int N = str . length ( ) ;\n  int [ ] [ ] dp = new int [ 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 . charAt ( i ) == str . charAt ( i + 1 ) ) dp [ i ] [ j ] = Math . min ( 1 + dp [ i + 2 ] [ j ] , dp [ i ] [ j ] ) ;\n        for ( int K = i + 2 ;\n        K <= j ;\n        K ++ ) if ( str . charAt ( i ) == str . charAt ( K ) ) dp [ i ] [ j ] = Math . 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": "static double vol_tetra ( int side ) {\n  double volume = ( Math . pow ( side , 3 ) / ( 6 * Math . sqrt ( 2 ) ) ) ;\n  return volume ;\n}\n", "SIEVE_OF_ATKIN": "static int SieveOfAtkin ( int limit ) {\n  if ( limit > 2 ) System . out . print ( 2 + \" \" ) ;\n  if ( limit > 3 ) System . out . print ( 3 + \" \" ) ;\n  boolean sieve [ ] = new boolean [ 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 ] ) System . out . print ( a + \" \" ) ;\n  return 0 ;\n}\n", "LENGTH_OF_THE_LONGEST_ARITHMATIC_PROGRESSION_IN_A_SORTED_ARRAY": "static int lenghtOfLongestAP ( int set [ ] , int n ) {\n  if ( n <= 2 ) return n ;\n  int L [ ] [ ] = new int [ 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 ;\n        i -- ;\n      }\n      else {\n        L [ i ] [ j ] = L [ j ] [ k ] + 1 ;\n        llap = Math . 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": "static 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": "static int longestCommonSum ( int n ) {\n  int maxLen = 0 ;\n  int preSum1 = 0 , preSum2 = 0 ;\n  int diff [ ] = new int [ 2 * n + 1 ] ;\n  for ( int i = 0 ;\n  i < diff . length ;\n  i ++ ) {\n    diff [ i ] = - 1 ;\n  }\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": "static 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    System . out . print ( f2 + \" \" ) ;\n    int next = f1 + f2 ;\n    f1 = f2 ;\n    f2 = next ;\n  }\n}\n", "LARGEST_SUM_CONTIGUOUS_SUBARRAY_3": "static void maxSubArraySum ( int a [ ] , int size ) {\n  int max_so_far = Integer . MIN_VALUE , 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  System . out . println ( \"Maximum contiguous sum is \" + max_so_far ) ;\n  System . out . println ( \"Starting index \" + start ) ;\n  System . out . println ( \"Ending index \" + end ) ;\n}\n", "FIND_EQUAL_POINT_STRING_BRACKETS": "static int findIndex ( String str ) {\n  int len = str . length ( ) ;\n  int open [ ] = new int [ len + 1 ] ;\n  int close [ ] = new int [ len + 1 ] ;\n  int index = - 1 ;\n  open [ 0 ] = 0 ;\n  close [ len ] = 0 ;\n  if ( str . charAt ( 0 ) == '(' ) open [ 1 ] = 1 ;\n  if ( str . charAt ( len - 1 ) == ')' ) close [ len - 1 ] = 1 ;\n  for ( int i = 1 ;\n  i < len ;\n  i ++ ) {\n    if ( str . charAt ( 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 . charAt ( 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": "static int countP ( int n , int k ) {\n  int [ ] [ ] dp = new int [ 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 <= k ;\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": "static int lis ( int arr [ ] , int n ) {\n  max_ref = 1 ;\n  _lis ( arr , n ) ;\n  return max_ref ;\n}\n", "FIND_REPEATED_CHARACTER_PRESENT_FIRST_STRING": "static int findRepeatFirstN2 ( String s ) {\n  int p = - 1 , i , j ;\n  for ( i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    for ( j = i + 1 ;\n    j < s . length ( ) ;\n    j ++ ) {\n      if ( s . charAt ( i ) == s . charAt ( 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": "static int ksmallest ( int arr [ ] , int n , int k ) {\n  int b [ ] = new int [ MAX ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    b [ arr [ i ] ] = 1 ;\n  }\n  for ( int j = 1 ;\n  j < MAX ;\n  j ++ ) {\n    if ( b [ j ] != 1 ) {\n      k -- ;\n    }\n    if ( k != 1 ) {\n      return j ;\n    }\n  }\n  return Integer . MAX_VALUE ;\n}\n", "CHECK_IF_STACK_ELEMENTS_ARE_PAIRWISE_CONSECUTIVE": "static boolean pairWiseConsecutive ( Stack < Integer > s ) {\n  Stack < Integer > aux = new Stack < Integer > ( ) ;\n  while ( ! s . isEmpty ( ) ) {\n    aux . push ( s . peek ( ) ) ;\n    s . pop ( ) ;\n  }\n  boolean result = true ;\n  while ( aux . size ( ) > 1 ) {\n    int x = aux . peek ( ) ;\n    aux . pop ( ) ;\n    int y = aux . peek ( ) ;\n    aux . pop ( ) ;\n    if ( Math . abs ( x - y ) != 1 ) result = false ;\n    s . push ( x ) ;\n    s . push ( y ) ;\n  }\n  if ( aux . size ( ) == 1 ) s . push ( aux . peek ( ) ) ;\n  return result ;\n}\n", "BINARY_SEARCH_1": "int binarySearch ( int arr [ ] , int x ) {\n  int l = 0 , r = arr . length - 1 ;\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": "static int findSubsequenceCount ( String S , String T ) {\n  int m = T . length ( ) ;\n  int n = S . length ( ) ;\n  if ( m > n ) return 0 ;\n  int mat [ ] [ ] = new int [ 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 . charAt ( i - 1 ) != S . charAt ( 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": "static void swap ( int [ ] xp , int [ ] yp ) {\n  xp [ 0 ] = xp [ 0 ] ^ yp [ 0 ] ;\n  yp [ 0 ] = xp [ 0 ] ^ yp [ 0 ] ;\n  xp [ 0 ] = xp [ 0 ] ^ yp [ 0 ] ;\n}\n", "POLICEMEN_CATCH_THIEVES": "static int policeThief ( char arr [ ] , int n , int k ) {\n  int res = 0 ;\n  ArrayList < Integer > thi = new ArrayList < Integer > ( ) ;\n  ArrayList < Integer > pol = new ArrayList < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( arr [ i ] == 'P' ) pol . add ( i ) ;\n    else if ( arr [ i ] == 'T' ) thi . add ( i ) ;\n  }\n  int l = 0 , r = 0 ;\n  while ( l < thi . size ( ) && r < pol . size ( ) ) {\n    if ( Math . abs ( thi . get ( l ) - pol . get ( r ) ) <= k ) {\n      res ++ ;\n      l ++ ;\n      r ++ ;\n    }\n    else if ( thi . get ( l ) < pol . get ( 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  HashMap < Integer , Integer > hM = new HashMap < Integer , Integer > ( ) ;\n  int sum = 0 ;\n  int max_len = 0 ;\n  int ending_index = - 1 ;\n  int start_index = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    arr [ i ] = ( arr [ i ] == 0 ) ? - 1 : 1 ;\n  }\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 . containsKey ( sum + n ) ) {\n      if ( max_len < i - hM . get ( sum + n ) ) {\n        max_len = i - hM . get ( sum + n ) ;\n        ending_index = i ;\n      }\n    }\n    else hM . put ( sum + n , i ) ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    arr [ i ] = ( arr [ i ] == - 1 ) ? 0 : 1 ;\n  }\n  int end = ending_index - max_len + 1 ;\n  System . out . println ( end + \" to \" + ending_index ) ;\n  return max_len ;\n}\n", "MAXIMUM_DIFFERENCE_ZEROS_ONES_BINARY_STRING_SET_2_TIME": "public static 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 . charAt ( i ) == '0' ? 1 : - 1 ) ;\n    if ( current_sum < 0 ) current_sum = 0 ;\n    max_sum = Math . max ( current_sum , max_sum ) ;\n  }\n  return max_sum == 0 ? - 1 : max_sum ;\n}\n", "MAXIMUM_CONSECUTIVE_NUMBERS_PRESENT_ARRAY": "static int findLongestConseqSubseq ( int arr [ ] , int n ) {\n  HashSet < Integer > S = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) S . add ( arr [ i ] ) ;\n  int ans = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( S . contains ( arr [ i ] ) ) {\n      int j = arr [ i ] ;\n      while ( S . contains ( j ) ) j ++ ;\n      ans = Math . max ( ans , j - arr [ i ] ) ;\n    }\n  }\n  return ans ;\n}\n", "LEXICOGRAPHICALLY_NEXT_STRING": "public static String nextWord ( String str ) {\n  if ( str == \"\" ) return \"a\" ;\n  int i = str . length ( ) - 1 ;\n  while ( str . charAt ( i ) == 'z' && i >= 0 ) i -- ;\n  if ( i == - 1 ) str = str + 'a' ;\n  else str = str . substring ( 0 , i ) + ( char ) ( ( int ) ( str . charAt ( i ) ) + 1 ) + str . substring ( i + 1 ) ;\n  return str ;\n}\n", "SCHEDULE_JOBS_SERVER_GETS_EQUAL_LOAD": "static int solve ( int a [ ] , int b [ ] , int n ) {\n  int i ;\n  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 ] = 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": "static String getMinNumberForPattern ( String seq ) {\n  int n = seq . length ( ) ;\n  if ( n >= 9 ) return \"-1\" ;\n  char result [ ] = new char [ n + 1 ] ;\n  int count = 1 ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) {\n    if ( i == n || seq . charAt ( i ) == 'I' ) {\n      for ( int j = i - 1 ;\n      j >= - 1 ;\n      j -- ) {\n        result [ j + 1 ] = ( char ) ( ( int ) '0' + count ++ ) ;\n        if ( j >= 0 && seq . charAt ( j ) == 'I' ) break ;\n      }\n    }\n  }\n  return new String ( result ) ;\n}\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE": "static 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 -- ) {\n    int temp = a [ j - 1 ] ;\n    a [ j - 1 ] = a [ j ] ;\n    a [ j ] = temp ;\n  }\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_1": "static int findRepeating ( int arr [ ] , int n ) {\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( s . contains ( arr [ i ] ) ) return arr [ i ] ;\n    s . add ( arr [ i ] ) ;\n  }\n  return - 1 ;\n}\n", "C_PROGRAM_SUBTRACTION_MATICES": "static void multiply ( int A [ ] [ ] , int B [ ] [ ] , int C [ ] [ ] ) {\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": "static void printFirstNegativeInteger ( int arr [ ] , int n , int k ) {\n  boolean 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        System . out . print ( ( arr [ i + j ] ) + \" \" ) ;\n        flag = true ;\n        break ;\n      }\n    }\n    if ( ! flag ) System . out . print ( \"0\" + \" \" ) ;\n  }\n}\n", "NUMBER_FULL_BINARY_TREES_NODE_PRODUCT_CHILDREN": "static int numoffbt ( int arr [ ] , int n ) {\n  int maxvalue = - 2147483647 ;\n  int minvalue = 2147483647 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    maxvalue = Math . max ( maxvalue , arr [ i ] ) ;\n    minvalue = Math . min ( minvalue , arr [ i ] ) ;\n  }\n  int mark [ ] = new int [ maxvalue + 2 ] ;\n  int value [ ] = new int [ maxvalue + 2 ] ;\n  Arrays . fill ( mark , 0 ) ;\n  Arrays . fill ( value , 0 ) ;\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 ] != 0 ) {\n      for ( int j = i + i ;\n      j <= maxvalue && j / i <= i ;\n      j += i ) {\n        if ( mark [ j ] == 0 ) 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": "public static int numberOfSticks ( int x ) {\n  return ( 3 * x * ( x + 1 ) ) / 2 ;\n}\n", "K_MAXIMUM_SUM_COMBINATIONS_TWO_ARRAYS": "static void KMaxCombinations ( int A [ ] , int B [ ] , int N , int K ) {\n  PriorityQueue < Integer > pq = new PriorityQueue < Integer > ( Collections . reverseOrder ( ) ) ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) for ( int j = 0 ;\n  j < N ;\n  j ++ ) pq . add ( A [ i ] + B [ j ] ) ;\n  int count = 0 ;\n  while ( count < K ) {\n    System . out . println ( pq . peek ( ) ) ;\n    pq . remove ( ) ;\n    count ++ ;\n  }\n}\n", "CONSTRUCT_ARRAY_PAIR_SUM_ARRAY": "static 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": "static boolean checkCorrectOrNot ( String s ) {\n  int [ ] count1 = new int [ MAX_CHAR ] ;\n  int [ ] count2 = new int [ MAX_CHAR ] ;\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 . charAt ( i ) - 'a' ] ++ ;\n    count2 [ s . charAt ( 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": "static int getMinDiff ( int arr [ ] , int n , int k ) {\n  if ( n == 1 ) return 0 ;\n  Arrays . sort ( arr ) ;\n  int ans = arr [ n - 1 ] - arr [ 0 ] ;\n  int small = arr [ 0 ] + k ;\n  int big = arr [ n - 1 ] - k ;\n  int temp = 0 ;\n  if ( small > big ) {\n    temp = small ;\n    small = big ;\n    big = temp ;\n  }\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 Math . min ( ans , big - small ) ;\n}\n", "MINIMUM_POSSIBLE_VALUE_AI_AJ_K_GIVEN_ARRAY_K": "static void pairs ( int arr [ ] , int n , int k ) {\n  int smallest = Integer . MAX_VALUE ;\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 ( Math . abs ( arr [ i ] + arr [ j ] - k ) < smallest ) {\n      smallest = Math . abs ( arr [ i ] + arr [ j ] - k ) ;\n      count = 1 ;\n    }\n    else if ( Math . abs ( arr [ i ] + arr [ j ] - k ) == smallest ) count ++ ;\n  }\n  System . out . println ( \"Minimal Value = \" + smallest ) ;\n  System . out . println ( \"Total Pairs = \" + count ) ;\n}\n", "SIZE_SUBARRAY_MAXIMUM_SUM": "static int maxSubArraySum ( int a [ ] , int size ) {\n  int max_so_far = Integer . MIN_VALUE , 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": "static int getMinSquares ( int n ) {\n  if ( n <= 3 ) return 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 <= Math . ceil ( Math . sqrt ( i ) ) ;\n    x ++ ) {\n      int temp = x * x ;\n      if ( temp > i ) break ;\n      else dp [ i ] = Math . min ( dp [ i ] , 1 + dp [ i - temp ] ) ;\n    }\n  }\n  int res = dp [ n ] ;\n  return res ;\n}\n", "DIVISIBILITY_BY_7": "static boolean isDivisibleBy7 ( int num ) {\n  if ( num < 0 ) return isDivisibleBy7 ( - num ) ;\n  if ( num == 0 || num == 7 ) return true ;\n  if ( num < 10 ) return false ;\n  return isDivisibleBy7 ( num / 10 - 2 * ( num - num / 10 * 10 ) ) ;\n}\n", "POSITION_OF_RIGHTMOST_SET_BIT_2": "static 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 ) ) == 0 ) pos ++ ;\n    else break ;\n  }\n  return pos ;\n}\n", "EFFICIENT_WAY_TO_MULTIPLY_WITH_7": "static int multiplyBySeven ( int n ) {\n  return ( ( n << 3 ) - n ) ;\n}\n", "NEXT_HIGHER_NUMBER_WITH_SAME_NUMBER_OF_SET_BITS": "static int snoob ( int x ) {\n  int rightOne , nextHigherOneBit , rightOnesPattern , next = 0 ;\n  if ( x > 0 ) {\n    rightOne = x & - 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": "static void makePermutation ( int [ ] a , int n ) {\n  HashMap < Integer , Integer > count = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( count . containsKey ( a [ i ] ) ) {\n      count . put ( a [ i ] , count . get ( a [ i ] ) + 1 ) ;\n    }\n    else {\n      count . put ( a [ i ] , 1 ) ;\n    }\n  }\n  int next_missing = 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( count . containsKey ( a [ i ] ) && count . get ( a [ i ] ) != 1 || a [ i ] > n || a [ i ] < 1 ) {\n      count . put ( a [ i ] , count . get ( a [ i ] ) - 1 ) ;\n      while ( count . containsKey ( next_missing ) ) next_missing ++ ;\n      a [ i ] = next_missing ;\n      count . put ( next_missing , 1 ) ;\n    }\n  }\n}\n", "MAXIMUM_AREA_QUADRILATERAL": "static double maxArea ( double a , double b , double c , double d ) {\n  double semiperimeter = ( a + b + c + d ) / 2 ;\n  return Math . sqrt ( ( semiperimeter - a ) * ( semiperimeter - b ) * ( semiperimeter - c ) * ( semiperimeter - d ) ) ;\n}\n", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE_1": "static void translate ( char str [ ] ) {\n  int len = str . length ;\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  str [ len - 1 ] = ' ' ;\n}\n", "FIND_POWER_POWER_MOD_PRIME": "static int Calculate ( int A , int B , int C , int M ) {\n  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": "static boolean checkPair ( int arr [ ] , int n ) {\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    sum += arr [ i ] ;\n  }\n  if ( sum % 2 != 0 ) {\n    return false ;\n  }\n  sum = sum / 2 ;\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int val = sum - arr [ i ] ;\n    if ( s . contains ( val ) && val == ( int ) s . toArray ( ) [ s . size ( ) - 1 ] ) {\n      System . out . printf ( \"Pair elements are %d and %d\\n\" , arr [ i ] , val ) ;\n      return true ;\n    }\n    s . add ( arr [ i ] ) ;\n  }\n  return false ;\n}\n", "PROGRAM_FOR_SURFACE_AREA_OF_OCTAHEDRON": "static double surface_area_octahedron ( double side ) {\n  return ( 2 * ( Math . sqrt ( 3 ) ) * ( side * side ) ) ;\n}\n", "FIND_A_SPECIFIC_PAIR_IN_MATRIX": "static int findMaxValue ( int N , int mat [ ] [ ] ) {\n  int maxValue = Integer . MIN_VALUE ;\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": "static 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  return - 1 ;\n}\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_1": "static void findTriplets ( int arr [ ] , int n ) {\n  boolean found = false ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    HashSet < Integer > s = new HashSet < Integer > ( ) ;\n    for ( int j = i + 1 ;\n    j < n ;\n    j ++ ) {\n      int x = - ( arr [ i ] + arr [ j ] ) ;\n      if ( s . contains ( x ) ) {\n        System . out . printf ( \"%d %d %d\\n\" , x , arr [ i ] , arr [ j ] ) ;\n        found = true ;\n      }\n      else {\n        s . add ( arr [ j ] ) ;\n      }\n    }\n  }\n  if ( found == false ) {\n    System . out . printf ( \" No Triplet Found\\n\" ) ;\n  }\n}\n", "FIND_MAXIMUM_VALUE_OF_SUM_IARRI_WITH_ONLY_ROTATIONS_ON_GIVEN_ARRAY_ALLOWED": "static int maxSum ( ) {\n  int arrSum = 0 ;\n  int currVal = 0 ;\n  for ( int i = 0 ;\n  i < arr . length ;\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 < arr . length ;\n  j ++ ) {\n    currVal = currVal + arrSum - arr . length * arr [ arr . length - j ] ;\n    if ( currVal > maxVal ) maxVal = currVal ;\n  }\n  return maxVal ;\n}\n", "PROGRAM_FOR_SCALAR_MULTIPLICATION_OF_A_MATRIX": "static void scalarProductMat ( int mat [ ] [ ] , 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": "static void printSquares ( int n ) {\n  int square = 0 , odd = 1 ;\n  for ( int x = 0 ;\n  x < n ;\n  x ++ ) {\n    System . out . print ( 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": "static int numofArray ( int n , int m ) {\n  int [ ] [ ] dp = new int [ MAX ] [ MAX ] ;\n  Vector < Integer > [ ] di = new Vector [ MAX ] ;\n  Vector < Integer > [ ] mu = new Vector [ MAX ] ;\n  for ( int i = 0 ;\n  i < MAX ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < MAX ;\n    j ++ ) {\n      dp [ i ] [ j ] = 0 ;\n    }\n  }\n  for ( int i = 0 ;\n  i < MAX ;\n  i ++ ) {\n    di [ i ] = new Vector < > ( ) ;\n    mu [ i ] = new Vector < > ( ) ;\n  }\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 ] . add ( i ) ;\n      mu [ i ] . add ( j ) ;\n    }\n    di [ i ] . add ( 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 ( Integer x : di [ j ] ) dp [ i ] [ j ] += dp [ i - 1 ] [ x ] ;\n      for ( Integer 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": "static 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": "static void findTriplets ( int [ ] arr , int n ) {\n  boolean 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          System . out . print ( arr [ i ] ) ;\n          System . out . print ( \" \" ) ;\n          System . out . print ( arr [ j ] ) ;\n          System . out . print ( \" \" ) ;\n          System . out . print ( arr [ k ] ) ;\n          System . out . print ( \"\\n\" ) ;\n          found = true ;\n        }\n      }\n    }\n  }\n  if ( found == false ) System . out . println ( \" not exist \" ) ;\n}\n", "COUNT_NUMBER_WAYS_REACH_GIVEN_SCORE_GAME": "static int count ( int n ) {\n  int table [ ] = new int [ n + 1 ] , i ;\n  Arrays . fill ( table , 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": "static int MaxSumDifference ( Integer [ ] a , int n ) {\n  List < Integer > finalSequence = new ArrayList < Integer > ( ) ;\n  Arrays . sort ( a ) ;\n  for ( int i = 0 ;\n  i < n / 2 ;\n  ++ i ) {\n    finalSequence . add ( a [ i ] ) ;\n    finalSequence . add ( a [ n - i - 1 ] ) ;\n  }\n  int MaximumSum = 0 ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  ++ i ) {\n    MaximumSum = MaximumSum + Math . abs ( finalSequence . get ( i ) - finalSequence . get ( i + 1 ) ) ;\n  }\n  MaximumSum = MaximumSum + Math . abs ( finalSequence . get ( n - 1 ) - finalSequence . get ( 0 ) ) ;\n  return MaximumSum ;\n}\n", "PROGRAM_FIND_MID_POINT_LINE": "static void midpoint ( int x1 , int x2 , int y1 , int y2 ) {\n  System . out . print ( ( x1 + x2 ) / 2 + \" , \" + ( y1 + y2 ) / 2 ) ;\n}\n", "ALTERNATIVE_SORTING": "static void alternateSort ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  int i = 0 , j = n - 1 ;\n  while ( i < j ) {\n    System . out . print ( arr [ j -- ] + \" \" ) ;\n    System . out . print ( arr [ i ++ ] + \" \" ) ;\n  }\n  if ( n % 2 != 0 ) System . out . print ( arr [ i ] ) ;\n}\n", "NUMBER_SUBARRAYS_SUM_EXACTLY_EQUAL_K": "static int findSubarraySum ( int arr [ ] , int n , int sum ) {\n  HashMap < Integer , Integer > prevSum = new HashMap < > ( ) ;\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 . containsKey ( currsum - sum ) ) res += prevSum . get ( currsum - sum ) ;\n    Integer count = prevSum . get ( currsum ) ;\n    if ( count == null ) prevSum . put ( currsum , 1 ) ;\n    else prevSum . put ( currsum , count + 1 ) ;\n  }\n  return res ;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_IN_A_SORTED_ARRAY": "public static void search ( int [ ] arr , int low , int high ) {\n  if ( low > high ) return ;\n  if ( low == high ) {\n    System . out . println ( \"The required element is \" + 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 if ( mid % 2 == 1 ) {\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": "public static String smallestNumber ( String str ) {\n  char [ ] num = str . toCharArray ( ) ;\n  int n = str . length ( ) ;\n  int [ ] rightMin = new int [ n ] ;\n  rightMin [ n - 1 ] = - 1 ;\n  int 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      rightMin [ i ] = - 1 ;\n      right = i ;\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 ) {\n    char temp ;\n    temp = num [ 0 ] ;\n    num [ 0 ] = num [ small ] ;\n    num [ small ] = temp ;\n  }\n  else {\n    for ( int i = 1 ;\n    i < n ;\n    i ++ ) {\n      if ( rightMin [ i ] != - 1 ) {\n        char temp ;\n        temp = num [ i ] ;\n        num [ i ] = num [ rightMin [ i ] ] ;\n        num [ rightMin [ i ] ] = temp ;\n        break ;\n      }\n    }\n  }\n  return ( new String ( num ) ) ;\n}\n", "PROGRAM_AREA_SQUARE": "static int areaSquare ( int side ) {\n  int area = side * side ;\n  return area ;\n}\n", "FIND_DAY_OF_THE_WEEK_FOR_A_GIVEN_DATE": "static int dayofweek ( int d , int m , int y ) {\n  int t [ ] = {\n    0 , 3 , 2 , 5 , 0 , 3 , 5 , 1 , 4 , 6 , 2 , 4 };\n    y -= ( m < 3 ) ? 1 : 0 ;\n    return ( y + y / 4 - y / 100 + y / 400 + t [ m - 1 ] + d ) % 7 ;\n  }\n  ", "CHECK_QUEUE_CAN_SORTED_ANOTHER_QUEUE_USING_STACK": "static boolean checkSorted ( int n ) {\n  Stack < Integer > st = new Stack < Integer > ( ) ;\n  int expected = 1 ;\n  int fnt ;\n  while ( q . size ( ) != 0 ) {\n    fnt = q . peek ( ) ;\n    q . poll ( ) ;\n    if ( fnt == expected ) expected ++ ;\n    else {\n      if ( st . size ( ) == 0 ) {\n        st . push ( fnt ) ;\n      }\n      else if ( st . size ( ) != 0 && st . peek ( ) < fnt ) {\n        return false ;\n      }\n      else st . push ( fnt ) ;\n    }\n    while ( st . size ( ) != 0 && st . peek ( ) == expected ) {\n      st . pop ( ) ;\n      expected ++ ;\n    }\n  }\n  if ( expected - 1 == n && st . size ( ) == 0 ) return true ;\n  return false ;\n}\n", "SORT_ARRAY_CONTAIN_1_N_VALUES": "static 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": "static int lcsOf3 ( int i , int j , int k ) {\n  if ( i == - 1 || j == - 1 || k == - 1 ) {\n    return 0 ;\n  }\n  if ( dp [ i ] [ j ] [ k ] != - 1 ) {\n    return dp [ i ] [ j ] [ k ] ;\n  }\n  if ( X . charAt ( i ) == Y . charAt ( j ) && Y . charAt ( j ) == Z . charAt ( k ) ) {\n    return dp [ i ] [ j ] [ k ] = 1 + lcsOf3 ( i - 1 , j - 1 , k - 1 ) ;\n  }\n  else {\n    return dp [ i ] [ j ] [ k ] = Math . max ( Math . max ( lcsOf3 ( i - 1 , j , k ) , lcsOf3 ( i , j - 1 , k ) ) , lcsOf3 ( i , j , k - 1 ) ) ;\n  }\n}\n", "LOWER_INSERTION_POINT": "static 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": "static String constructPalin ( char [ ] 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    System . out . println ( \"Not Possible\" ) ;\n    return \"\" ;\n  }\n  return String . valueOf ( str ) ;\n}\n", "SECTION_FORMULA_POINT_DIVIDES_LINE_GIVEN_RATIO": "static 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  System . out . println ( \"(\" + x + \", \" + y + \")\" ) ;\n}\n", "SQUARE_ROOT_NUMBER_USING_LOG": "static double squareRoot ( double n ) {\n  return Math . pow ( 2 , 0.5 * ( Math . log ( n ) / Math . log ( 2 ) ) ) ;\n}\n", "MAXIMIZE_SUM_ARRII": "static int maxSum ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\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": "static 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": "static int countWords ( String str , int len ) {\n  int count = 1 ;\n  if ( len == 1 ) return count ;\n  if ( str . charAt ( 0 ) == str . charAt ( 1 ) ) count *= 1 ;\n  else count *= 2 ;\n  for ( int j = 1 ;\n  j < len - 1 ;\n  j ++ ) {\n    if ( str . charAt ( j ) == str . charAt ( j - 1 ) && str . charAt ( j ) == str . charAt ( j + 1 ) ) count *= 1 ;\n    else if ( str . charAt ( j ) == str . charAt ( j - 1 ) || str . charAt ( j ) == str . charAt ( j + 1 ) || str . charAt ( j - 1 ) == str . charAt ( j + 1 ) ) count *= 2 ;\n    else count *= 3 ;\n  }\n  if ( str . charAt ( len - 1 ) == str . charAt ( 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": "static int minJumps ( int a , int b , int d ) {\n  int temp = a ;\n  a = Math . min ( a , b ) ;\n  b = Math . 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": "static int sumofFactors ( int n ) {\n  int res = 1 ;\n  for ( int i = 2 ;\n  i <= Math . 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": "static int removeConsecutiveSame ( Vector < String > v ) {\n  int n = v . size ( ) ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  ) {\n    if ( v . get ( i ) . equals ( v . get ( i + 1 ) ) ) {\n      v . remove ( i ) ;\n      v . remove ( 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": "static int countStrings ( int n ) {\n  int a [ ] = new int [ n ] ;\n  int b [ ] = new int [ 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": "static int getMissingNo ( int a [ ] , int n ) {\n  int i , total ;\n  total = ( n + 1 ) * ( n + 2 ) / 2 ;\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) total -= a [ i ] ;\n  return total ;\n}\n", "SQUARE_ROOT_OF_A_PERFECT_SQUARE": "static float squareRoot ( float n ) {\n  float x = n ;\n  float y = 1 ;\n  double 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": "static boolean isSubsetSum ( int arr [ ] , int n , int sum ) {\n  boolean subset [ ] [ ] = new boolean [ 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": "static 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  return 1 ;\n}\n", "COMPUTE_AVERAGE_TWO_NUMBERS_WITHOUT_OVERFLOW": "static int compute_average ( int a , int b ) {\n  return ( a + b ) / 2 ;\n}\n", "REPRESENT_GIVEN_SET_POINTS_BEST_POSSIBLE_STRAIGHT_LINE": "static void bestApproximate ( int x [ ] , int y [ ] ) {\n  int n = x . length ;\n  double 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  System . out . println ( \"m = \" + m ) ;\n  System . out . println ( \"c = \" + c ) ;\n}\n", "SPLIT_ARRAY_ADD_FIRST_PART_END": "public static 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": "static 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    boolean 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 Math . abs ( SubsetSum_1 - SubsetSum_2 ) ;\n}\n", "LONGEST_SUBSEQUENCE_DIFFERENCE_ADJACENTS_ONE_SET_2": "static int longLenSub ( int [ ] arr , int n ) {\n  HashMap < Integer , Integer > um = new HashMap < Integer , Integer > ( ) ;\n  int longLen = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int len = 0 ;\n    if ( um . containsKey ( arr [ i ] - 1 ) && len < um . get ( arr [ i ] - 1 ) ) len = um . get ( arr [ i ] - 1 ) ;\n    if ( um . containsKey ( arr [ i ] + 1 ) && len < um . get ( arr [ i ] + 1 ) ) len = um . get ( arr [ i ] + 1 ) ;\n    um . put ( arr [ i ] , len + 1 ) ;\n    if ( longLen < um . get ( arr [ i ] ) ) longLen = um . get ( arr [ i ] ) ;\n  }\n  return longLen ;\n}\n", "LONGEST_REPEATED_SUBSEQUENCE_1": "static String longestRepeatedSubSeq ( String str ) {\n  int n = str . length ( ) ;\n  int [ ] [ ] dp = new int [ 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 . charAt ( i - 1 ) == str . charAt ( j - 1 ) && i != j ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n  else dp [ i ] [ j ] = Math . 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 . charAt ( i - 1 ) ;\n      i -- ;\n      j -- ;\n    }\n    else if ( dp [ i ] [ j ] == dp [ i - 1 ] [ j ] ) i -- ;\n    else j -- ;\n  }\n  String reverse = \"\" ;\n  for ( int k = res . length ( ) - 1 ;\n  k >= 0 ;\n  k -- ) {\n    reverse = reverse + res . charAt ( k ) ;\n  }\n  return reverse ;\n}\n", "FIND_INDEX_MAXIMUM_OCCURRING_ELEMENT_EQUAL_PROBABILITY": "static void findRandomIndexOfMax ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > mp = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( mp . containsKey ( arr [ i ] ) ) {\n    mp . put ( arr [ i ] , mp . get ( arr [ i ] ) + 1 ) ;\n  }\n  else {\n    mp . put ( arr [ i ] , 1 ) ;\n  }\n  int max_element = Integer . MIN_VALUE ;\n  int max_so_far = Integer . MIN_VALUE ;\n  for ( Map . Entry < Integer , Integer > p : mp . entrySet ( ) ) {\n    if ( p . getValue ( ) > max_so_far ) {\n      max_so_far = p . getValue ( ) ;\n      max_element = p . getKey ( ) ;\n    }\n  }\n  int r = ( int ) ( ( new Random ( ) . nextInt ( max_so_far ) % 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      System . out . print ( \"Element with maximum frequency present \" + \"at index \" + i + \"\\n\" ) ;\n      break ;\n    }\n  }\n}\n", "CHECK_NUMBER_IS_PERFECT_SQUARE_USING_ADDITIONSUBTRACTION": "static boolean 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": "static void bonacciseries ( int n , int m ) {\n  int a [ ] = new int [ m ] ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) a [ i ] = 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 ++ ) System . out . print ( a [ i ] + \" \" ) ;\n}\n", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY_1": "public static int countPairs ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > hm = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( hm . containsKey ( arr [ i ] ) ) hm . put ( arr [ i ] , hm . get ( arr [ i ] ) + 1 ) ;\n    else hm . put ( arr [ i ] , 1 ) ;\n  }\n  int ans = 0 ;\n  for ( Map . Entry < Integer , Integer > it : hm . entrySet ( ) ) {\n    int count = it . getValue ( ) ;\n    ans += ( count * ( count - 1 ) ) / 2 ;\n  }\n  return ans ;\n}\n", "SORT_EVEN_PLACED_ELEMENTS_INCREASING_ODD_PLACED_DECREASING_ORDER": "static void bitonicGenerator ( int arr [ ] , int n ) {\n  Vector < Integer > evenArr = new Vector < Integer > ( ) ;\n  Vector < Integer > oddArr = new Vector < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( i % 2 != 1 ) {\n      evenArr . add ( arr [ i ] ) ;\n    }\n    else {\n      oddArr . add ( arr [ i ] ) ;\n    }\n  }\n  Collections . sort ( evenArr ) ;\n  Collections . sort ( oddArr , Collections . reverseOrder ( ) ) ;\n  int i = 0 ;\n  for ( int j = 0 ;\n  j < evenArr . size ( ) ;\n  j ++ ) {\n    arr [ i ++ ] = evenArr . get ( j ) ;\n  }\n  for ( int j = 0 ;\n  j < oddArr . size ( ) ;\n  j ++ ) {\n    arr [ i ++ ] = oddArr . get ( j ) ;\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_9_BINOMIAL_COEFFICIENT": "static 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": "static boolean getParity ( int n ) {\n  boolean parity = false ;\n  while ( n != 0 ) {\n    parity = ! parity ;\n    n = n & ( n - 1 ) ;\n  }\n  return parity ;\n}\n", "CHECK_WHETHER_LARGE_NUMBER_DIVISIBLE_7": "static boolean isDivisible7 ( String num ) {\n  int n = num . length ( ) ;\n  if ( n == 0 && num . charAt ( 0 ) == '0' ) return true ;\n  if ( n % 3 == 1 ) num = \"00\" + num ;\n  if ( n % 3 == 2 ) num = \"0\" + num ;\n  n = num . length ( ) ;\n  int gSum = 0 , p = 1 ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    int group = 0 ;\n    group += num . charAt ( i -- ) - '0' ;\n    group += ( num . charAt ( i -- ) - '0' ) * 10 ;\n    group += ( num . charAt ( i ) - '0' ) * 100 ;\n    gSum = gSum + group * p ;\n    p = p * - 1 ;\n  }\n  return ( gSum % 7 == 0 ) ;\n}\n", "PRODUCT_NODES_K_TH_LEVEL_TREE_REPRESENTED_STRING": "static 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 . charAt ( i ) == '(' ) level ++ ;\n    else if ( tree . charAt ( i ) == ')' ) level -- ;\n    else {\n      if ( level == k ) product *= ( tree . charAt ( i ) - '0' ) ;\n    }\n  }\n  return product ;\n}\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD": "public static boolean isEven ( int n ) {\n  return ( n % 2 == 0 ) ;\n}\n", "COUNT_GROUPINGS_NUMBER_SUM_DIGITS_EVERY_SUB_GROUP_LESS_EQUALS_IMMEDIATE_RIGHT_SUB_GROUP": "static int countGroups ( int position , int previous_sum , int length , String 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 . charAt ( 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": "static void search ( int arr [ ] , int low , int high ) {\n  if ( low > high ) return ;\n  if ( low == high ) {\n    System . out . 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": "static int removeConsecutiveSame ( Vector < String > v ) {\n  Stack < String > st = new Stack < > ( ) ;\n  for ( int i = 0 ;\n  i < v . size ( ) ;\n  i ++ ) {\n    if ( st . empty ( ) ) st . push ( v . get ( i ) ) ;\n    else {\n      String str = st . peek ( ) ;\n      if ( str . equals ( v . get ( i ) ) ) st . pop ( ) ;\n      else st . push ( v . get ( i ) ) ;\n    }\n  }\n  return st . size ( ) ;\n}\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY_2": "static 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 ] = Integer . MAX_VALUE ;\n    else if ( arr [ i ] >= n - i - 1 ) jumps [ i ] = 1 ;\n    else {\n      min = Integer . MAX_VALUE ;\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 != Integer . MAX_VALUE ) jumps [ i ] = min + 1 ;\n      else jumps [ i ] = min ;\n    }\n  }\n  return jumps [ 0 ] ;\n}\n", "PROGRAM_FIND_GCD_FLOATING_POINT_NUMBERS": "static double gcd ( double a , double b ) {\n  if ( a < b ) return gcd ( b , a ) ;\n  if ( Math . abs ( b ) < 0.001 ) return a ;\n  else return ( gcd ( b , a - Math . floor ( a / b ) * b ) ) ;\n}\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_TWICE": "static 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 ] = Math . 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 ] = Math . max ( profit [ i - 1 ] , profit [ i ] + ( price [ i ] - min_price ) ) ;\n  }\n  int result = profit [ n - 1 ] ;\n  return result ;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_1": "public static 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": "static void reorder ( ) {\n  int temp [ ] = new int [ arr . length ] ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) temp [ index [ i ] ] = arr [ i ] ;\n  for ( int i = 0 ;\n  i < arr . length ;\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": "boolean canRepresentBST ( int pre [ ] , int n ) {\n  Stack < Integer > s = new Stack < Integer > ( ) ;\n  int root = Integer . MIN_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( pre [ i ] < root ) {\n      return false ;\n    }\n    while ( ! s . empty ( ) && s . peek ( ) < pre [ i ] ) {\n      root = s . peek ( ) ;\n      s . pop ( ) ;\n    }\n    s . push ( pre [ i ] ) ;\n  }\n  return true ;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1_3": "static int findRepeating ( int arr [ ] , int n ) {\n  int missingElement = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int element = arr [ Math . abs ( arr [ i ] ) ] ;\n    if ( element < 0 ) {\n      missingElement = arr [ i ] ;\n      break ;\n    }\n    arr [ Math . abs ( arr [ i ] ) ] = - arr [ Math . abs ( arr [ i ] ) ] ;\n  }\n  return Math . abs ( missingElement ) ;\n}\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION_1": "static int MatrixChainOrder ( int p [ ] , int n ) {\n  int m [ ] [ ] = new int [ 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      if ( j == n ) continue ;\n      m [ i ] [ j ] = Integer . MAX_VALUE ;\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": "static int countIslands ( int mat [ ] [ ] , int m , int 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": "static int solve ( int [ ] A , int [ ] B , int [ ] C ) {\n  int i , j , k ;\n  i = A . length - 1 ;\n  j = B . length - 1 ;\n  k = C . length - 1 ;\n  int min_diff , current_diff , max_term ;\n  min_diff = Math . abs ( Math . max ( A [ i ] , Math . max ( B [ j ] , C [ k ] ) ) - Math . min ( A [ i ] , Math . min ( B [ j ] , C [ k ] ) ) ) ;\n  while ( i != - 1 && j != - 1 && k != - 1 ) {\n    current_diff = Math . abs ( Math . max ( A [ i ] , Math . max ( B [ j ] , C [ k ] ) ) - Math . min ( A [ i ] , Math . min ( B [ j ] , C [ k ] ) ) ) ;\n    if ( current_diff < min_diff ) min_diff = current_diff ;\n    max_term = Math . max ( A [ i ] , Math . 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    System . out . println ( \"Invalid\" ) ;\n    return ;\n  }\n  int d = b * b - 4 * a * c ;\n  double sqrt_val = sqrt ( abs ( d ) ) ;\n  if ( d > 0 ) {\n    System . out . println ( \"Roots are real and different \\n\" ) ;\n    System . out . println ( ( double ) ( - b + sqrt_val ) / ( 2 * a ) + \"\\n\" + ( double ) ( - b - sqrt_val ) / ( 2 * a ) ) ;\n  }\n  else {\n    System . out . println ( \"Roots are complex \\n\" ) ;\n    System . out . println ( - ( 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": "static boolean isMinHeap ( int [ ] level ) {\n  int n = level . length - 1 ;\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": "static 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": "static int stringReduction ( String str ) {\n  int n = str . length ( ) ;\n  int count [ ] = new int [ 3 ] ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) {\n    count [ str . charAt ( i ) - 'a' ] ++ ;\n  }\n  if ( count [ 0 ] == n || count [ 1 ] == n || count [ 2 ] == n ) {\n    return n ;\n  }\n  if ( ( count [ 0 ] % 2 ) == ( count [ 1 ] % 2 ) && ( count [ 1 ] % 2 ) == ( count [ 2 ] % 2 ) ) {\n    return 2 ;\n  }\n  return 1 ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_3_NOT": "static boolean check ( String str ) {\n  int n = str . length ( ) ;\n  int digitSum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) digitSum += ( str . charAt ( i ) - '0' ) ;\n  return ( digitSum % 3 == 0 ) ;\n}\n", "COMPUTE_N_UNDER_MODULO_P": "static 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": "static boolean isPresent ( String s , String q ) {\n  int [ ] freq = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) freq [ s . charAt ( i ) ] ++ ;\n  for ( int i = 0 ;\n  i < q . length ( ) ;\n  i ++ ) {\n    freq [ q . charAt ( i ) ] -- ;\n    if ( freq [ q . charAt ( i ) ] < 0 ) return false ;\n  }\n  return true ;\n}\n", "NEXT_POWER_OF_2_1": "static int nextPowerOf2 ( int n ) {\n  int p = 1 ;\n  if ( n > 0 && ( n & ( n - 1 ) ) == 0 ) return n ;\n  while ( p < n ) p <<= 1 ;\n  return p ;\n}\n", "REORDER_A_ARRAY_ACCORDING_TO_GIVEN_INDEXES_1": "static void reorder ( ) {\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    while ( index [ i ] != i ) {\n      int oldTargetI = index [ index [ i ] ] ;\n      char oldTargetE = ( char ) 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": "private static int unboundedKnapsack ( int W , int n , int [ ] val , int [ ] wt ) {\n  int dp [ ] = new int [ W + 1 ] ;\n  for ( int i = 0 ;\n  i <= W ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j < n ;\n    j ++ ) {\n      if ( wt [ j ] <= i ) {\n        dp [ i ] = max ( dp [ i ] , dp [ i - wt [ j ] ] + val [ j ] ) ;\n      }\n    }\n  }\n  return dp [ W ] ;\n}\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX": "static boolean isDiagonalMatrix ( int mat [ ] [ ] ) {\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": "static int maxRemoval ( int arr [ ] , int n ) {\n  int count = 0 ;\n  int cummulative_sum = 0 ;\n  Arrays . sort ( arr ) ;\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": "static String censor ( String text , String word ) {\n  String [ ] word_list = text . split ( \"\\\\s+\" ) ;\n  String result = \"\" ;\n  String stars = \"\" ;\n  for ( int i = 0 ;\n  i < word . length ( ) ;\n  i ++ ) stars += '*' ;\n  int index = 0 ;\n  for ( String i : word_list ) {\n    if ( i . compareTo ( word ) == 0 ) word_list [ index ] = stars ;\n    index ++ ;\n  }\n  for ( String i : word_list ) result += i + ' ' ;\n  return result ;\n}\n", "COUNT_STRINGS_WITH_CONSECUTIVE_1S": "static int countStrings ( int n ) {\n  int a [ ] = new int [ n ] , b [ ] = new int [ 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  from 2 ^ n return ( 1 << n ) - a [ n - 1 ] - b [ n - 1 ] ;\n}\n", "LENGTH_LONGEST_BALANCED_SUBSEQUENCE": "static int maxLength ( String s , int n ) {\n  int dp [ ] [ ] = new int [ n ] [ n ] ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) if ( s . charAt ( i ) == '(' && s . charAt ( 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 . charAt ( i ) == '(' && s . charAt ( j ) == ')' ) dp [ i ] [ j ] = 2 + dp [ i + 1 ] [ j - 1 ] ;\n      for ( int k = i ;\n      k < j ;\n      k ++ ) dp [ i ] [ j ] = Math . 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": "static void findMaxGuests ( int arrl [ ] , int exit [ ] , int n ) {\n  Arrays . sort ( arrl ) ;\n  Arrays . sort ( exit ) ;\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  System . out . println ( \"Maximum Number of Guests = \" + max_guests + \" at time \" + time ) ;\n}\n", "EFFICIENT_WAY_CHECK_WHETHER_N_TH_FIBONACCI_NUMBER_MULTIPLE_10": "static boolean isMultipleOf10 ( int n ) {\n  if ( n % 15 == 0 ) return true ;\n  return false ;\n}\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE": "static int maxSumPairWithDifferenceLessThanK ( int arr [ ] , int N , int K ) {\n  Arrays . sort ( arr ) ;\n  int dp [ ] = new int [ 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 ] = Math . max ( dp [ i ] , dp [ i - 2 ] + arr [ i ] + arr [ i - 1 ] ) ;\n      else dp [ i ] = Math . max ( dp [ i ] , arr [ i ] + arr [ i - 1 ] ) ;\n    }\n  }\n  return dp [ N - 1 ] ;\n}\n", "FIND_K_PAIRS_SMALLEST_SUMS_TWO_ARRAYS": "static void kSmallestPair ( int arr1 [ ] , int n1 , int arr2 [ ] , int n2 , int k ) {\n  if ( k > n1 * n2 ) {\n    System . out . print ( \"k pairs don't exist\" ) ;\n    return ;\n  }\n  int index2 [ ] = new int [ n1 ] ;\n  while ( k > 0 ) {\n    int min_sum = Integer . MAX_VALUE ;\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    System . out . print ( \"(\" + 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": "static char first ( String str , int i ) {\n  if ( str . charAt ( i ) == '\\0' ) return 0 ;\n  if ( Character . isUpperCase ( str . charAt ( i ) ) ) return str . charAt ( i ) ;\n  return first ( str , i + 1 ) ;\n}\n", "FIND_PAIRS_B_ARRAY_B_K": "static boolean printPairs ( int arr [ ] , int n , int k ) {\n  boolean 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        System . out . print ( \"(\" + arr [ i ] + \", \" + arr [ j ] + \")\" + \" \" ) ;\n        isPairFound = true ;\n      }\n    }\n  }\n  return isPairFound ;\n}\n", "FIND_ARRANGEMENT_QUEUE_GIVEN_TIME": "static void solve ( int n , int t , char 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  System . out . print ( s ) ;\n}\n", "SHORTEST_POSSIBLE_COMBINATION_TWO_STRINGS": "static void printSuperSeq ( String a , String b ) {\n  int m = a . length ( ) , n = b . length ( ) ;\n  int [ ] [ ] dp = new int [ 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 ( a . charAt ( i - 1 ) == b . charAt ( j - 1 ) ) dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n      else dp [ i ] [ j ] = 1 + Math . min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) ;\n    }\n  }\n  String res = \"\" ;\n  int i = m , j = n ;\n  while ( i > 0 && j > 0 ) {\n    if ( a . charAt ( i - 1 ) == b . charAt ( j - 1 ) ) {\n      res = a . charAt ( i - 1 ) + res ;\n      i -- ;\n      j -- ;\n    }\n    else if ( dp [ i - 1 ] [ j ] < dp [ i ] [ j - 1 ] ) {\n      res = a . charAt ( i - 1 ) + res ;\n      i -- ;\n    }\n    else {\n      res = b . charAt ( j - 1 ) + res ;\n      j -- ;\n    }\n  }\n  while ( i > 0 ) {\n    res = a . charAt ( i - 1 ) + res ;\n    i -- ;\n  }\n  while ( j > 0 ) {\n    res = b . charAt ( j - 1 ) + res ;\n    j -- ;\n  }\n  System . out . println ( res ) ;\n}\n", "COUNT_ROTATIONS_DIVISIBLE_8": "static int countRotationsDivBy8 ( String n ) {\n  int len = n . length ( ) ;\n  int count = 0 ;\n  if ( len == 1 ) {\n    int oneDigit = n . charAt ( 0 ) - '0' ;\n    if ( oneDigit % 8 == 0 ) return 1 ;\n    return 0 ;\n  }\n  if ( len == 2 ) {\n    int first = ( n . charAt ( 0 ) - '0' ) * 10 + ( n . charAt ( 1 ) - '0' ) ;\n    int second = ( n . charAt ( 1 ) - '0' ) * 10 + ( n . charAt ( 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 . charAt ( i ) - '0' ) * 100 + ( n . charAt ( i + 1 ) - '0' ) * 10 + ( n . charAt ( i + 2 ) - '0' ) ;\n    if ( threeDigit % 8 == 0 ) count ++ ;\n  }\n  threeDigit = ( n . charAt ( len - 1 ) - '0' ) * 100 + ( n . charAt ( 0 ) - '0' ) * 10 + ( n . charAt ( 1 ) - '0' ) ;\n  if ( threeDigit % 8 == 0 ) count ++ ;\n  threeDigit = ( n . charAt ( len - 2 ) - '0' ) * 100 + ( n . charAt ( len - 1 ) - '0' ) * 10 + ( n . charAt ( 0 ) - '0' ) ;\n  if ( threeDigit % 8 == 0 ) count ++ ;\n  return count ;\n}\n", "LONGEST_COMMON_SUBSEQUENCE_WITH_AT_MOST_K_CHANGES_ALLOWED": "static int lcs ( int [ ] [ ] [ ] dp , int [ ] arr1 , int n , int [ ] arr2 , int m , int k ) {\n  if ( k < 0 ) return - 10000000 ;\n  if ( n < 0 || m < 0 ) return 0 ;\n  int ans = dp [ n ] [ m ] [ k ] ;\n  if ( ans != - 1 ) return ans ;\n  try {\n    ans = Math . 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 = Math . max ( ans , 1 + lcs ( dp , arr1 , n - 1 , arr2 , m - 1 , k ) ) ;\n    ans = Math . max ( ans , 1 + lcs ( dp , arr1 , n - 1 , arr2 , m - 1 , k - 1 ) ) ;\n  }\n  catch ( Exception e ) {\n  }\n  return ans ;\n}\n", "CHECK_LINE_TOUCHES_INTERSECTS_CIRCLE": "static void checkCollision ( int a , int b , int c , int x , int y , int radius ) {\n  double dist = ( Math . abs ( a * x + b * y + c ) ) / Math . sqrt ( a * a + b * b ) ;\n  if ( radius == dist ) System . out . println ( \"Touch\" ) ;\n  else if ( radius > dist ) System . out . println ( \"Intersect\" ) ;\n  else System . out . println ( \"Outside\" ) ;\n}\n", "FIND_THE_MAXIMUM_SUBARRAY_XOR_IN_A_GIVEN_ARRAY": "static int maxSubarrayXOR ( int arr [ ] , int n ) {\n  int ans = Integer . MIN_VALUE ;\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 = Math . max ( ans , curr_xor ) ;\n    }\n  }\n  return ans ;\n}\n", "SHORTEST_PATH_EXACTLY_K_EDGES_DIRECTED_WEIGHTED_GRAPH": "int shortestPath ( int graph [ ] [ ] , 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 = Math . 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        int p = j - 1 ;\n        System . out . println ( \"Sum found between indexes \" + i + \" and \" + p ) ;\n        return 1 ;\n      }\n      if ( curr_sum > sum || j == n ) break ;\n      curr_sum = curr_sum + arr [ j ] ;\n    }\n  }\n  System . out . println ( \"No subarray found\" ) ;\n  return 0 ;\n}\n", "K_TH_PRIME_FACTOR_GIVEN_NUMBER": "static 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 <= Math . 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": "static 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": "static 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": "static void sortUsingHash ( int a [ ] , int n ) {\n  int max = Arrays . stream ( a ) . max ( ) . getAsInt ( ) ;\n  int min = Math . abs ( Arrays . stream ( a ) . min ( ) . getAsInt ( ) ) ;\n  int hashpos [ ] = new int [ max + 1 ] ;\n  int hashneg [ ] = new int [ min + 1 ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( a [ i ] >= 0 ) hashpos [ a [ i ] ] += 1 ;\n    else hashneg [ Math . abs ( a [ i ] ) ] += 1 ;\n  }\n  for ( int i = min ;\n  i > 0 ;\n  i -- ) {\n    if ( hashneg [ i ] > 0 ) {\n      for ( int j = 0 ;\n      j < hashneg [ i ] ;\n      j ++ ) {\n        System . out . print ( ( - 1 ) * i + \" \" ) ;\n      }\n    }\n  }\n  for ( int i = 0 ;\n  i <= max ;\n  i ++ ) {\n    if ( hashpos [ i ] > 0 ) {\n      for ( int j = 0 ;\n      j < hashpos [ i ] ;\n      j ++ ) {\n        System . out . print ( 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 [ size ] ;\n  int i ;\n  System . out . println ( \"Repeated elements are : \" ) ;\n  for ( i = 0 ;\n  i < size ;\n  i ++ ) {\n    if ( count [ arr [ i ] ] == 1 ) System . out . print ( arr [ i ] + \" \" ) ;\n    else count [ arr [ i ] ] ++ ;\n  }\n}\n", "MINIMUM_STEPS_MINIMIZE_N_PER_GIVEN_CONDITION": "static int getMinSteps ( int n ) {\n  int table [ ] = new int [ 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 > 0 ) ) table [ i / 2 ] = Math . min ( table [ i ] + 1 , table [ i / 2 ] ) ;\n    if ( ! ( i % 3 > 0 ) ) table [ i / 3 ] = Math . min ( table [ i ] + 1 , table [ i / 3 ] ) ;\n  }\n  return table [ 1 ] ;\n  ", "COUNT_POSSIBLE_DECODINGS_GIVEN_DIGIT_SEQUENCE_1": "static int countDecodingDP ( char digits [ ] , int n ) {\n  int count [ ] = new int [ 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": "public static void checkEulerFourSquareIdentity ( int a , int b ) {\n  int ab = a * b ;\n  boolean 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 = Math . sqrt ( ab - ( i * i + j * j + k * k ) ) ;\n        if ( Math . floor ( l ) == Math . ceil ( l ) && l >= k ) {\n          flag = true ;\n          System . out . print ( \"i = \" + i + \"\\n\" ) ;\n          System . out . print ( \"j = \" + j + \"\\n\" ) ;\n          System . out . print ( \"k = \" + k + \"\\n\" ) ;\n          System . out . print ( \"l = \" + ( int ) l + \"\\n\" ) ;\n          System . out . print ( \"Product of \" + a + \" and \" + b + \" can be written as sum of squares\" + \" of i, j, k, l \\n\" ) ;\n          System . out . print ( 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    System . out . println ( \"Solution doesn't exist!\" ) ;\n    return ;\n  }\n}\n", "COUNT_NUMBER_INCREASING_SUBSEQUENCES_SIZE_K": "static int numOfIncSubseqOfSizeK ( int arr [ ] , int n , int k ) {\n  int dp [ ] [ ] = new int [ k ] [ n ] , sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    dp [ 0 ] [ i ] = 1 ;\n  }\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 ] ) {\n          dp [ l ] [ i ] += dp [ l - 1 ] [ j ] ;\n        }\n      }\n    }\n  }\n  for ( int i = k - 1 ;\n  i < n ;\n  i ++ ) {\n    sum += dp [ k - 1 ] [ i ] ;\n  }\n  return sum ;\n}\n", "KNAPSACK_PROBLEM_1": "static int knapSack ( int W , int wt [ ] , int val [ ] , int n ) {\n  int i , w ;\n  int K [ ] [ ] = new int [ 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": "static 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      System . out . print ( \"  \" ) ;\n      csp1 = csp1 + 1 ;\n    }\n    int cst1 = 1 ;\n    while ( cst1 <= nst ) {\n      System . out . print ( val1 + \" \" ) ;\n      val1 = val1 - 1 ;\n      cst1 = cst1 + 1 ;\n    }\n    int csp2 = 1 ;\n    while ( csp2 <= nsp2 ) {\n      System . out . print ( \"  \" ) ;\n      csp2 = csp2 + 1 ;\n    }\n    if ( row != 1 && row != n ) {\n      int cst2 = 1 ;\n      while ( cst2 <= nst ) {\n        System . out . print ( val2 + \" \" ) ;\n        val2 = val2 + 1 ;\n        cst2 = cst2 + 1 ;\n      }\n    }\n    System . out . println ( ) ;\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": "static int findInteger ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > hash = new HashMap < > ( ) ;\n  int maximum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( arr [ i ] < 0 ) hash . put ( Math . abs ( arr [ i ] ) , ( hash . get ( Math . abs ( arr [ i ] ) ) == null ? 0 : hash . get ( Math . abs ( arr [ i ] ) ) ) - 1 ) ;\n    else hash . put ( Math . abs ( arr [ i ] ) , ( hash . get ( Math . abs ( arr [ i ] ) ) == null ? 0 : hash . get ( Math . abs ( arr [ i ] ) ) ) + 1 ) ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( hash . get ( arr [ i ] ) > 0 ) return arr [ i ] ;\n  return - 1 ;\n}\n", "SPACE_OPTIMIZED_SOLUTION_LCS": "public static int lcs ( String X , String Y ) {\n  int m = X . length ( ) , n = Y . length ( ) ;\n  int L [ ] [ ] = new int [ 2 ] [ n + 1 ] ;\n  int bi = 0 ;\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 . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) L [ bi ] [ j ] = L [ 1 - bi ] [ j - 1 ] + 1 ;\n      else L [ bi ] [ j ] = Math . 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": "public static void psuedoBinary ( int n ) {\n  while ( n != 0 ) {\n    int temp = n , m = 0 , p = 1 ;\n    while ( temp != 0 ) {\n      int rem = temp % 10 ;\n      temp = temp / 10 ;\n      if ( rem != 0 ) m += p ;\n      p *= 10 ;\n    }\n    System . out . print ( m + \" \" ) ;\n    n = n - m ;\n  }\n  System . out . println ( \" \" ) ;\n}\n", "FIND_NUMBER_CURRENCY_NOTES_SUM_UPTO_GIVEN_AMOUNT": "public static void countCurrency ( int amount ) {\n  int [ ] notes = new int [ ] {\n    2000 , 500 , 200 , 100 , 50 , 20 , 10 , 5 , 1 };\n    int [ ] noteCounter = new int [ 9 ] ;\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    System . out . println ( \"Currency Count ->\" ) ;\n    for ( int i = 0 ;\n    i < 9 ;\n    i ++ ) {\n      if ( noteCounter [ i ] != 0 ) {\n        System . out . println ( notes [ i ] + \" : \" + noteCounter [ i ] ) ;\n      }\n    }\n  }\n  ", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS": "static void rearrange ( int a [ ] , int size ) {\n  int positive = 0 , negative = 1 , temp ;\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 ) {\n      temp = a [ positive ] ;\n      a [ positive ] = a [ negative ] ;\n      a [ negative ] = temp ;\n    }\n    else break ;\n  }\n}\n", "FIND_WHETHER_AN_ARRAY_IS_SUBSET_OF_ANOTHER_ARRAY_SET_1": "static boolean 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 ++ ) if ( arr2 [ i ] == arr1 [ j ] ) break ;\n    if ( j == m ) return false ;\n  }\n  return true ;\n}\n", "GIVEN_A_SORTED_AND_ROTATED_ARRAY_FIND_IF_THERE_IS_A_PAIR_WITH_A_GIVEN_SUM": "static boolean 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": "static int getRemainder ( int num , int divisor ) {\n  if ( divisor == 0 ) {\n    System . out . println ( \"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": "static 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      int temp = 0 ;\n      temp = arr [ index ] ;\n      arr [ index ] = arr [ index - 1 ] ;\n      arr [ index - 1 ] = temp ;\n      index -- ;\n    }\n  }\n  return ;\n}\n", "NUMBER_WAYS_INSERT_CHARACTER_INCREASE_LCS_ONE": "static int numberofways ( String A , String B , int N , int M ) {\n  Vector < Integer > [ ] pos = new Vector [ MAX ] ;\n  for ( int i = 0 ;\n  i < MAX ;\n  i ++ ) pos [ i ] = new Vector < > ( ) ;\n  for ( int i = 0 ;\n  i < M ;\n  i ++ ) pos [ B . charAt ( i ) ] . add ( i + 1 ) ;\n  int [ ] [ ] dpl = new int [ N + 2 ] [ M + 2 ] ;\n  for ( int i = 1 ;\n  i <= N ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= M ;\n    j ++ ) {\n      if ( A . charAt ( i - 1 ) == B . charAt ( j - 1 ) ) dpl [ i ] [ j ] = dpl [ i - 1 ] [ j - 1 ] + 1 ;\n      else dpl [ i ] [ j ] = Math . max ( dpl [ i - 1 ] [ j ] , dpl [ i ] [ j - 1 ] ) ;\n    }\n  }\n  int LCS = dpl [ N ] [ M ] ;\n  int [ ] [ ] dpr = new int [ N + 2 ] [ M + 2 ] ;\n  for ( int i = N ;\n  i >= 1 ;\n  i -- ) {\n    for ( int j = M ;\n    j >= 1 ;\n    j -- ) {\n      if ( A . charAt ( i - 1 ) == B . charAt ( j - 1 ) ) dpr [ i ] [ j ] = dpr [ i + 1 ] [ j + 1 ] + 1 ;\n      else dpr [ i ] [ j ] = Math . 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 ( int 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": "public static int minProduct ( int [ ] arr , int n , int k ) {\n  PriorityQueue < Integer > pq = new PriorityQueue < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) pq . add ( arr [ i ] ) ;\n  int count = 0 , ans = 1 ;\n  while ( pq . isEmpty ( ) == false && count < k ) {\n    ans = ans * pq . element ( ) ;\n    pq . remove ( ) ;\n    count ++ ;\n  }\n  return ans ;\n}\n", "FIND_UNIQUE_ELEMENTS_MATRIX": "static void unique ( int mat [ ] [ ] , 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 [ ] = new int [ maximum + 1 ] ;\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 ) System . out . print ( i + \" \" ) ;\n  flag = 1 ;\n  if ( flag == 0 ) {\n    System . out . println ( \"No unique element \" + \"in the matrix\" ) ;\n  }\n}\n", "LONGEST_SUBSEQUENCE_SUCH_THAT_DIFFERENCE_BETWEEN_ADJACENTS_IS_ONE": "static int longestSubseqWithDiffOne ( int arr [ ] , int n ) {\n  int dp [ ] = new int [ 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 ] = Math . 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": "static 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": "public static void search ( String txt , String pat ) {\n  int M = pat . length ( ) ;\n  int N = txt . length ( ) ;\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 . charAt ( i + j ) != pat . charAt ( j ) ) break ;\n    if ( j == M ) System . out . println ( \"Pattern found at index \" + i ) ;\n  }\n}\n", "COUNT_POSSIBLE_PATHS_SOURCE_DESTINATION_EXACTLY_K_EDGES": "int countwalks ( int graph [ ] [ ] , int u , int v , int k ) {\n  if ( k == 0 && u == v ) return 1 ;\n  if ( k == 1 && graph [ u ] [ v ] == 1 ) 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": "static 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": "static boolean isSymmetric ( int mat [ ] [ ] , 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": "static int CountPS ( char str [ ] , int n ) {\n  int dp [ ] [ ] = new int [ n ] [ n ] ;\n  boolean P [ ] [ ] = new boolean [ n ] [ n ] ;\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": "static int countWays ( int N ) {\n  int count [ ] = new int [ N + 1 ] ;\n  count [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i <= N ;\n  i ++ ) for ( int j = 0 ;\n  j < arr . length ;\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": "static 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 ( Character . isUpperCase ( str . charAt ( i ) ) ) {\n      lastUpper = i ;\n      break ;\n    }\n  }\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( Character . isLowerCase ( str . charAt ( 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 ( Character . isUpperCase ( str . charAt ( i ) ) ) {\n      countUpper ++ ;\n    }\n  }\n  int countLower = 0 ;\n  for ( i = 0 ;\n  i < lastUpper ;\n  i ++ ) {\n    if ( Character . isLowerCase ( str . charAt ( i ) ) ) {\n      countLower ++ ;\n    }\n  }\n  return Math . min ( countLower , countUpper ) ;\n}\n", "PRINT_A_GIVEN_MATRIX_IN_SPIRAL_FORM": "static void spiralPrint ( int m , int n , int a [ ] [ ] ) {\n  int i , k = 0 , l = 0 ;\n  while ( k < m && l < n ) {\n    for ( i = l ;\n    i < n ;\n    ++ i ) {\n      System . out . print ( a [ k ] [ i ] + \" \" ) ;\n    }\n    k ++ ;\n    for ( i = k ;\n    i < m ;\n    ++ i ) {\n      System . out . print ( a [ i ] [ n - 1 ] + \" \" ) ;\n    }\n    n -- ;\n    if ( k < m ) {\n      for ( i = n - 1 ;\n      i >= l ;\n      -- i ) {\n        System . out . print ( a [ m - 1 ] [ i ] + \" \" ) ;\n      }\n      m -- ;\n    }\n    if ( l < n ) {\n      for ( i = m - 1 ;\n      i >= k ;\n      -- i ) {\n        System . out . print ( a [ i ] [ l ] + \" \" ) ;\n      }\n      l ++ ;\n    }\n  }\n}\n", "FIND_DISTINCT_INTEGERS_FOR_A_TRIPLET_WITH_GIVEN_PRODUCT": "static void findTriplets ( int x ) {\n  Vector < Integer > fact = new Vector < Integer > ( ) ;\n  HashSet < Integer > factors = new HashSet < Integer > ( ) ;\n  for ( int i = 2 ;\n  i <= Math . sqrt ( x ) ;\n  i ++ ) {\n    if ( x % i == 0 ) {\n      fact . add ( i ) ;\n      if ( x / i != i ) fact . add ( x / i ) ;\n      factors . add ( i ) ;\n      factors . add ( x / i ) ;\n    }\n  }\n  boolean found = false ;\n  int k = fact . size ( ) ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) {\n    int a = fact . get ( i ) ;\n    for ( int j = 0 ;\n    j < k ;\n    j ++ ) {\n      int b = fact . get ( j ) ;\n      if ( ( a != b ) && ( x % ( a * b ) == 0 ) && ( x / ( a * b ) != a ) && ( x / ( a * b ) != b ) && ( x / ( a * b ) != 1 ) ) {\n        System . out . print ( a + \" \" + b + \" \" + ( x / ( a * b ) ) ) ;\n        found = true ;\n        break ;\n      }\n    }\n    if ( found ) break ;\n  }\n  if ( ! found ) System . out . print ( \"-1\" ) ;\n}\n", "SUM_TWO_LARGE_NUMBERS_1": "static String findSum ( String str1 , String str2 ) {\n  if ( str1 . length ( ) > str2 . length ( ) ) {\n    String t = str1 ;\n    str1 = str2 ;\n    str2 = t ;\n  }\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 = ( ( int ) ( str1 . charAt ( i ) - '0' ) + ( int ) ( str2 . charAt ( i + diff ) - '0' ) + carry ) ;\n    str += ( char ) ( sum % 10 + '0' ) ;\n    carry = sum / 10 ;\n  }\n  for ( int i = n2 - n1 - 1 ;\n  i >= 0 ;\n  i -- ) {\n    int sum = ( ( int ) ( str2 . charAt ( i ) - '0' ) + carry ) ;\n    str += ( char ) ( sum % 10 + '0' ) ;\n    carry = sum / 10 ;\n  }\n  if ( carry > 0 ) str += ( char ) ( carry + '0' ) ;\n  return new StringBuilder ( str ) . reverse ( ) . toString ( ) ;\n}\n", "COCKTAIL_SORT": "void cocktailSort ( int a [ ] ) {\n  boolean swapped = true ;\n  int start = 0 ;\n  int end = a . length ;\n  while ( swapped == true ) {\n    swapped = false ;\n    for ( int i = start ;\n    i < end - 1 ;\n    ++ i ) {\n      if ( a [ i ] > a [ i + 1 ] ) {\n        int temp = a [ i ] ;\n        a [ i ] = a [ i + 1 ] ;\n        a [ i + 1 ] = temp ;\n        swapped = true ;\n      }\n    }\n    if ( swapped == false ) break ;\n    swapped = false ;\n    end = end - 1 ;\n    for ( int i = end - 1 ;\n    i >= start ;\n    i -- ) {\n      if ( a [ i ] > a [ i + 1 ] ) {\n        int temp = a [ i ] ;\n        a [ i ] = a [ i + 1 ] ;\n        a [ i + 1 ] = temp ;\n        swapped = true ;\n      }\n    }\n    start = start + 1 ;\n  }\n}\n", "COUNT_DERANGEMENTS_PERMUTATION_SUCH_THAT_NO_ELEMENT_APPEARS_IN_ITS_ORIGINAL_POSITION_1": "static int countDer ( int n ) {\n  int der [ ] = new int [ 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": "static int findMaxProduct ( int arr [ ] , int n ) {\n  int i ;\n  int ans = Integer . MIN_VALUE ;\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 = Math . 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 = Math . 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": "static void assign ( int a [ ] , int n ) {\n  Arrays . sort ( a ) ;\n  int ans [ ] = new int [ 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 ++ ) System . out . print ( ans [ i ] + \" \" ) ;\n}\n", "FRIENDS_PAIRING_PROBLEM": "static int countFriendsPairings ( int n ) {\n  int dp [ ] = new int [ 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": "static boolean 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": "static float find_prob ( int N , float P ) {\n  double dp [ ] = new double [ 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 ( ( float ) ( dp [ N ] ) ) ;\n}\n", "SMALLEST_OF_THREE_INTEGERS_WITHOUT_COMPARISON_OPERATORS_1": "static int smallest ( int x , int y , int z ) {\n  if ( ( y / x ) != 1 ) return ( ( y / z ) != 1 ) ? y : z ;\n  return ( ( x / z ) != 1 ) ? x : z ;\n}\n", "COMMON_ELEMENTS_IN_ALL_ROWS_OF_A_GIVEN_MATRIX": "static void printCommonElements ( int mat [ ] [ ] ) {\n  Map < Integer , Integer > mp = new HashMap < > ( ) ;\n  for ( int j = 0 ;\n  j < N ;\n  j ++ ) mp . put ( 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 . get ( mat [ i ] [ j ] ) != null && mp . get ( mat [ i ] [ j ] ) == i ) {\n        mp . put ( mat [ i ] [ j ] , i + 1 ) ;\n        if ( i == M - 1 ) System . out . print ( mat [ i ] [ j ] + \" \" ) ;\n      }\n    }\n  }\n}\n", "DETECTING_NEGATIVE_CYCLE_USING_FLOYD_WARSHALL": "static boolean negCyclefloydWarshall ( int graph [ ] [ ] ) {\n  int dist [ ] [ ] = new int [ 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 ( i = 0 ;\n  i < V ;\n  i ++ ) if ( dist [ i ] [ i ] < 0 ) return true ;\n  return false ;\n}\n", "PROGRAM_SORT_STRING_DESCENDING_ORDER": "static void sortString ( String str ) {\n  int charCount [ ] = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    charCount [ str . charAt ( i ) - 'a' ] ++ ;\n  }\n  for ( int i = MAX_CHAR - 1 ;\n  i >= 0 ;\n  i -- ) {\n    for ( int j = 0 ;\n    j < charCount [ i ] ;\n    j ++ ) {\n      System . out . print ( ( char ) ( 'a' + i ) ) ;\n    }\n  }\n}\n", "COUNT_PAIRS_WITH_GIVEN_SUM": "public static void getPairsCount ( int [ ] arr , int sum ) {\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) for ( int j = i + 1 ;\n  j < arr . length ;\n  j ++ ) if ( ( arr [ i ] + arr [ j ] ) == sum ) count ++ ;\n  System . out . printf ( \"Count of pairs is %d\" , count ) ;\n}\n", "SUM_SERIES_12_32_52_2N_12_1": "static 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": "static int maxdiff ( int arr [ ] , int n ) {\n  Map < Integer , Integer > freq = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) freq . put ( arr [ i ] , freq . get ( arr [ i ] ) == null ? 1 : freq . get ( arr [ i ] ) + 1 ) ;\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 . get ( arr [ i ] ) > freq . get ( arr [ j ] ) && arr [ i ] > arr [ j ] ) ans = Math . max ( ans , freq . get ( arr [ i ] ) - freq . get ( arr [ j ] ) ) ;\n      else if ( freq . get ( arr [ i ] ) < freq . get ( arr [ j ] ) && arr [ i ] < arr [ j ] ) ans = Math . max ( ans , freq . get ( arr [ j ] ) - freq . get ( arr [ i ] ) ) ;\n    }\n  }\n  return ans ;\n}\n", "SHIFT_MATRIX_ELEMENTS_K": "static void shiftMatrixByK ( int [ ] [ ] mat , int k ) {\n  if ( k > N ) {\n    System . out . print ( \"Shifting is\" + \" not possible\" ) ;\n    return ;\n  }\n  int j = 0 ;\n  while ( j < N ) {\n    for ( int i = k ;\n    i < N ;\n    i ++ ) System . out . print ( mat [ j ] [ i ] + \" \" ) ;\n    for ( int i = 0 ;\n    i < k ;\n    i ++ ) System . out . print ( mat [ j ] [ i ] + \" \" ) ;\n    System . out . println ( ) ;\n    j ++ ;\n  }\n}\n", "MAXIMUM_AND_MINIMUM_IN_A_SQUARE_MATRIX": "static void maxMin ( int arr [ ] [ ] , int n ) {\n  int min = + 2147483647 ;\n  int max = - 2147483648 ;\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  System . out . print ( \"Maximum = \" + max + \", Minimum = \" + min ) ;\n}\n", "FIND_PAIR_WITH_GREATEST_PRODUCT_IN_ARRAY_1": "static int findGreatest ( int arr [ ] , int n ) {\n  Map < Integer , Integer > m = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( m . containsKey ( arr [ i ] ) ) {\n      m . put ( arr [ i ] , m . get ( arr [ i ] ) + 1 ) ;\n    }\n    else {\n      m . put ( arr [ i ] , m . get ( arr [ i ] ) ) ;\n    }\n  }\n  Arrays . sort ( arr ) ;\n  for ( int i = n - 1 ;\n  i > 1 ;\n  i -- ) {\n    for ( int j = 0 ;\n    j < i && arr [ j ] <= Math . 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 . get ( result ) == null || m . get ( result ) > 0 ) {\n          return arr [ i ] ;\n        }\n        else if ( result == arr [ j ] && m . get ( result ) > 1 ) {\n          return arr [ i ] ;\n        }\n      }\n    }\n  }\n  return - 1 ;\n}\n", "0_1_KNAPSACK_PROBLEM_DP_10_1": "static int knapSack ( int W , int wt [ ] , int val [ ] , int n ) {\n  int i , w ;\n  int K [ ] [ ] = new int [ 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": "static void decToOctal ( int n ) {\n  int [ ] octalNum = new int [ 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 -- ) System . out . print ( octalNum [ j ] ) ;\n}\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M_1": "static int countSubSeq ( int A [ ] , int N , int M ) {\n  int ans = 0 ;\n  int h [ ] = new int [ M ] ;\n  Arrays . fill ( h , 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": "static 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": "static int isPowerOfFour ( int n ) {\n  int count = 0 ;\n  int x = n & ( n - 1 ) ;\n  if ( n > 0 && x == 0 ) {\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": "public static int sumofFactors ( int n ) {\n  if ( n % 2 != 0 ) return 0 ;\n  int res = 1 ;\n  for ( int i = 2 ;\n  i <= Math . 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      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": "static int findSum ( int arr [ ] , int n ) {\n  int sum = 0 ;\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! s . contains ( arr [ i ] ) ) {\n      sum += arr [ i ] ;\n      s . add ( arr [ i ] ) ;\n    }\n  }\n  return sum ;\n}\n", "DYNAMIC_PROGRAMMING_SET_17_PALINDROME_PARTITIONING_1": "static int minPalPartion ( String str ) {\n  int n = str . length ( ) ;\n  int [ ] C = new int [ n ] ;\n  boolean [ ] [ ] P = new boolean [ 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 . charAt ( i ) == str . charAt ( j ) ) ;\n      else P [ i ] [ j ] = ( str . charAt ( i ) == str . charAt ( 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 ] = Integer . MAX_VALUE ;\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": "static int minInitialPoints ( int points [ ] [ ] , int R , int C ) {\n  int dp [ ] [ ] = new int [ R ] [ C ] ;\n  int m = R , n = C ;\n  dp [ m - 1 ] [ n - 1 ] = points [ m - 1 ] [ n - 1 ] > 0 ? 1 : Math . abs ( points [ m - 1 ] [ n - 1 ] ) + 1 ;\n  for ( int i = m - 2 ;\n  i >= 0 ;\n  i -- ) dp [ i ] [ n - 1 ] = Math . 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 ] = Math . 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 = Math . min ( dp [ i + 1 ] [ j ] , dp [ i ] [ j + 1 ] ) ;\n      dp [ i ] [ j ] = Math . 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": "static int countPair ( int a , int b ) {\n  String s = String . valueOf ( b ) ;\n  int i ;\n  for ( i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    if ( s . charAt ( 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": "static void survival ( int S , int N , int M ) {\n  if ( ( ( N * 6 ) < ( M * 7 ) && S > 6 ) || M > N ) System . out . println ( \"No\" ) ;\n  else {\n    int days = ( M * S ) / N ;\n    if ( ( ( M * S ) % N ) != 0 ) days ++ ;\n    System . out . println ( \"Yes \" + days ) ;\n  }\n}\n", "INTERLEAVE_FIRST_HALF_QUEUE_SECOND_HALF": "static void interLeaveQueue ( Queue < Integer > q ) {\n  if ( q . size ( ) % 2 != 0 ) System . out . println ( \"Input even number of integers.\" ) ;\n  Stack < Integer > s = new Stack < > ( ) ;\n  int halfSize = q . size ( ) / 2 ;\n  for ( int i = 0 ;\n  i < halfSize ;\n  i ++ ) {\n    s . push ( q . peek ( ) ) ;\n    q . poll ( ) ;\n  }\n  while ( ! s . empty ( ) ) {\n    q . add ( s . peek ( ) ) ;\n    s . pop ( ) ;\n  }\n  for ( int i = 0 ;\n  i < halfSize ;\n  i ++ ) {\n    q . add ( q . peek ( ) ) ;\n    q . poll ( ) ;\n  }\n  for ( int i = 0 ;\n  i < halfSize ;\n  i ++ ) {\n    s . push ( q . peek ( ) ) ;\n    q . poll ( ) ;\n  }\n  while ( ! s . empty ( ) ) {\n    q . add ( s . peek ( ) ) ;\n    s . pop ( ) ;\n    q . add ( q . peek ( ) ) ;\n    q . poll ( ) ;\n  }\n}\n", "INTEGER_POSITIVE_VALUE_POSITIVE_NEGATIVE_VALUE_ARRAY_1": "static 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 / Math . abs ( neg - pos ) ) ;\n}\n", "FIND_SUM_EVEN_INDEX_BINOMIAL_COEFFICIENTS": "static int evenSum ( int n ) {\n  int C [ ] [ ] = new int [ n + 1 ] [ n + 1 ] ;\n  int i , j ;\n  for ( i = 0 ;\n  i <= n ;\n  i ++ ) {\n    for ( j = 0 ;\n    j <= Math . 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 ( i = 0 ;\n  i <= n ;\n  i += 2 ) sum += C [ n ] [ i ] ;\n  return sum ;\n}\n", "DELANNOY_NUMBER": "public static 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": "static 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 = Math . max ( max_len , j - i + 1 ) ;\n    }\n  }\n  return max_len ;\n}\n", "NEXT_POWER_OF_2": "static int nextPowerOf2 ( int n ) {\n  int count = 0 ;\n  if ( n > 0 && ( n & ( n - 1 ) ) == 0 ) return n ;\n  while ( n != 0 ) {\n    n >>= 1 ;\n    count += 1 ;\n  }\n  return 1 << count ;\n}\n", "LONGEST_GEOMETRIC_PROGRESSION": "static int lenOfLongestGP ( int set [ ] , int n ) {\n  if ( n < 2 ) {\n    return n ;\n  }\n  if ( n == 2 ) {\n    return ( set [ 1 ] % set [ 0 ] == 0 ? 1 : 0 ) ;\n  }\n  Arrays . sort ( set ) ;\n  int L [ ] [ ] = new int [ n ] [ n ] ;\n  int llgp = 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) {\n    if ( set [ n - 1 ] % set [ i ] == 0 ) {\n      L [ i ] [ n - 1 ] = 2 ;\n    }\n    else {\n      L [ i ] [ n - 1 ] = 1 ;\n    }\n  }\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 ] ) {\n        ++ k ;\n      }\n      else if ( set [ i ] * set [ k ] > set [ j ] * set [ j ] ) {\n        if ( set [ j ] % set [ i ] == 0 ) {\n          L [ i ] [ j ] = 2 ;\n        }\n        else {\n          L [ i ] [ j ] = 1 ;\n        }\n        -- i ;\n      }\n      else {\n        L [ i ] [ j ] = L [ j ] [ k ] + 1 ;\n        if ( L [ i ] [ j ] > llgp ) {\n          llgp = L [ i ] [ j ] ;\n        }\n        -- i ;\n        ++ k ;\n      }\n    }\n    while ( i >= 0 ) {\n      if ( set [ j ] % set [ i ] == 0 ) {\n        L [ i ] [ j ] = 2 ;\n      }\n      else {\n        L [ i ] [ j ] = 1 ;\n      }\n      -- i ;\n    }\n  }\n  return llgp ;\n}\n", "DYNAMIC_PROGRAMMING_SET_6_MIN_COST_PATH": "private static int minCost ( int cost [ ] [ ] , int m , int n ) {\n  int i , j ;\n  int tc [ ] [ ] = new int [ m + 1 ] [ n + 1 ] ;\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": "public static double distance ( double lat1 , double lat2 , double lon1 , double lon2 ) {\n  lon1 = Math . toRadians ( lon1 ) ;\n  lon2 = Math . toRadians ( lon2 ) ;\n  lat1 = Math . toRadians ( lat1 ) ;\n  lat2 = Math . toRadians ( lat2 ) ;\n  double dlon = lon2 - lon1 ;\n  double dlat = lat2 - lat1 ;\n  double a = Math . pow ( Math . sin ( dlat / 2 ) , 2 ) + Math . cos ( lat1 ) * Math . cos ( lat2 ) * Math . pow ( Math . sin ( dlon / 2 ) , 2 ) ;\n  double c = 2 * Math . asin ( Math . sqrt ( a ) ) ;\n  double r = 6371 ;\n  return ( c * r ) ;\n}\n", "BIN_PACKING_PROBLEM_MINIMIZE_NUMBER_OF_USED_BINS": "static 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      int p = i - 1 ;\n      System . out . println ( \"Sum found between indexes \" + start + \" and \" + p ) ;\n      return 1 ;\n    }\n    if ( i < n ) curr_sum = curr_sum + arr [ i ] ;\n  }\n  System . out . println ( \"No subarray found\" ) ;\n  return 0 ;\n}\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM_1": "static int KnapSack ( int val [ ] , int wt [ ] , int n , int W ) {\n  int [ ] dp = new int [ W + 1 ] ;\n  Arrays . fill ( dp , 0 ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = W ;\n  j >= wt [ i ] ;\n  j -- ) dp [ j ] = Math . 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": "static long yMod ( long y , long x ) {\n  if ( ( Math . log ( y ) / Math . log ( 2 ) ) < x ) return y ;\n  if ( x > 63 ) return y ;\n  return ( y % ( 1 << ( int ) x ) ) ;\n}\n", "SUM_SERIES_23_45_67_89_UPTO_N_TERMS": "static double seriesSum ( int n ) {\n  int i = 1 ;\n  double res = 0.0 ;\n  boolean 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": "static int longLenStrictBitonicSub ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > inc = new HashMap < Integer , Integer > ( ) ;\n  HashMap < Integer , Integer > dcr = new HashMap < Integer , Integer > ( ) ;\n  int len_inc [ ] = new int [ n ] ;\n  int len_dcr [ ] = new int [ n ] ;\n  int longLen = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int len = 0 ;\n    if ( inc . containsKey ( arr [ i ] - 1 ) ) len = inc . get ( arr [ i ] - 1 ) ;\n    len_inc [ i ] = len + 1 ;\n    inc . put ( arr [ i ] , len_inc [ i ] ) ;\n  }\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    int len = 0 ;\n    if ( dcr . containsKey ( arr [ i ] - 1 ) ) len = dcr . get ( arr [ i ] - 1 ) ;\n    len_dcr [ i ] = len + 1 ;\n    dcr . put ( arr [ i ] , len_dcr [ i ] ) ;\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": "static int maxDistance ( int [ ] arr , int n ) {\n  HashMap < Integer , Integer > map = new HashMap < > ( ) ;\n  int max_dist = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! map . containsKey ( arr [ i ] ) ) map . put ( arr [ i ] , i ) ;\n    else max_dist = Math . max ( max_dist , i - map . get ( arr [ i ] ) ) ;\n  }\n  return max_dist ;\n}\n", "FIND_RECTANGLE_BINARY_MATRIX_CORNERS_1_1": "static boolean isRectangle ( int matrix [ ] [ ] ) {\n  int rows = matrix . length ;\n  if ( rows == 0 ) return false ;\n  int columns = matrix [ 0 ] . length ;\n  HashMap < Integer , HashSet < Integer >> table = new HashMap < > ( ) ;\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 . containsKey ( j ) && table . get ( j ) . contains ( k ) ) {\n            return true ;\n          }\n          if ( table . containsKey ( k ) && table . get ( k ) . contains ( j ) ) {\n            return true ;\n          }\n          if ( ! table . containsKey ( j ) ) {\n            HashSet < Integer > x = new HashSet < > ( ) ;\n            x . add ( k ) ;\n            table . put ( j , x ) ;\n          }\n          else {\n            table . get ( j ) . add ( k ) ;\n          }\n          if ( ! table . containsKey ( k ) ) {\n            HashSet < Integer > x = new HashSet < > ( ) ;\n            x . add ( j ) ;\n            table . put ( k , x ) ;\n          }\n          else {\n            table . get ( k ) . add ( j ) ;\n          }\n        }\n      }\n    }\n  }\n  return false ;\n}\n", "COUNT_MINIMUM_NUMBER_SUBSETS_SUBSEQUENCES_CONSECUTIVE_NUMBERS": "static int numofsubset ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\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": "static int maxSubArraySum ( int a [ ] ) {\n  int size = a . length ;\n  int max_so_far = Integer . MIN_VALUE , 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": "static int getRemainder ( int num , int divisor ) {\n  while ( num >= divisor ) num -= divisor ;\n  return num ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_4_NOT": "static boolean check ( String str ) {\n  int n = str . length ( ) ;\n  if ( n == 0 ) return false ;\n  if ( n == 1 ) return ( ( str . charAt ( 0 ) - '0' ) % 4 == 0 ) ;\n  int last = str . charAt ( n - 1 ) - '0' ;\n  int second_last = str . charAt ( n - 2 ) - '0' ;\n  return ( ( second_last * 10 + last ) % 4 == 0 ) ;\n}\n", "FIND_THE_ELEMENT_THAT_APPEARS_ONCE_1": "static 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 ) == 0 ) sum ++ ;\n    }\n    if ( ( sum % 3 ) == 0 ) result |= x ;\n  }\n  return result ;\n}\n", "NUMBER_RECTANGLES_NM_GRID": "public static long rectCount ( int n , int m ) {\n  return ( m * n * ( n + 1 ) * ( m + 1 ) ) / 4 ;\n}\n", "MAXIMUM_POINTS_INTERSECTION_N_CIRCLES": "static int intersection ( int n ) {\n  return n * ( n - 1 ) ;\n}\n", "PRINT_DISTINCT_ELEMENTS_GIVEN_INTEGER_ARRAY_2": "static void printDistinct ( int arr [ ] ) {\n  HashSet < Integer > set = new HashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    if ( ! set . contains ( arr [ i ] ) ) {\n      set . add ( arr [ i ] ) ;\n      System . out . print ( arr [ i ] + \" \" ) ;\n    }\n  }\n}\n", "CHECK_ROWS_MATRIX_CIRCULAR_ROTATIONS": "static boolean isPermutedMatrix ( int mat [ ] [ ] , int n ) {\n  String str_cat = \"\" ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    str_cat = str_cat + \"-\" + String . valueOf ( mat [ 0 ] [ i ] ) ;\n  }\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 ++ ) {\n      curr_str = curr_str + \"-\" + String . valueOf ( mat [ i ] [ j ] ) ;\n    }\n    if ( str_cat . contentEquals ( curr_str ) ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "SUM_PAIRWISE_PRODUCTS": "static int findSum ( int n ) {\n  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": "static void printSorted ( int a , int b , int c ) {\n  int get_max = Math . max ( a , Math . max ( b , c ) ) ;\n  int get_min = - Math . max ( - a , Math . max ( - b , - c ) ) ;\n  int get_mid = ( a + b + c ) - ( get_max + get_min ) ;\n  System . out . print ( 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": "static int find_extra_element_index ( int [ ] arrA , int [ ] arrB ) {\n  int extra_element = sum ( arrA ) - sum ( arrB ) ;\n  return indexOf ( arrA , extra_element ) ;\n}\n", "SUBARRAYSUBSTRING_VS_SUBSEQUENCE_AND_PROGRAMS_TO_GENERATE_THEM_1": "static void printSubsequences ( int n ) {\n  int opsize = ( int ) Math . 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 ( BigInteger . valueOf ( counter ) . testBit ( j ) ) System . out . print ( arr [ j ] + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "N_BONACCI_NUMBERS": "static void bonacciseries ( int n , int m ) {\n  int [ ] a = new int [ m ] ;\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 ++ ) System . out . print ( a [ i ] + \" \" ) ;\n}\n", "LOWER_CASE_UPPER_CASE_INTERESTING_FACT": "static String to_upper ( char [ ] in ) {\n  for ( int i = 0 ;\n  i < in . length ;\n  i ++ ) {\n    if ( 'a' <= in [ i ] & in [ i ] <= 'z' ) {\n      in [ i ] = ( char ) ( in [ i ] - 'a' + 'A' ) ;\n    }\n  }\n  return String . valueOf ( in ) ;\n}\n", "PRINT_BRACKET_NUMBER": "static void printBracketNumber ( String exp , int n ) {\n  int left_bnum = 1 ;\n  Stack < Integer > right_bnum = new Stack < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( exp . charAt ( i ) == '(' ) {\n      System . out . print ( left_bnum + \" \" ) ;\n      right_bnum . push ( left_bnum ) ;\n      left_bnum ++ ;\n    }\n    else if ( exp . charAt ( i ) == ')' ) {\n      System . out . print ( right_bnum . peek ( ) + \" \" ) ;\n      right_bnum . pop ( ) ;\n    }\n  }\n}\n", "MAXIMUM_PRODUCT_OF_4_ADJACENT_ELEMENTS_IN_MATRIX": "static int FindMaxProduct ( int arr [ ] [ ] , 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": "static int longSubarrWthSumDivByK ( int arr [ ] , int n , int k ) {\n  HashMap < Integer , Integer > um = new HashMap < Integer , Integer > ( ) ;\n  int mod_arr [ ] = new int [ n ] ;\n  int 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 . containsKey ( mod_arr [ i ] ) == false ) um . put ( mod_arr [ i ] , i ) ;\n    else if ( max < ( i - um . get ( mod_arr [ i ] ) ) ) max = i - um . get ( mod_arr [ i ] ) ;\n  }\n  return max ;\n}\n", "CAESAR_CIPHER": "public static StringBuffer encrypt ( String text , int s ) {\n  StringBuffer result = new StringBuffer ( ) ;\n  for ( int i = 0 ;\n  i < text . length ( ) ;\n  i ++ ) {\n    if ( Character . isUpperCase ( text . charAt ( i ) ) ) {\n      char ch = ( char ) ( ( ( int ) text . charAt ( i ) + s - 65 ) % 26 + 65 ) ;\n      result . append ( ch ) ;\n    }\n    else {\n      char ch = ( char ) ( ( ( int ) text . charAt ( i ) + s - 97 ) % 26 + 97 ) ;\n      result . append ( ch ) ;\n    }\n  }\n  return result ;\n}\n", "SUBARRAYS_DISTINCT_ELEMENTS": "public static int sumoflength ( int [ ] arr , int n ) {\n  Set < Integer > s = new HashSet < > ( ) ;\n  int j = 0 , ans = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    while ( j < n && ! s . contains ( arr [ j ] ) ) {\n      s . add ( arr [ i ] ) ;\n      j ++ ;\n    }\n    ans += ( ( j - i ) * ( j - i + 1 ) ) / 2 ;\n    s . remove ( arr [ i ] ) ;\n  }\n  return ans ;\n}\n", "K_TH_ELEMENT_TWO_SORTED_ARRAYS": "static int kth ( int arr1 [ ] , int arr2 [ ] , int m , int n , int k ) {\n  int [ ] sorted1 = new int [ 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": "static void removeDuplicates ( char [ ] S ) {\n  int n = S . length ;\n  if ( n < 2 ) {\n    return ;\n  }\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  System . out . println ( Arrays . copyOfRange ( S , 0 , j + 1 ) ) ;\n}\n", "MAJORITY_ELEMENT": "static 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 ) System . out . println ( arr [ index ] ) ;\n  else System . out . println ( \"No Majority Element\" ) ;\n}\n", "FUNCTION_COPY_STRING_ITERATIVE_RECURSIVE_1": "static void myCopy ( char s1 [ ] , char s2 [ ] , int index ) {\n  s2 [ index ] = s1 [ index ] ;\n  if ( index == s1 . length - 1 ) {\n    return ;\n  }\n  myCopy ( s1 , s2 , index + 1 ) ;\n}\n", "COUNT_NUMBER_OF_WAYS_TO_COVER_A_DISTANCE_1": "static int printCountDP ( int dist ) {\n  int [ ] count = new int [ dist + 1 ] ;\n  count [ 0 ] = 1 ;\n  count [ 1 ] = 1 ;\n  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": "static int discreteLogarithm ( int a , int b , int m ) {\n  int n = ( int ) ( Math . sqrt ( m ) + 1 ) ;\n  int an = 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) an = ( an * a ) % m ;\n  int [ ] value = new int [ m ] ;\n  for ( int i = 1 , cur = an ;\n  i <= n ;\n  ++ i ) {\n    if ( value [ cur ] == 0 ) 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 ] > 0 ) {\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": "static boolean isOneFlip ( String str ) {\n  int sum = 0 ;\n  int n = str . length ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum += str . charAt ( i ) - '0' ;\n  return ( sum == n - 1 || sum == 1 ) ;\n}\n", "FIND_PAIRS_IN_ARRAY_WHOSE_SUMS_ALREADY_EXIST_IN_ARRAY": "static void findPair ( int [ ] arr , int n ) {\n  boolean 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          System . out . println ( arr [ i ] + \" \" + arr [ j ] ) ;\n          found = true ;\n        }\n      }\n    }\n  }\n  if ( found == false ) System . out . println ( \"Not exist\" ) ;\n}\n", "MODULAR_MULTIPLICATIVE_INVERSE_1_N": "static void modularInverse ( int n , int prime ) {\n  int dp [ ] = new int [ 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 ++ ) System . out . print ( dp [ i ] + \" \" ) ;\n}\n", "SHUFFLE_2N_INTEGERS_FORMAT_A1_B1_A2_B2_A3_B3_BN_WITHOUT_USING_EXTRA_SPACE_1": "static void shufleArray ( int a [ ] , int f , int l ) {\n  if ( l > f ) return ;\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 ++ ) {\n    int temp1 = a [ i ] ;\n    a [ i ] = a [ temp ] ;\n    a [ temp ++ ] = temp1 ;\n  }\n  shufleArray ( a , f , mid ) ;\n  shufleArray ( a , mid + 1 , l ) ;\n}\n", "N_TH_ROOT_NUMBER": "static double nthRoot ( int A , int N ) {\n  double xPre = Math . random ( ) % 10 ;\n  double eps = 0.001 ;\n  double delX = 2147483647 ;\n  double xK = 0.0 ;\n  while ( delX > eps ) {\n    xK = ( ( N - 1.0 ) * xPre + ( double ) A / Math . pow ( xPre , N - 1 ) ) / ( double ) N ;\n    delX = Math . abs ( xK - xPre ) ;\n    xPre = xK ;\n  }\n  return xK ;\n}\n", "NUMBER_OF_WAYS_TO_ARRANGE_N_ITEMS_UNDER_GIVEN_CONSTRAINTS": "static int waysToArrange ( int N , int K , int [ ] k ) {\n  int [ ] [ ] C = new int [ 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 ) {\n        C [ i ] [ j ] = 1 ;\n      }\n      else {\n        C [ i ] [ j ] = ( C [ i - 1 ] [ j - 1 ] + C [ i - 1 ] [ j ] ) ;\n      }\n    }\n  }\n  int [ ] dp = new int [ K + 1 ] ;\n  int count = 0 ;\n  dp [ 0 ] = 1 ;\n  for ( 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": "static 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 += Math . max ( right , left ) + 1 ;\n  }\n  return sum ;\n}\n", "CENTER_ELEMENT_OF_MATRIX_EQUALS_SUMS_OF_HALF_DIAGONALS": "static boolean HalfDiagonalSums ( int mat [ ] [ ] , 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": "static 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": "static void reverseStr ( String str ) {\n  int n = str . length ( ) ;\n  char [ ] ch = str . toCharArray ( ) ;\n  char temp ;\n  for ( int i = 0 , j = n - 1 ;\n  i < j ;\n  i ++ , j -- ) {\n    temp = ch [ i ] ;\n    ch [ i ] = ch [ j ] ;\n    ch [ j ] = temp ;\n  }\n  System . out . println ( ch ) ;\n}\n", "FIND_MINIMUM_ADJUSTMENT_COST_OF_AN_ARRAY": "static int minAdjustmentCost ( int A [ ] , int n , int target ) {\n  int [ ] [ ] dp = new int [ n ] [ M + 1 ] ;\n  for ( int j = 0 ;\n  j <= M ;\n  j ++ ) dp [ 0 ] [ j ] = Math . 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 ] = Integer . MAX_VALUE ;\n      int k = Math . max ( j - target , 0 ) ;\n      for ( ;\n      k <= Math . min ( M , j + target ) ;\n      k ++ ) dp [ i ] [ j ] = Math . min ( dp [ i ] [ j ] , dp [ i - 1 ] [ k ] + Math . abs ( A [ i ] - j ) ) ;\n    }\n  }\n  int res = Integer . MAX_VALUE ;\n  for ( int j = 0 ;\n  j <= M ;\n  j ++ ) res = Math . min ( res , dp [ n - 1 ] [ j ] ) ;\n  return res ;\n}\n", "COUNT_FREQUENCY_K_MATRIX_SIZE_N_MATRIXI_J_IJ": "public static 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": "static int minimumflip ( int mat [ ] [ ] , 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": "static void nthPalindrome ( int n , int k ) {\n  int temp = ( k & 1 ) != 0 ? ( k / 2 ) : ( k / 2 - 1 ) ;\n  int palindrome = ( int ) Math . pow ( 10 , temp ) ;\n  palindrome += n - 1 ;\n  System . out . print ( palindrome ) ;\n  if ( ( k & 1 ) > 0 ) palindrome /= 10 ;\n  while ( palindrome > 0 ) {\n    System . out . print ( palindrome % 10 ) ;\n    palindrome /= 10 ;\n  }\n  System . out . println ( \"\" ) ;\n}\n", "DYNAMIC_PROGRAMMING_SET_3_LONGEST_INCREASING_SUBSEQUENCE_1": "static int lis ( int arr [ ] , int n ) {\n  int lis [ ] = new int [ n ] ;\n  int i , j , max = 0 ;\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  for ( i = 0 ;\n  i < n ;\n  i ++ ) if ( max < lis [ i ] ) max = lis [ i ] ;\n  return max ;\n}\n", "PATH_MAXIMUM_AVERAGE_VALUE": "public static double maxAverageOfPath ( int cost [ ] [ ] , int N ) {\n  int dp [ ] [ ] = new int [ 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 ] = Math . 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": "public static int count ( String s , char c ) {\n  int res = 0 ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    if ( s . charAt ( i ) == c ) res ++ ;\n  }\n  return res ;\n}\n", "KTH_SMALLESTLARGEST_ELEMENT_UNSORTED_ARRAY": "public static int kthSmallest ( Integer [ ] arr , int k ) {\n  Arrays . sort ( arr ) ;\n  return arr [ k - 1 ] ;\n}\n", "CONVERT_ALTERNATE_CHARACTERS_STRING_UPPER_CASE": "static void convertOpposite ( StringBuffer str ) {\n  int ln = str . length ( ) ;\n  for ( int i = 0 ;\n  i < ln ;\n  i ++ ) {\n    Character c = str . charAt ( i ) ;\n    if ( Character . isLowerCase ( c ) ) str . replace ( i , i + 1 , Character . toUpperCase ( c ) + \"\" ) ;\n    else str . replace ( i , i + 1 , Character . toLowerCase ( c ) + \"\" ) ;\n  }\n}\n", "SUM_SERIES_555555_N_TERMS": "static int sumOfSeries ( int n ) {\n  return ( int ) ( 0.6172 * ( Math . pow ( 10 , n ) - 1 ) - 0.55 * n ) ;\n}\n", "DYNAMIC_PROGRAMMING_SET_8_MATRIX_CHAIN_MULTIPLICATION": "static int MatrixChainOrder ( int p [ ] , int i , int j ) {\n  if ( i == j ) return 0 ;\n  int min = Integer . MAX_VALUE ;\n  for ( int k = i ;\n  k < j ;\n  k ++ ) {\n    int 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": "public static 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": "static 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    System . out . println ( \"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  System . out . println ( \" The unsorted subarray which\" + \" makes the given array sorted lies\" + \"  between the indices \" + s + \" and \" + e ) ;\n  return ;\n}\n", "STEINS_ALGORITHM_FOR_FINDING_GCD": "static 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 ) {\n      int temp = a ;\n      a = b ;\n      b = temp ;\n    }\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": "static String convert ( String s ) {\n  int n = s . length ( ) ;\n  String s1 = \"\" ;\n  s1 = s1 + Character . toLowerCase ( s . charAt ( 0 ) ) ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( s . charAt ( i ) == ' ' && i < n ) {\n      s1 = s1 + \" \" + Character . toLowerCase ( s . charAt ( i + 1 ) ) ;\n      i ++ ;\n    }\n    else s1 = s1 + Character . toUpperCase ( s . charAt ( i ) ) ;\n  }\n  return s1 ;\n}\n", "FIND_A_ROTATION_WITH_MAXIMUM_HAMMING_DISTANCE": "static int maxHamming ( int arr [ ] , int n ) {\n  int brr [ ] = new int [ 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 = Math . 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": "static void generateGrayarr ( int n ) {\n  if ( n <= 0 ) return ;\n  ArrayList < String > arr = new ArrayList < String > ( ) ;\n  arr . add ( \"0\" ) ;\n  arr . add ( \"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 . add ( arr . get ( j ) ) ;\n    for ( j = 0 ;\n    j < i ;\n    j ++ ) arr . set ( j , \"0\" + arr . get ( j ) ) ;\n    for ( j = i ;\n    j < 2 * i ;\n    j ++ ) arr . set ( j , \"1\" + arr . get ( j ) ) ;\n  }\n  for ( i = 0 ;\n  i < arr . size ( ) ;\n  i ++ ) System . out . println ( arr . get ( i ) ) ;\n}\n", "MINIMUM_SWAPS_REQUIRED_BRING_ELEMENTS_LESS_EQUAL_K_TOGETHER": "static 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 = Math . min ( ans , bad ) ;\n  }\n  return ans ;\n}\n", "FIND_NTH_FIBONACCI_NUMBER_USING_GOLDEN_RATIO": "static int fib ( int n ) {\n  if ( n < 6 ) return f [ n ] ;\n  int t = 5 ;\n  int fn = 5 ;\n  while ( t < n ) {\n    fn = ( int ) Math . round ( fn * PHI ) ;\n    t ++ ;\n  }\n  return fn ;\n}\n", "SORTING_ARRAY_REVERSE_AROUND_MIDDLE": "static boolean ifPossible ( int arr [ ] , int n ) {\n  int copy [ ] = Arrays . copyOf ( arr , arr . length ) ;\n  Arrays . sort ( copy ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! ( arr [ i ] == copy [ i ] ) && ! ( arr [ n - 1 - i ] == copy [ i ] ) ) return false ;\n  }\n  return true ;\n}\n", "COUNT_ROTATIONS_DIVISIBLE_4": "static int countRotations ( String n ) {\n  int len = n . length ( ) ;\n  if ( len == 1 ) {\n    int oneDigit = n . charAt ( 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 . charAt ( i ) - '0' ) * 10 + ( n . charAt ( i + 1 ) - '0' ) ;\n    if ( twoDigit % 4 == 0 ) count ++ ;\n  }\n  twoDigit = ( n . charAt ( len - 1 ) - '0' ) * 10 + ( n . charAt ( 0 ) - '0' ) ;\n  if ( twoDigit % 4 == 0 ) count ++ ;\n  return count ;\n}\n", "N_TH_NUMBER_WHOSE_SUM_OF_DIGITS_IS_TEN_2": "public static int findNth ( int n ) {\n  int nthElement = 19 + ( n - 1 ) * 9 ;\n  int outliersCount = ( int ) Math . log10 ( nthElement ) - 1 ;\n  nthElement += 9 * outliersCount ;\n  return nthElement ;\n}\n", "PRIMALITY_TEST_SET_1_INTRODUCTION_AND_SCHOOL_METHOD_1": "static boolean 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": "static int subset ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > mp = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) mp . put ( arr [ i ] , mp . get ( arr [ i ] ) == null ? 1 : mp . get ( arr [ i ] ) + 1 ) ;\n  int res = 0 ;\n  for ( Map . Entry < Integer , Integer > entry : mp . entrySet ( ) ) res = Math . max ( res , entry . getValue ( ) ) ;\n  return res ;\n}\n", "RECAMANS_SEQUENCE_1": "static void recaman ( int n ) {\n  if ( n <= 0 ) return ;\n  System . out . printf ( \"%d, \" , 0 ) ;\n  HashSet < Integer > s = new HashSet < Integer > ( ) ;\n  s . add ( 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 . contains ( curr ) ) curr = prev + i ;\n    s . add ( curr ) ;\n    System . out . printf ( \"%d, \" , curr ) ;\n    prev = curr ;\n  }\n}\n", "GENERATE_ROTATIONS_GIVEN_STRING_1": "static void printRotatedString ( String str ) {\n  int n = str . length ( ) ;\n  StringBuffer sb = new StringBuffer ( str ) ;\n  sb . append ( str ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j != n ;\n    j ++ ) System . out . print ( sb . charAt ( i + j ) ) ;\n    System . out . println ( ) ;\n  }\n}\n", "FITTING_SHELVES_PROBLEM": "static 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  System . out . println ( num_m + \" \" + num_n + \" \" + min_empty ) ;\n}\n", "COUNT_STRINGS_CAN_FORMED_USING_B_C_GIVEN_CONSTRAINTS_1": "static int countStr ( int n ) {\n  return 1 + ( n * 2 ) + ( n * ( ( n * n ) - 1 ) / 2 ) ;\n}\n", "DIVISIBILITY_BY_12_FOR_A_LARGE_NUMBER": "static boolean isDvisibleBy12 ( String num ) {\n  if ( num . length ( ) >= 3 ) {\n    int d1 = ( int ) num . charAt ( num . length ( ) - 1 ) ;\n    if ( d1 % 2 != 0 ) return false ;\n    int d2 = ( int ) num . charAt ( num . length ( ) - 2 ) ;\n    int sum = 0 ;\n    for ( int i = 0 ;\n    i < num . length ( ) ;\n    i ++ ) sum += num . charAt ( i ) ;\n    return ( sum % 3 == 0 && ( d2 * 10 + d1 ) % 4 == 0 ) ;\n  }\n  else {\n    int number = Integer . parseInt ( num ) ;\n    return ( number % 12 == 0 ) ;\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_36_CUT_A_ROPE_TO_MAXIMIZE_PRODUCT_1": "static 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": "static void maxProduct ( int arr [ ] , int n ) {\n  if ( n < 2 ) {\n    System . out . println ( \"No pairs exists\" ) ;\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 ) {\n    a = arr [ i ] ;\n    b = arr [ j ] ;\n  }\n  System . out . println ( \"Max product pair is {\n\" + a + \", \" + b + \"}\" ) ;\n  }\n  ", "SUM_MATRIX_ELEMENT_ABSOLUTE_DIFFERENCE_ROW_COLUMN_NUMBERS_2": "static 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": "public static void antiSpiralTraversal ( int m , int n , int a [ ] [ ] ) {\n  int i , k = 0 , l = 0 ;\n  Stack < Integer > stk = new Stack < Integer > ( ) ;\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    System . out . print ( stk . peek ( ) + \" \" ) ;\n    stk . pop ( ) ;\n  }\n}\n", "DICE_THROW_PROBLEM_1": "public static long findWays ( int f , int d , int s ) {\n  long mem [ ] [ ] = new long [ d + 1 ] [ s + 1 ] ;\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": "static int power ( int x , 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": "static String findSubString ( String str ) {\n  int n = str . length ( ) ;\n  int dist_count = 0 ;\n  boolean [ ] visited = new boolean [ MAX_CHARS ] ;\n  Arrays . fill ( visited , false ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( visited [ str . charAt ( i ) ] == false ) {\n      visited [ str . charAt ( i ) ] = true ;\n      dist_count ++ ;\n    }\n  }\n  int start = 0 , start_index = - 1 ;\n  int min_len = Integer . MAX_VALUE ;\n  int count = 0 ;\n  int [ ] curr_count = new int [ MAX_CHARS ] ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) {\n    curr_count [ str . charAt ( j ) ] ++ ;\n    if ( curr_count [ str . charAt ( j ) ] == 1 ) count ++ ;\n    if ( count == dist_count ) {\n      while ( curr_count [ str . charAt ( start ) ] > 1 ) {\n        if ( curr_count [ str . charAt ( start ) ] > 1 ) curr_count [ str . charAt ( 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 . substring ( start_index , start_index + min_len ) ;\n}\n", "CLUSTERINGPARTITIONING_AN_ARRAY_SUCH_THAT_SUM_OF_SQUARE_DIFFERENCES_IS_MINIMUM": "static 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 = Math . 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": "static void minMaxLengthWords ( String input ) {\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 . charAt ( ei ) != ' ' ) {\n      ei ++ ;\n    }\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 . substring ( min_start_index , min_start_index + min_length ) ;\n  maxWord = input . substring ( max_start_index , max_length ) ;\n}\n", "CHECK_VALID_SEQUENCE_DIVISIBLE_M_1": "static int isPossible ( int n , int index , int modulo , int M , int arr [ ] , int dp [ ] [ ] ) {\n  modulo = ( ( modulo % M ) + M ) % M ;\n  if ( index == n ) {\n    if ( modulo == 0 ) {\n      return 1 ;\n    }\n    return 0 ;\n  }\n  if ( dp [ index ] [ modulo ] != - 1 ) {\n    return dp [ index ] [ modulo ] ;\n  }\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  int res = placeAdd ;\n  dp [ index ] [ modulo ] = res ;\n  return res ;\n}\n", "MINIMUM_OPERATION_MAKE_ELEMENTS_EQUAL_ARRAY": "public static int minOperation ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > hash = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( hash . containsKey ( arr [ i ] ) ) hash . put ( arr [ i ] , hash . get ( arr [ i ] ) + 1 ) ;\n  else hash . put ( arr [ i ] , 1 ) ;\n  int max_count = 0 ;\n  Set < Integer > s = hash . keySet ( ) ;\n  for ( int i : s ) if ( max_count < hash . get ( i ) ) max_count = hash . get ( i ) ;\n  return ( n - max_count ) ;\n}\n", "HYPERCUBE_GRAPH": "static int power ( int n ) {\n  if ( n == 1 ) return 2 ;\n  return 2 * power ( n - 1 ) ;\n}\n", "PROGRAM_FIND_CORRELATION_COEFFICIENT": "static 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 ) / ( float ) ( Math . 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": "static int countPS ( String str ) {\n  int N = str . length ( ) ;\n  int [ ] [ ] cps = new int [ N + 1 ] [ N + 1 ] ;\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 ( k < N ) {\n        if ( str . charAt ( i ) == str . charAt ( 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  }\n  return cps [ 0 ] [ N - 1 ] ;\n}\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N_1": "static int nextPowerOf2 ( int n ) {\n  int p = 1 ;\n  if ( n > 0 && ( n & ( n - 1 ) ) == 0 ) return n ;\n  while ( p < n ) p <<= 1 ;\n  return p ;\n}\n", "FIND_LAST_DIGIT_FACTORIAL_DIVIDES_FACTORIAL_B": "static int computeLastDigit ( long A , long B ) {\n  int variable = 1 ;\n  if ( A == B ) return 1 ;\n  else if ( ( B - A ) >= 5 ) return 0 ;\n  else {\n    for ( long i = A + 1 ;\n    i <= B ;\n    i ++ ) variable = ( int ) ( variable * ( i % 10 ) ) % 10 ;\n    return variable % 10 ;\n  }\n}\n", "NUMBER_SUBSTRINGS_DIVISIBLE_4_STRING_INTEGERS": "static int countDivisbleby4 ( String s ) {\n  int n = s . length ( ) ;\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) if ( s . charAt ( i ) == '4' || s . charAt ( i ) == '8' || s . charAt ( i ) == '0' ) count ++ ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  ++ i ) {\n    int h = ( s . charAt ( i ) - '0' ) * 10 + ( s . charAt ( i + 1 ) - '0' ) ;\n    if ( h % 4 == 0 ) count = count + i + 1 ;\n  }\n  return count ;\n}\n", "DECODE_MEDIAN_STRING_ORIGINAL_STRING": "static String decodeMedianString ( String s ) {\n  int l = s . length ( ) ;\n  String s1 = \"\" ;\n  boolean isEven = ( l % 2 == 0 ) ? true : false ;\n  for ( int i = 0 ;\n  i < l ;\n  i += 2 ) {\n    if ( isEven ) {\n      s1 = s . charAt ( i ) + s1 ;\n      s1 += s . charAt ( i + 1 ) ;\n    }\n    else {\n      if ( l - i > 1 ) {\n        s1 += s . charAt ( i ) ;\n        s1 = s . charAt ( i + 1 ) + s1 ;\n      }\n      else {\n        s1 += s . charAt ( i ) ;\n      }\n    }\n  }\n  return s1 ;\n}\n", "NUMBER_WHICH_HAS_THE_MAXIMUM_NUMBER_OF_DISTINCT_PRIME_FACTORS_IN_RANGE_M_TO_N": "static int maximumNumberDistinctPrimeRange ( int m , int n ) {\n  long factorCount [ ] = new long [ n + 1 ] ;\n  boolean prime [ ] = new boolean [ 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 = ( int ) factorCount [ m ] ;\n  int num = m ;\n  for ( int i = m ;\n  i <= n ;\n  i ++ ) {\n    if ( factorCount [ i ] > max ) {\n      max = ( int ) factorCount [ i ] ;\n      num = i ;\n    }\n  }\n  return num ;\n}\n", "NUMBER_EQUAL_PAIRS_STRING": "static int countPairs ( String s ) {\n  int cnt [ ] = new int [ MAX ] ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) cnt [ s . charAt ( 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": "static int countPaths ( int maze [ ] [ ] ) {\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": "public static 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 ( true ) {\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": "static int maxSum ( int arr [ ] , int N , int k ) {\n  int MS [ ] = new int [ 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 ] = Math . max ( arr [ i ] , MS [ i + 1 ] ) ;\n    else MS [ i ] = Math . max ( arr [ i ] + MS [ i + k + 1 ] , MS [ i + 1 ] ) ;\n  }\n  return MS [ 0 ] ;\n}\n", "CHECK_WHETHER_GIVEN_NUMBER_EVEN_ODD_1": "public static boolean isEven ( int n ) {\n  if ( ( n & 1 ) == 0 ) return true ;\n  else return false ;\n}\n", "SORT_ARRAY_TWO_HALVES_SORTED": "static void mergeTwoHalf ( int [ ] A , int n ) {\n  Arrays . sort ( A ) ;\n}\n", "PYTHAGOREAN_QUADRUPLE": "static Boolean 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": "static void printMaxOfMin ( int n ) {\n  for ( int k = 1 ;\n  k <= n ;\n  k ++ ) {\n    int maxOfMin = Integer . MIN_VALUE ;\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    System . out . print ( maxOfMin + \" \" ) ;\n  }\n}\n", "COUNT_SUM_OF_DIGITS_IN_NUMBERS_FROM_1_TO_N": "static int sumOfDigitsFrom1ToN ( int n ) {\n  if ( n < 10 ) return ( n * ( n + 1 ) / 2 ) ;\n  int d = ( int ) ( Math . log10 ( n ) ) ;\n  int a [ ] = new int [ d + 1 ] ;\n  a [ 0 ] = 0 ;\n  a [ 1 ] = 45 ;\n  for ( int i = 2 ;\n  i <= d ;\n  i ++ ) a [ i ] = a [ i - 1 ] * 10 + 45 * ( int ) ( Math . ceil ( Math . pow ( 10 , i - 1 ) ) ) ;\n  int p = ( int ) ( Math . ceil ( Math . 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": "static int breakSum ( int n ) {\n  int dp [ ] = new int [ n + 1 ] ;\n  dp [ 0 ] = 0 ;\n  dp [ 1 ] = 1 ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) dp [ i ] = Math . max ( dp [ i / 2 ] + dp [ i / 3 ] + dp [ i / 4 ] , i ) ;\n  return dp [ n ] ;\n}\n", "FIND_REPEATING_ELEMENT_SORTED_ARRAY_SIZE_N": "static 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": "static int countSubarrWithEqualZeroAndOne ( int [ ] arr , int n ) {\n  Map < Integer , Integer > myMap = new HashMap < > ( ) ;\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 ( myMap . containsKey ( sum ) ) count += myMap . get ( sum ) ;\n    if ( ! myMap . containsKey ( sum ) ) myMap . put ( sum , 1 ) ;\n    else myMap . put ( sum , myMap . get ( sum ) + 1 ) ;\n  }\n  return count ;\n}\n", "UNION_AND_INTERSECTION_OF_TWO_SORTED_ARRAYS_2_1": "static void 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      System . out . print ( arr2 [ j ++ ] + \" \" ) ;\n      i ++ ;\n    }\n  }\n}\n", "COUNT_ALL_INCREASING_SUBSEQUENCES": "static int countSub ( int arr [ ] , int n ) {\n  int count [ ] = new int [ 10 ] ;\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": "static void digitsNum ( int N ) {\n  if ( N == 0 ) System . out . println ( \"0\" ) ;\n  if ( N % 9 != 0 ) System . out . print ( ( N % 9 ) ) ;\n  for ( int i = 1 ;\n  i <= ( N / 9 ) ;\n  ++ i ) System . out . print ( \"9\" ) ;\n  for ( int i = 1 ;\n  i <= N ;\n  ++ i ) System . out . print ( \"0\" ) ;\n  System . out . print ( \"\" ) ;\n}\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES_1": "static int getOddOccurrence ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > hmap = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( hmap . containsKey ( arr [ i ] ) ) {\n      int val = hmap . get ( arr [ i ] ) ;\n      hmap . put ( arr [ i ] , val + 1 ) ;\n    }\n    else hmap . put ( arr [ i ] , 1 ) ;\n  }\n  for ( Integer a : hmap . keySet ( ) ) {\n    if ( hmap . get ( a ) % 2 != 0 ) return a ;\n  }\n  return - 1 ;\n}\n", "CHECK_IF_X_CAN_GIVE_CHANGE_TO_EVERY_PERSON_IN_THE_QUEUE": "static 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": "static void 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  boolean dp [ ] [ ] = new boolean [ MAX + 1 ] [ MAX * MAX + 1 ] ;\n  dp [ 0 ] [ 0 ] = true ;\n  for ( int i = 0 ;\n  i < ( n + m ) ;\n  i ++ ) {\n    for ( int k = Math . 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 ] ] = true ;\n      }\n    }\n  }\n  double max_value = - 1 * 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 = Math . max ( max_value , temp * ( sum - temp ) ) ;\n      min_value = Math . min ( min_value , temp * ( sum - temp ) ) ;\n    }\n  }\n  System . out . print ( \"Maximum Value: \" + ( int ) max_value + \"\\n\" + \"Minimum Value: \" + ( int ) min_value + \"\\n\" ) ;\n}\n", "MULTIPLY_AN_INTEGER_WITH_3_5": "static int multiplyWith3Point5 ( int x ) {\n  return ( x << 1 ) + x + ( x >> 1 ) ;\n}\n", "MINIMUM_CELLS_REQUIRED_REACH_DESTINATION_JUMPS_EQUAL_CELL_VALUES": "static int minCells ( int mat [ ] [ ] , int m , int n ) {\n  int dp [ ] [ ] = new int [ m ] [ n ] ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) for ( int j = 0 ;\n  j < n ;\n  j ++ ) dp [ i ] [ j ] = Integer . MAX_VALUE ;\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 ] != Integer . MAX_VALUE && ( 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 ] != Integer . MAX_VALUE && ( 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 ] != Integer . MAX_VALUE ) return dp [ m - 1 ] [ n - 1 ] ;\n  return - 1 ;\n}\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY": "static 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": "static int findSum ( String str ) {\n  String temp = \"\" ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    char ch = str . charAt ( i ) ;\n    if ( Character . isDigit ( ch ) ) temp += ch ;\n    else {\n      sum += Integer . parseInt ( temp ) ;\n      temp = \"0\" ;\n    }\n  }\n  return sum + Integer . parseInt ( temp ) ;\n}\n", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED": "static boolean checkReverse ( int arr [ ] , int n ) {\n  int temp [ ] = new int [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    temp [ i ] = arr [ i ] ;\n  }\n  Arrays . sort ( temp ) ;\n  int front ;\n  for ( front = 0 ;\n  front < n ;\n  front ++ ) {\n    if ( temp [ front ] != arr [ front ] ) {\n      break ;\n    }\n  }\n  int back ;\n  for ( back = n - 1 ;\n  back >= 0 ;\n  back -- ) {\n    if ( temp [ back ] != arr [ back ] ) {\n      break ;\n    }\n  }\n  if ( front >= back ) {\n    return true ;\n  }\n  do {\n    front ++ ;\n    if ( arr [ front - 1 ] < arr [ front ] ) {\n      return false ;\n    }\n  }\n  while ( front != back ) ;\n  return true ;\n}\n", "GENERATE_PYTHAGORAS_TRIPLET_SINGLE_INTEGER": "static void evaluate ( int n ) {\n  if ( n == 1 || n == 2 ) System . out . println ( \"No Pythagoras \" + \"Triplet exists\" ) ;\n  else if ( n % 2 == 0 ) {\n    int var = 1 * n * n / 4 ;\n    System . out . print ( \"Pythagoras Triplets \" + \"exist i.e. \" ) ;\n    System . out . print ( n + \" \" ) ;\n    System . out . print ( var - 1 + \" \" ) ;\n    System . out . println ( var + 1 + \" \" ) ;\n  }\n  else if ( n % 2 != 0 ) {\n    int var = 1 * n * n + 1 ;\n    System . out . print ( \"Pythagoras Triplets \" + \"exist i.e. \" ) ;\n    System . out . print ( n + \" \" ) ;\n    System . out . print ( var / 2 - 1 + \" \" ) ;\n    System . out . println ( var / 2 + \" \" ) ;\n  }\n}\n", "PETERSON_GRAPH": "static boolean findthepath ( char [ ] S , int v ) {\n  result [ 0 ] = ( char ) ( v + '0' ) ;\n  for ( int i = 1 ;\n  i < ( int ) S . length ;\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 ] = ( char ) ( v + '0' ) ;\n  }\n  return true ;\n}\n", "COUNT_NUMBER_OF_SOLUTIONS_OF_X2_1_MOD_P_IN_GIVEN_RANGE": "static int findCountOfSolutions ( int n , int p ) {\n  int ans = 0 ;\n  for ( int x = 1 ;\n  x < p ;\n  x ++ ) {\n    if ( ( x * x ) % p == 1 ) {\n      int 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": "public static int jumpSearch ( int [ ] arr , int x ) {\n  int n = arr . length ;\n  int step = ( int ) Math . floor ( Math . sqrt ( n ) ) ;\n  int prev = 0 ;\n  while ( arr [ Math . min ( step , n ) - 1 ] < x ) {\n    prev = step ;\n    step += ( int ) Math . floor ( Math . sqrt ( n ) ) ;\n    if ( prev >= n ) return - 1 ;\n  }\n  while ( arr [ prev ] < x ) {\n    prev ++ ;\n    if ( prev == Math . min ( step , n ) ) return - 1 ;\n  }\n  if ( arr [ prev ] == x ) return prev ;\n  return - 1 ;\n}\n", "FORM_MINIMUM_NUMBER_FROM_GIVEN_SEQUENCE": "static 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 . charAt ( i ) ) {\n      case 'I' : j = i + 1 ;\n      while ( j < arr . length ( ) && arr . charAt ( j ) == 'D' ) {\n        noOfNextD ++ ;\n        j ++ ;\n      }\n      if ( i == 0 ) {\n        curr_max = noOfNextD + 2 ;\n        System . out . print ( \" \" + ++ last_entry ) ;\n        System . out . print ( \" \" + curr_max ) ;\n        last_entry = curr_max ;\n      }\n      else {\n        curr_max = curr_max + noOfNextD + 1 ;\n        last_entry = curr_max ;\n        System . out . print ( \" \" + last_entry ) ;\n      }\n      for ( int k = 0 ;\n      k < noOfNextD ;\n      k ++ ) {\n        System . out . print ( \" \" + -- last_entry ) ;\n        i ++ ;\n      }\n      break ;\n      case 'D' : if ( i == 0 ) {\n        j = i + 1 ;\n        while ( j < arr . length ( ) && arr . charAt ( j ) == 'D' ) {\n          noOfNextD ++ ;\n          j ++ ;\n        }\n        curr_max = noOfNextD + 2 ;\n        System . out . print ( \" \" + curr_max + \" \" + ( curr_max - 1 ) ) ;\n        last_entry = curr_max - 1 ;\n      }\n      else {\n        System . out . print ( \" \" + ( last_entry - 1 ) ) ;\n        last_entry -- ;\n      }\n      break ;\n    }\n  }\n  System . out . println ( ) ;\n}\n", "GIVEN_LARGE_NUMBER_CHECK_SUBSEQUENCE_DIGITS_DIVISIBLE_8": "static boolean isSubSeqDivisible ( String str ) {\n  int i , j , k , l = str . length ( ) ;\n  int arr [ ] = new int [ l ] ;\n  for ( i = 0 ;\n  i < l ;\n  i ++ ) {\n    for ( j = i ;\n    j < l ;\n    j ++ ) {\n      for ( 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": "static void fib ( int n ) {\n  int a = 0 , b = 1 , c ;\n  if ( n >= 0 ) System . out . print ( a + \" \" ) ;\n  if ( n >= 1 ) System . out . print ( b + \" \" ) ;\n  for ( int i = 2 ;\n  i <= n ;\n  i ++ ) {\n    c = a + b ;\n    System . out . print ( c + \" \" ) ;\n    a = b ;\n    b = c ;\n  }\n}\n", "INTERCHANGE_ELEMENTS_OF_FIRST_AND_LAST_ROWS_IN_MATRIX": "static void interchangeFirstLast ( int m [ ] [ ] ) {\n  int rows = m . length ;\n  for ( int i = 0 ;\n  i < m [ 0 ] . length ;\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": "static int findSum ( int n ) {\n  int [ ] [ ] arr = new int [ n ] [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = 0 ;\n  j < n ;\n  j ++ ) arr [ i ] [ j ] = Math . 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": "static int findMaximum ( int arr [ ] , int low , int high ) {\n  int max = arr [ low ] ;\n  int i ;\n  for ( i = low ;\n  i <= high ;\n  i ++ ) {\n    if ( arr [ i ] > max ) max = arr [ i ] ;\n  }\n  return max ;\n}\n", "PROGRAM_CHECK_DIAGONAL_MATRIX_SCALAR_MATRIX_1": "static boolean isScalarMatrix ( int mat [ ] [ ] ) {\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": "static void stoogesort ( int arr [ ] , int l , int h ) {\n  if ( l >= h ) return ;\n  if ( arr [ l ] > arr [ h ] ) {\n    int t = arr [ l ] ;\n    arr [ l ] = arr [ h ] ;\n    arr [ h ] = t ;\n  }\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": "static int eggDrop ( int n , int k ) {\n  if ( k == 1 || k == 0 ) return k ;\n  if ( n == 1 ) return k ;\n  int min = Integer . MAX_VALUE ;\n  int x , res ;\n  for ( x = 1 ;\n  x <= k ;\n  x ++ ) {\n    res = Math . 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": "static int numberofways ( int n , int m ) {\n  int dp [ ] [ ] = new int [ n + 2 ] [ n + 2 ] ;\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 [ ] ) {\n  int n = arr . length ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) for ( int j = 0 ;\n  j < n - i - 1 ;\n  j ++ ) if ( arr [ j ] > arr [ j + 1 ] ) {\n    int temp = arr [ j ] ;\n    arr [ j ] = arr [ j + 1 ] ;\n    arr [ j + 1 ] = temp ;\n  }\n}\n", "GENERATE_ROTATIONS_GIVEN_STRING": "static void printRotatedString ( String str ) {\n  int len = str . length ( ) ;\n  StringBuffer sb ;\n  for ( int i = 0 ;\n  i < len ;\n  i ++ ) {\n    sb = new StringBuffer ( ) ;\n    int j = i ;\n    int k = 0 ;\n    for ( int k2 = j ;\n    k2 < str . length ( ) ;\n    k2 ++ ) {\n      sb . insert ( k , str . charAt ( j ) ) ;\n      k ++ ;\n      j ++ ;\n    }\n    j = 0 ;\n    while ( j < i ) {\n      sb . insert ( k , str . charAt ( j ) ) ;\n      j ++ ;\n      k ++ ;\n    }\n    System . out . println ( sb ) ;\n  }\n}\n", "MID_POINT_LINE_GENERATION_ALGORITHM": "static 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  System . out . print ( 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    System . out . print ( x + \",\" + y + \"\\n\" ) ;\n  }\n}\n", "FINDING_VERTEX_FOCUS_DIRECTRIX_PARABOLA": "static void parabola ( float a , float b , float c ) {\n  System . out . println ( \"Vertex: (\" + ( - b / ( 2 * a ) ) + \", \" + ( ( ( 4 * a * c ) - ( b * b ) ) / ( 4 * a ) ) + \")\" ) ;\n  System . out . println ( \"Focus: (\" + ( - b / ( 2 * a ) ) + \", \" + ( ( ( 4 * a * c ) - ( b * b ) + 1 ) / ( 4 * a ) ) + \")\" ) ;\n  System . out . println ( \"Directrix:\" + \" y=\" + ( int ) ( c - ( ( b * b ) + 1 ) * 4 * a ) ) ;\n}\n", "TRIANGULAR_NUMBERS": "static boolean 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": "static int findMaximumPieces ( int n ) {\n  return 1 + n * ( n + 1 ) / 2 ;\n}\n", "MINIMUM_TIME_WRITE_CHARACTERS_USING_INSERT_DELETE_COPY_OPERATION": "static 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 [ ] = new int [ N + 1 ] ;\n  for ( int i = 1 ;\n  i <= N ;\n  i ++ ) {\n    if ( i % 2 == 0 ) dp [ i ] = Math . min ( dp [ i - 1 ] + insert , dp [ i / 2 ] + copy ) ;\n    else dp [ i ] = Math . min ( dp [ i - 1 ] + insert , dp [ ( i + 1 ) / 2 ] + copy + remove ) ;\n  }\n  return dp [ N ] ;\n}\n", "SEARCHING_ARRAY_ADJACENT_DIFFER_K": "static 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 + Math . max ( 1 , Math . abs ( arr [ i ] - x ) / k ) ;\n  }\n  System . out . println ( \"number is \" + \"not present!\" ) ;\n  return - 1 ;\n}\n", "FIND_MAXIMUM_PRODUCT_OF_A_TRIPLET_IN_ARRAY": "static int maxProduct ( int [ ] arr , int n ) {\n  if ( n < 3 ) return - 1 ;\n  int max_product = Integer . MIN_VALUE ;\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 = Math . max ( max_product , arr [ i ] * arr [ j ] * arr [ k ] ) ;\n  return max_product ;\n}\n", "LONGEST_PALINDROME_SUBSEQUENCE_SPACE": "static int lps ( String s ) {\n  int n = s . length ( ) ;\n  int a [ ] = new int [ 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 . charAt ( i ) == s . charAt ( 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 ] = Math . max ( a [ j - 1 ] , a [ j ] ) ;\n      }\n    }\n  }\n  return a [ n - 1 ] ;\n}\n", "CHECK_HALF_STRING_CHARACTER_FREQUENCY_CHARACTER_1": "static boolean checkCorrectOrNot ( String s ) {\n  int [ ] count = new int [ MAX_CHAR ] ;\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 . charAt ( i ) - 'a' ] ++ ;\n    count [ s . charAt ( 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": "static long exponentiation ( long base , long exp ) {\n  if ( exp == 0 ) return 1 ;\n  if ( exp == 1 ) return base % N ;\n  long 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": "public static int minRemove ( int a [ ] , int b [ ] , int n , int m ) {\n  HashMap < Integer , Integer > countA = new HashMap < Integer , Integer > ( ) ;\n  HashMap < Integer , Integer > countB = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( countA . containsKey ( a [ i ] ) ) countA . put ( a [ i ] , countA . get ( a [ i ] ) + 1 ) ;\n    else countA . put ( a [ i ] , 1 ) ;\n  }\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) {\n    if ( countB . containsKey ( b [ i ] ) ) countB . put ( b [ i ] , countB . get ( b [ i ] ) + 1 ) ;\n    else countB . put ( b [ i ] , 1 ) ;\n  }\n  int res = 0 ;\n  Set < Integer > s = countA . keySet ( ) ;\n  for ( int x : s ) if ( countB . containsKey ( x ) ) res += Math . min ( countB . get ( x ) , countA . get ( x ) ) ;\n  return res ;\n}\n", "FIND_A_FIXED_POINT_IN_A_GIVEN_ARRAY": "static 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": "static int addOne ( int x ) {\n  int m = 1 ;\n  while ( ( int ) ( x & m ) >= 1 ) {\n    x = x ^ m ;\n    m <<= 1 ;\n  }\n  x = x ^ m ;\n  return x ;\n}\n", "HEIGHT_COMPLETE_BINARY_TREE_HEAP_N_NODES": "static int height ( int N ) {\n  return ( int ) Math . ceil ( Math . log ( N + 1 ) / Math . log ( 2 ) ) - 1 ;\n}\n", "MINIMUM_NUMBER_OF_JUMPS_TO_REACH_END_OF_A_GIVEN_ARRAY": "static int minJumps ( int arr [ ] , int l , int h ) {\n  if ( h == l ) return 0 ;\n  if ( arr [ l ] == 0 ) return Integer . MAX_VALUE ;\n  int min = Integer . MAX_VALUE ;\n  for ( int i = l + 1 ;\n  i <= h && i <= l + arr [ l ] ;\n  i ++ ) {\n    int jumps = minJumps ( arr , i , h ) ;\n    if ( jumps != Integer . MAX_VALUE && jumps + 1 < min ) min = jumps + 1 ;\n  }\n  return min ;\n}\n", "PROGRAM_FOR_NTH_FIBONACCI_NUMBER_2": "public static int fib ( int n ) {\n  if ( n == 0 ) return 0 ;\n  if ( n == 1 || n == 2 ) return ( f [ n ] = 1 ) ;\n  if ( f [ n ] != 0 ) return f [ n ] ;\n  int k = ( n & 1 ) == 1 ? ( n + 1 ) / 2 : n / 2 ;\n  f [ n ] = ( n & 1 ) == 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": "static String decode ( String str ) {\n  Stack < Integer > integerstack = new Stack < > ( ) ;\n  Stack < Character > stringstack = new Stack < > ( ) ;\n  String temp = \"\" , result = \"\" ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    int count = 0 ;\n    if ( Character . isDigit ( str . charAt ( i ) ) ) {\n      while ( Character . isDigit ( str . charAt ( i ) ) ) {\n        count = count * 10 + str . charAt ( i ) - '0' ;\n        i ++ ;\n      }\n      i -- ;\n      integerstack . push ( count ) ;\n    }\n    else if ( str . charAt ( i ) == ']' ) {\n      temp = \"\" ;\n      count = 0 ;\n      if ( ! integerstack . isEmpty ( ) ) {\n        count = integerstack . peek ( ) ;\n        integerstack . pop ( ) ;\n      }\n      while ( ! stringstack . isEmpty ( ) && stringstack . peek ( ) != '[' ) {\n        temp = stringstack . peek ( ) + temp ;\n        stringstack . pop ( ) ;\n      }\n      if ( ! stringstack . empty ( ) && stringstack . peek ( ) == '[' ) 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 . charAt ( j ) ) ;\n      result = \"\" ;\n    }\n    else if ( str . charAt ( i ) == '[' ) {\n      if ( Character . isDigit ( str . charAt ( i - 1 ) ) ) stringstack . push ( str . charAt ( i ) ) ;\n      else {\n        stringstack . push ( str . charAt ( i ) ) ;\n        integerstack . push ( 1 ) ;\n      }\n    }\n    else stringstack . push ( str . charAt ( i ) ) ;\n  }\n  while ( ! stringstack . isEmpty ( ) ) {\n    result = stringstack . peek ( ) + result ;\n    stringstack . pop ( ) ;\n  }\n  return result ;\n}\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP": "static boolean isHeap ( int arr [ ] , int i , int n ) {\n  if ( i > ( n - 2 ) / 2 ) {\n    return true ;\n  }\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 ) ) {\n    return true ;\n  }\n  return false ;\n}\n", "HOW_TO_CHECK_IF_A_GIVEN_ARRAY_REPRESENTS_A_BINARY_HEAP_1": "static boolean 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 ] ) {\n      return false ;\n    }\n    if ( 2 * i + 2 < n && arr [ 2 * i + 2 ] > arr [ i ] ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "CALCULATE_ANGLE_HOUR_HAND_MINUTE_HAND": "static int calcAngle ( double h , double m ) {\n  if ( h < 0 || m < 0 || h > 12 || m > 60 ) System . out . println ( \"Wrong input\" ) ;\n  if ( h == 12 ) h = 0 ;\n  if ( m == 60 ) m = 0 ;\n  int hour_angle = ( int ) ( 0.5 * ( h * 60 + m ) ) ;\n  int minute_angle = ( int ) ( 6 * m ) ;\n  int angle = Math . abs ( hour_angle - minute_angle ) ;\n  angle = Math . min ( 360 - angle , angle ) ;\n  return angle ;\n}\n", "CONVERTING_DECIMAL_NUMBER_LYING_BETWEEN_1_TO_3999_TO_ROMAN_NUMERALS": "static void printRoman ( int number ) {\n  char c [ ] = new char [ 10001 ] ;\n  int i = 0 ;\n  if ( number <= 0 ) {\n    System . out . printf ( \"Invalid number\" ) ;\n    return ;\n  }\n  while ( number != 0 ) {\n    if ( number >= 1000 ) {\n      i = digit ( 'M' , number / 1000 , i , c ) ;\n      number = number % 1000 ;\n    }\n    else if ( number >= 500 ) {\n      if ( number < 900 ) {\n        i = digit ( 'D' , number / 500 , i , c ) ;\n        number = number % 500 ;\n      }\n      else {\n        i = sub_digit ( 'C' , 'M' , i , c ) ;\n        number = number % 100 ;\n      }\n    }\n    else if ( number >= 100 ) {\n      if ( number < 400 ) {\n        i = digit ( 'C' , number / 100 , i , c ) ;\n        number = number % 100 ;\n      }\n      else {\n        i = sub_digit ( 'C' , 'D' , i , c ) ;\n        number = number % 100 ;\n      }\n    }\n    else if ( number >= 50 ) {\n      if ( number < 90 ) {\n        i = digit ( 'L' , number / 50 , i , c ) ;\n        number = number % 50 ;\n      }\n      else {\n        i = sub_digit ( 'X' , 'C' , i , c ) ;\n        number = number % 10 ;\n      }\n    }\n    else if ( number >= 10 ) {\n      if ( number < 40 ) {\n        i = digit ( 'X' , number / 10 , i , c ) ;\n        number = number % 10 ;\n      }\n      else {\n        i = sub_digit ( 'X' , 'L' , i , c ) ;\n        number = number % 10 ;\n      }\n    }\n    else if ( number >= 5 ) {\n      if ( number < 9 ) {\n        i = digit ( 'V' , number / 5 , i , c ) ;\n        number = number % 5 ;\n      }\n      else {\n        i = sub_digit ( 'I' , 'X' , i , c ) ;\n        number = 0 ;\n      }\n    }\n    else if ( number >= 1 ) {\n      if ( number < 4 ) {\n        i = digit ( 'I' , number , i , c ) ;\n        number = 0 ;\n      }\n      else {\n        i = sub_digit ( 'I' , 'V' , i , c ) ;\n        number = 0 ;\n      }\n    }\n  }\n  System . out . printf ( \"Roman numeral is: \" ) ;\n  for ( int j = 0 ;\n  j < i ;\n  j ++ ) {\n    System . out . printf ( \"%c\" , c [ j ] ) ;\n  }\n}\n", "SORTING_USING_TRIVIAL_HASH_FUNCTION": "static void sortUsingHash ( int a [ ] , int n ) {\n  int max = Arrays . stream ( a ) . max ( ) . getAsInt ( ) ;\n  int hash [ ] = new int [ max + 1 ] ;\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 ] != 0 ) {\n      for ( int j = 0 ;\n      j < hash [ i ] ;\n      j ++ ) {\n        System . out . print ( i + \" \" ) ;\n      }\n    }\n  }\n}\n", "SUM_PAIRWISE_PRODUCTS_2": "static int findSum ( int n ) {\n  return n * ( n + 1 ) * ( n + 2 ) * ( 3 * n + 1 ) / 24 ;\n}\n", "ENTRINGER_NUMBER": "static 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": "static int minSum ( int a [ ] , int n ) {\n  Arrays . sort ( a ) ;\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": "static void subarrayDivisibleByK ( int [ ] arr , int n , int k ) {\n  int [ ] mp = new int [ 1000 ] ;\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  System . out . print ( \"The maximum size is \" + ( maxe - maxs + 1 ) + \" and the subarray is as follows\\n\" ) ;\n  for ( int i = maxs ;\n  i <= maxe ;\n  i ++ ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "MAXIMUM_PROFIT_BY_BUYING_AND_SELLING_A_SHARE_AT_MOST_K_TIMES": "static int maxProfit ( int [ ] price , int n , int k ) {\n  int [ ] [ ] profit = new int [ 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 = 0 ;\n      for ( int m = 0 ;\n      m < j ;\n      m ++ ) max_so_far = Math . max ( max_so_far , price [ j ] - price [ m ] + profit [ i - 1 ] [ m ] ) ;\n      profit [ i ] [ j ] = Math . 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": "static int minValue ( int A [ ] , int B [ ] , int n ) {\n  Arrays . sort ( A ) ;\n  Arrays . sort ( B ) ;\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": "public static void maxelement ( int no_of_rows , int [ ] [ ] arr ) {\n  int i = 0 ;\n  int max = 0 ;\n  int [ ] result = new int [ no_of_rows ] ;\n  while ( i < no_of_rows ) {\n    for ( int j = 0 ;\n    j < arr [ i ] . length ;\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 ) ;\n}\n", "ROUND_OFF_NUMBER_GIVEN_NUMBER_SIGNIFICANT_DIGITS": "static 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 = ( int ) ( 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  System . out . println ( \"The number after rounding-off is \" + j ) ;\n}\n", "CHECK_WHETHER_POINT_EXISTS_CIRCLE_SECTOR_NOT": "static void checkPoint ( int radius , int x , int y , float percent , float startAngle ) {\n  float endAngle = 360 / percent + startAngle ;\n  double polarradius = Math . sqrt ( x * x + y * y ) ;\n  double Angle = Math . atan ( y / x ) ;\n  if ( Angle >= startAngle && Angle <= endAngle && polarradius < radius ) System . out . print ( \"Point\" + \"(\" + x + \",\" + y + \")\" + \" exist in the circle sector\\n\" ) ;\n  else System . out . print ( \"Point\" + \"(\" + x + \",\" + y + \")\" + \" exist in the circle sector\\n\" ) ;\n}\n", "NUMBER_IS_DIVISIBLE_BY_29_OR_NOT": "static boolean isDivisible ( long n ) {\n  while ( n / 100 > 0 ) {\n    int last_digit = ( int ) 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": "static void printDistinct ( String str ) {\n  int [ ] count = new int [ NO_OF_CHARS ] ;\n  int i ;\n  for ( i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) if ( str . charAt ( i ) != ' ' ) count [ ( int ) str . charAt ( i ) ] ++ ;\n  int n = i ;\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) if ( count [ ( int ) str . charAt ( i ) ] == 1 ) System . out . print ( str . charAt ( i ) ) ;\n}\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE": "public static String recursiveReverse ( char [ ] str ) {\n  Stack < Character > st = new Stack < > ( ) ;\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 . peek ( ) ;\n    st . pop ( ) ;\n  }\n  return String . valueOf ( str ) ;\n}\n", "PAINTING_FENCE_ALGORITHM": "static 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 = ( int ) 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": "static 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 -= Math . min ( b_index , c_index ) ;\n    }\n    else if ( str [ i ] == 'b' ) {\n      b_index = i + 1 ;\n      ans -= Math . min ( a_index , c_index ) ;\n    }\n    else {\n      c_index = i + 1 ;\n      ans -= Math . min ( a_index , b_index ) ;\n    }\n  }\n  return ans ;\n}\n", "CALCULATING_FACTORIALS_USING_STIRLING_APPROXIMATION": "public static int stirlingFactorial ( double n ) {\n  if ( n == 1 ) return 1 ;\n  double z ;\n  double e = 2.71 ;\n  z = Math . sqrt ( 2 * 3.14 * n ) * Math . pow ( ( n / e ) , n ) ;\n  return ( int ) ( z ) ;\n}\n", "LEXICOGRAPHICALLY_SMALLEST_STRING_OBTAINED_CONCATENATING_ARRAY": "static String lexsmallest ( String a [ ] , int n ) {\n  sort ( a , n ) ;\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": "public static int minMaxProduct ( int arr1 [ ] , int arr2 [ ] , int n1 , int n2 ) {\n  Arrays . sort ( arr1 ) ;\n  Arrays . sort ( arr2 ) ;\n  return arr1 [ n1 - 1 ] * arr2 [ 0 ] ;\n}\n", "FIND_IF_THERE_IS_A_SUBARRAY_WITH_0_SUM": "static Boolean subArrayExists ( int arr [ ] ) {\n  HashMap < Integer , Integer > hM = new HashMap < Integer , Integer > ( ) ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    sum += arr [ i ] ;\n    if ( arr [ i ] == 0 || sum == 0 || hM . get ( sum ) != null ) return true ;\n    hM . put ( sum , i ) ;\n  }\n  return false ;\n}\n", "MINIMUM_PRODUCT_SUBSET_ARRAY": "static int minProductSubset ( int a [ ] , int n ) {\n  if ( n == 1 ) return a [ 0 ] ;\n  int negmax = Integer . MIN_VALUE ;\n  int posmin = Integer . MAX_VALUE ;\n  int count_neg = 0 , count_zero = 0 ;\n  int product = 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      negmax = Math . max ( negmax , a [ i ] ) ;\n    }\n    if ( a [ i ] > 0 && a [ i ] < posmin ) posmin = a [ i ] ;\n    product *= a [ i ] ;\n  }\n  if ( count_zero == n || ( count_neg == 0 && count_zero > 0 ) ) return 0 ;\n  if ( count_neg == 0 ) return posmin ;\n  if ( count_neg % 2 == 0 && count_neg != 0 ) {\n    product = product / negmax ;\n  }\n  return product ;\n}\n", "NUMBER_NODES_TWO_VERTICES_ACYCLIC_GRAPH_DISJOINT_UNION_METHOD": "static int totalNodes ( Vector < Integer > adjac [ ] , int n , int x , int y ) {\n  Boolean visited [ ] = new Boolean [ n + 1 ] ;\n  Arrays . fill ( visited , false ) ;\n  int p [ ] = new int [ n ] ;\n  Queue < Integer > q = new LinkedList < > ( ) ;\n  q . add ( x ) ;\n  visited [ x ] = true ;\n  int m ;\n  while ( ! q . isEmpty ( ) ) {\n    m = q . peek ( ) ;\n    q . poll ( ) ;\n    for ( int i = 0 ;\n    i < adjac [ m ] . size ( ) ;\n    ++ i ) {\n      int h = adjac [ m ] . get ( i ) ;\n      if ( visited [ h ] != true ) {\n        visited [ h ] = true ;\n        p [ h ] = m ;\n        q . add ( 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": "static void carveCross ( String str ) {\n  int n = str . length ( ) ;\n  if ( n % 2 == 0 ) {\n    System . out . print ( \"Not possible. Please enter \" + \"odd length string.\\n\" ) ;\n  }\n  else {\n    char arr [ ] [ ] = new char [ 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 . charAt ( i ) ;\n    }\n    for ( int i = 0 ;\n    i < n ;\n    i ++ ) {\n      arr [ m ] [ i ] = str . charAt ( i ) ;\n    }\n    for ( int i = 0 ;\n    i < n ;\n    i ++ ) {\n      for ( int j = 0 ;\n      j < n ;\n      j ++ ) {\n        System . out . print ( arr [ i ] [ j ] + \" \" ) ;\n      }\n      System . out . print ( \"\\n\" ) ;\n    }\n  }\n}\n", "NEXT_GREATER_FREQUENCY_ELEMENT": "static void NFG ( int a [ ] , int n , int freq [ ] ) {\n  Stack < Integer > s = new Stack < Integer > ( ) ;\n  s . push ( 0 ) ;\n  int res [ ] = new int [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) res [ i ] = 0 ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( freq [ a [ s . peek ( ) ] ] > freq [ a [ i ] ] ) s . push ( i ) ;\n    else {\n      while ( freq [ a [ s . peek ( ) ] ] < freq [ a [ i ] ] && s . size ( ) > 0 ) {\n        res [ s . peek ( ) ] = a [ i ] ;\n        s . pop ( ) ;\n      }\n      s . push ( i ) ;\n    }\n  }\n  while ( s . size ( ) > 0 ) {\n    res [ s . peek ( ) ] = - 1 ;\n    s . pop ( ) ;\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( res [ i ] + \" \" ) ;\n  }\n}\n", "CHECK_REVERSING_SUB_ARRAY_MAKE_ARRAY_SORTED_1": "static boolean checkReverse ( int arr [ ] , int n ) {\n  if ( n == 1 ) {\n    return true ;\n  }\n  int i ;\n  for ( i = 1 ;\n  arr [ i - 1 ] < arr [ i ] && i < n ;\n  i ++ ) ;\n  if ( i == n ) {\n    return true ;\n  }\n  int j = i ++ ;\n  while ( arr [ j ] < arr [ j - 1 ] ) {\n    if ( i > 1 && arr [ j ] < arr [ i - 2 ] ) {\n      return false ;\n    }\n    j ++ ;\n  }\n  if ( j == n ) {\n    return true ;\n  }\n  int k = j ;\n  if ( arr [ k ] < arr [ i - 1 ] ) {\n    return false ;\n  }\n  while ( k > 1 && k < n ) {\n    if ( arr [ k ] < arr [ k - 1 ] ) {\n      return false ;\n    }\n    k ++ ;\n  }\n  return true ;\n}\n", "FIND_TRIPLETS_ARRAY_WHOSE_SUM_EQUAL_ZERO_2": "static void findTriplets ( int arr [ ] , int n ) {\n  boolean found = false ;\n  Arrays . sort ( arr ) ;\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        System . out . print ( x + \" \" ) ;\n        System . out . print ( arr [ l ] + \" \" ) ;\n        System . out . println ( 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 ) System . out . println ( \" No Triplet Found\" ) ;\n}\n", "FIND_ELEMENTS_ARRAY_LEAST_TWO_GREATER_ELEMENTS": "static 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 ) System . out . print ( arr [ i ] + \" \" ) ;\n  }\n}\n", "POSITIVE_ELEMENTS_EVEN_NEGATIVE_ODD_POSITIONS_1": "static void printArray ( int [ ] a , int n ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) System . out . print ( a [ i ] + \" \" ) ;\n  System . out . println ( ) ;\n}\n", "FIND_MINIMUM_RADIUS_ATLEAST_K_POINT_LIE_INSIDE_CIRCLE": "static int minRadius ( int k , int [ ] x , int [ ] y , int n ) {\n  int [ ] dis = new int [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) dis [ i ] = x [ i ] * x [ i ] + y [ i ] * y [ i ] ;\n  Arrays . sort ( dis ) ;\n  return dis [ k - 1 ] ;\n}\n", "COUNT_SUBARRAYS_EQUAL_NUMBER_1S_0S": "static int countSubarrWithEqualZeroAndOne ( int arr [ ] , int n ) {\n  Map < Integer , Integer > um = new HashMap < > ( ) ;\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 . put ( curr_sum , um . get ( curr_sum ) == null ? 1 : um . get ( curr_sum ) + 1 ) ;\n  }\n  int count = 0 ;\n  for ( Map . Entry < Integer , Integer > itr : um . entrySet ( ) ) {\n    if ( itr . getValue ( ) > 1 ) count += ( ( itr . getValue ( ) * ( itr . getValue ( ) - 1 ) ) / 2 ) ;\n  }\n  if ( um . containsKey ( 0 ) ) count += um . get ( 0 ) ;\n  return count ;\n}\n", "MINIMUM_INDEX_SUM_COMMON_ELEMENTS_TWO_LISTS": "static void find ( Vector < String > list1 , Vector < String > list2 ) {\n  Vector < String > res = new Vector < > ( ) ;\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 . get ( i ) == list2 . get ( sum - i ) ) res . add ( list1 . get ( i ) ) ;\n    if ( res . size ( ) > 0 ) break ;\n  }\n  for ( int i = 0 ;\n  i < res . size ( ) ;\n  i ++ ) System . out . print ( res . get ( i ) + \" \" ) ;\n}\n", "CHECK_IF_A_NUMBER_IS_JUMBLED_OR_NOT": "static boolean 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 ( Math . abs ( digit2 - digit1 ) > 1 ) return false ;\n    num = num / 10 ;\n  }\n  return true ;\n}\n", "CEILING_IN_A_SORTED_ARRAY_1": "static 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": "static int Largestpower ( int n , int p ) {\n  int ans = 0 ;\n  while ( n > 0 ) {\n    n /= p ;\n    ans += n ;\n  }\n  return ans ;\n}\n", "MAXIMUM_SUM_IARRI_AMONG_ROTATIONS_GIVEN_ARRAY": "static int maxSum ( int arr [ ] , int n ) {\n  int res = Integer . MIN_VALUE ;\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 = Math . max ( res , curr_sum ) ;\n  }\n  return res ;\n}\n", "MINIMUM_LENGTH_SUBARRAY_SUM_GREATER_GIVEN_VALUE_1": "static 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": "static void findString ( String str , int n , int k ) {\n  if ( k == 0 ) {\n    System . out . println ( str ) ;\n    ;\n    return ;\n  }\n  String str2 = str ;\n  int p = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( str2 . charAt ( i ) != 'a' ) {\n      str2 = str2 . substring ( 0 , i ) + 'a' + str2 . substring ( i + 1 ) ;\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 . charAt ( i ) == 'a' ) {\n      str2 = str2 . substring ( 0 , i ) + 'b' + str2 . substring ( i + 1 ) ;\n      p ++ ;\n      if ( p == k ) break ;\n    }\n  }\n  System . out . println ( str2 ) ;\n}\n", "SUBSET_SUM_DIVISIBLE_M": "static boolean modularSum ( int arr [ ] , int n , int m ) {\n  if ( n > m ) return true ;\n  boolean DP [ ] = new boolean [ m ] ;\n  Arrays . fill ( DP , false ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( DP [ 0 ] ) return true ;\n    boolean temp [ ] = new boolean [ m ] ;\n    Arrays . fill ( temp , false ) ;\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": "static int evenbinomialCoeffSum ( int n ) {\n  return ( 1 << ( n - 1 ) ) ;\n}\n", "EVEN_FIBONACCI_NUMBERS_SUM": "static int evenFibSum ( int limit ) {\n  if ( limit < 2 ) return 0 ;\n  long ef1 = 0 , ef2 = 2 ;\n  long sum = ef1 + ef2 ;\n  while ( ef2 <= limit ) {\n    long ef3 = 4 * ef2 + ef1 ;\n    if ( ef3 > limit ) break ;\n    ef1 = ef2 ;\n    ef2 = ef3 ;\n    sum += ef2 ;\n  }\n  return ( int ) sum ;\n}\n", "MAKING_ELEMENTS_OF_TWO_ARRAYS_SAME_WITH_MINIMUM_INCREMENTDECREMENT": "static int MinOperation ( int a [ ] , int b [ ] , int n ) {\n  Arrays . sort ( a ) ;\n  Arrays . sort ( b ) ;\n  int result = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) {\n    if ( a [ i ] > b [ i ] ) result = result + Math . abs ( a [ i ] - b [ i ] ) ;\n    else if ( a [ i ] < b [ i ] ) result = result + Math . abs ( a [ i ] - b [ i ] ) ;\n  }\n  return result ;\n}\n", "REQUIRED_MINIMUM_DIGITS_REMOVE_NUMBER_MAKE_PERFECT_SQUARE": "static int perfectSquare ( String s ) {\n  int n = s . length ( ) ;\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 ) == 1 ) {\n        str += s . charAt ( j ) ;\n      }\n    }\n    if ( str . charAt ( 0 ) != '0' ) {\n      int temp = 0 ;\n      for ( int j = 0 ;\n      j < str . length ( ) ;\n      j ++ ) temp = temp * 10 + ( int ) ( str . charAt ( j ) - '0' ) ;\n      int k = ( int ) Math . sqrt ( temp ) ;\n      if ( k * k == temp ) {\n        if ( ans < ( int ) str . length ( ) ) {\n          ans = ( int ) str . length ( ) ;\n          num = str ;\n        }\n      }\n    }\n  }\n  if ( ans == - 1 ) return ans ;\n  else {\n    System . out . print ( num + \" \" ) ;\n    return n - ans ;\n  }\n}\n", "COUNT_WORDS_APPEAR_EXACTLY_TWO_TIMES_ARRAY_WORDS": "static int countWords ( String str [ ] , int n ) {\n  HashMap < String , Integer > m = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( m . containsKey ( str [ i ] ) ) {\n      int get = m . get ( str [ i ] ) ;\n      m . put ( str [ i ] , get + 1 ) ;\n    }\n    else {\n      m . put ( str [ i ] , 1 ) ;\n    }\n  }\n  int res = 0 ;\n  for ( Map . Entry < String , Integer > it : m . entrySet ( ) ) {\n    if ( it . getValue ( ) == 2 ) res ++ ;\n  }\n  return res ;\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_4": "static int countSetBitsRec ( 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": "public static int maxCost ( int mat [ ] [ ] , int N ) {\n  int dp [ ] [ ] = new int [ N ] [ N ] ;\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 ] + Math . 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": "static boolean isReversible ( String str ) {\n  int i = 0 , j = str . length ( ) - 1 ;\n  while ( i < j ) {\n    if ( str . charAt ( i ) != str . charAt ( j ) ) return false ;\n    i ++ ;\n    j -- ;\n  }\n  return true ;\n}\n", "FIND_SUM_ODD_FACTORS_NUMBER": "static int sumofoddFactors ( int n ) {\n  int res = 1 ;\n  while ( n % 2 == 0 ) n = n / 2 ;\n  for ( int i = 3 ;\n  i <= Math . 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": "static int maxSum ( int [ ] [ ] mat , int n ) {\n  if ( n == 1 ) return mat [ 0 ] [ 0 ] ;\n  int dp [ ] [ ] = new int [ n ] [ n ] ;\n  int maxSum = Integer . MIN_VALUE , 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 = Integer . MIN_VALUE ;\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": "static 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 += Math . log10 ( i ) ;\n  return ( int ) ( Math . floor ( digits ) ) + 1 ;\n}\n", "FIND_UNCOMMON_CHARACTERS_TWO_STRINGS": "static void findAndPrintUncommonChars ( String str1 , String str2 ) {\n  int present [ ] = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < MAX_CHAR ;\n  i ++ ) {\n    present [ i ] = 0 ;\n  }\n  int l1 = str1 . length ( ) ;\n  int l2 = str2 . length ( ) ;\n  for ( int i = 0 ;\n  i < l1 ;\n  i ++ ) {\n    present [ str1 . charAt ( i ) - 'a' ] = 1 ;\n  }\n  for ( int i = 0 ;\n  i < l2 ;\n  i ++ ) {\n    if ( present [ str2 . charAt ( i ) - 'a' ] == 1 || present [ str2 . charAt ( i ) - 'a' ] == - 1 ) {\n      present [ str2 . charAt ( i ) - 'a' ] = - 1 ;\n    }\n    else {\n      present [ str2 . charAt ( i ) - 'a' ] = 2 ;\n    }\n  }\n  for ( int i = 0 ;\n  i < MAX_CHAR ;\n  i ++ ) {\n    if ( present [ i ] == 1 || present [ i ] == 2 ) {\n      System . out . print ( ( char ) ( i + 'a' ) + \" \" ) ;\n    }\n  }\n}\n", "SQUARE_ROOT_OF_AN_INTEGER_1": "public static int floorSqrt ( int x ) {\n  if ( x == 0 || x == 1 ) return x ;\n  int start = 1 , end = x , ans = 0 ;\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": "static boolean isPath ( int arr [ ] [ ] ) {\n  arr [ 0 ] [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i < 5 ;\n  i ++ ) if ( arr [ 0 ] [ i ] != - 1 ) arr [ 0 ] [ i ] = arr [ 0 ] [ i - 1 ] ;\n  for ( int j = 1 ;\n  j < 5 ;\n  j ++ ) if ( arr [ j ] [ 0 ] != - 1 ) arr [ j ] [ 0 ] = arr [ j - 1 ] [ 0 ] ;\n  for ( int i = 1 ;\n  i < 5 ;\n  i ++ ) for ( int j = 1 ;\n  j < 5 ;\n  j ++ ) if ( arr [ i ] [ j ] != - 1 ) arr [ i ] [ j ] = Math . max ( arr [ i ] [ j - 1 ] , arr [ i - 1 ] [ j ] ) ;\n  return ( arr [ 5 - 1 ] [ 5 - 1 ] == 1 ) ;\n}\n", "NEWMAN_CONWAY_SEQUENCE_1": "static int sequence ( int n ) {\n  int f [ ] = new int [ n + 1 ] ;\n  f [ 0 ] = 0 ;\n  f [ 1 ] = 1 ;\n  f [ 2 ] = 1 ;\n  int i ;\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": "static 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 . charAt ( i ) == ' ' ) {\n      start = i + 1 ;\n      while ( start != end ) result += str . charAt ( start ++ ) ;\n      result += ' ' ;\n      end = i ;\n    }\n    i -- ;\n  }\n  start = 0 ;\n  while ( start != end ) result += str . charAt ( start ++ ) ;\n  return result ;\n}\n", "FIND_NUMBER_ENDLESS_POINTS": "static int countEndless ( boolean input [ ] [ ] , int n ) {\n  boolean row [ ] [ ] = new boolean [ n ] [ n ] ;\n  boolean col [ ] [ ] = new boolean [ n ] [ n ] ;\n  for ( int j = 0 ;\n  j < n ;\n  j ++ ) {\n    boolean isEndless = true ;\n    for ( int i = n - 1 ;\n    i >= 0 ;\n    i -- ) {\n      if ( input [ i ] [ j ] == false ) isEndless = false ;\n      col [ i ] [ j ] = isEndless ;\n    }\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    boolean isEndless = true ;\n    for ( int j = n - 1 ;\n    j >= 0 ;\n    j -- ) {\n      if ( input [ i ] [ j ] == false ) isEndless = false ;\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": "static boolean check ( String s1 , String s2 ) {\n  int n = s1 . length ( ) ;\n  int m = s2 . length ( ) ;\n  boolean dp [ ] [ ] = new boolean [ 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 ( ) && ( Character . toUpperCase ( s1 . charAt ( i ) ) == s2 . charAt ( j ) ) ) dp [ i + 1 ] [ j + 1 ] = true ;\n        if ( ! Character . isUpperCase ( s1 . charAt ( i ) ) ) dp [ i + 1 ] [ j ] = true ;\n      }\n    }\n  }\n  return ( dp [ n ] [ m ] ) ;\n}\n", "CALCULATE_VOLUME_DODECAHEDRON": "static double vol_of_dodecahedron ( int side ) {\n  return ( ( ( 15 + ( 7 * ( Math . sqrt ( 5 ) ) ) ) / 4 ) * ( Math . pow ( side , 3 ) ) ) ;\n}\n", "PROGRAM_FIND_REMAINDER_LARGE_NUMBER_DIVIDED_11": "static 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 . charAt ( i ) - '0' ) ;\n    rem = num % 11 ;\n  }\n  return rem ;\n}\n", "SORT_STRING_CHARACTERS": "static void sortString ( String str ) {\n  char [ ] arr = str . toCharArray ( ) ;\n  Arrays . sort ( arr ) ;\n  System . out . print ( String . valueOf ( arr ) ) ;\n}\n", "BIRTHDAY_PARADOX": "static double find ( double p ) {\n  return Math . ceil ( Math . sqrt ( 2 * 365 * Math . log ( 1 / ( 1 - p ) ) ) ) ;\n}\n", "CHECK_LINE_PASSES_ORIGIN": "static boolean 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": "static void findElements ( int arr [ ] , int n ) {\n  int first = Integer . MIN_VALUE ;\n  int second = Integer . MAX_VALUE ;\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 ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "MINIMUM_SUM_SUBSEQUENCE_LEAST_ONE_EVERY_FOUR_CONSECUTIVE_ELEMENTS_PICKED_1": "static int minSum ( int ar [ ] , int n ) {\n  if ( n <= 4 ) return Arrays . stream ( ar ) . min ( ) . getAsInt ( ) ;\n  int [ ] sum = new int [ 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 ] + Arrays . stream ( Arrays . copyOfRange ( sum , i - 4 , i ) ) . min ( ) . getAsInt ( ) ;\n  return Arrays . stream ( Arrays . copyOfRange ( sum , n - 4 , n ) ) . min ( ) . getAsInt ( ) ;\n}\n", "CEILING_IN_A_SORTED_ARRAY": "static 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": "static 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": "static int countManipulations ( String s1 , String s2 ) {\n  int count = 0 ;\n  int char_count [ ] = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < s1 . length ( ) ;\n  i ++ ) char_count [ s1 . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < s2 . length ( ) ;\n  i ++ ) if ( char_count [ s2 . charAt ( i ) - 'a' ] -- <= 0 ) count ++ ;\n  return count ;\n}\n", "CHECK_IF_ALL_THE_ELEMENTS_CAN_BE_MADE_OF_SAME_PARITY_BY_INVERTING_ADJACENT_ELEMENTS": "static boolean 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 ) == 1 ) count_odd ++ ;\n    else count_even ++ ;\n  }\n  if ( count_odd % 2 == 1 && count_even % 2 == 1 ) return false ;\n  else return true ;\n}\n", "CONVERT_SUBSTRINGS_LENGTH_K_BASE_B_DECIMAL": "static void substringConversions ( String str , int k , int b ) {\n  for ( int i = 0 ;\n  i + k <= str . length ( ) ;\n  i ++ ) {\n    String sub = str . substring ( i , i + k ) ;\n    int sum = 0 , counter = 0 ;\n    for ( int j = sub . length ( ) - 1 ;\n    j >= 0 ;\n    j -- ) {\n      sum = ( int ) ( sum + ( ( sub . charAt ( j ) - '0' ) * Math . pow ( b , counter ) ) ) ;\n      counter ++ ;\n    }\n    System . out . print ( sum + \" \" ) ;\n  }\n}\n", "FIND_K_SUCH_THAT_ALL_ELEMENTS_IN_KTH_ROW_ARE_0_AND_KTH_COLUMN_ARE_1_IN_A_BOOLEAN_MATRIX": "static int find ( boolean arr [ ] [ ] ) {\n  int i = 0 , j = n - 1 ;\n  int res = - 1 ;\n  while ( i < n && j >= 0 ) {\n    if ( arr [ i ] [ j ] == false ) {\n      while ( j >= 0 && ( arr [ i ] [ j ] == false || i == j ) ) {\n        j -- ;\n      }\n      if ( j == - 1 ) {\n        res = i ;\n        break ;\n      }\n      else {\n        i ++ ;\n      }\n    }\n    else {\n      while ( i < n && ( arr [ i ] [ j ] == true || i == j ) ) {\n        i ++ ;\n      }\n      if ( i == n ) {\n        res = j ;\n        break ;\n      }\n      else {\n        j -- ;\n      }\n    }\n  }\n  if ( res == - 1 ) {\n    return res ;\n  }\n  for ( int k = 0 ;\n  k < n ;\n  k ++ ) {\n    if ( res != k && arr [ k ] [ res ] != true ) {\n      return - 1 ;\n    }\n  }\n  for ( int l = 0 ;\n  l < n ;\n  l ++ ) {\n    if ( res != l && arr [ res ] [ l ] != false ) {\n      return - 1 ;\n    }\n  }\n  return res ;\n}\n", "NUMBER_ORDERED_PAIRS_AI_AJ_0": "static 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": "static 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 = ( int ) Math . sqrt ( ySquare ) ;\n    if ( y * y == ySquare ) result += 4 ;\n  }\n  return result ;\n}\n", "MINIMUM_CHARACTERS_ADDED_FRONT_MAKE_STRING_PALINDROME": "static boolean ispalindrome ( String s ) {\n  int l = s . length ( ) ;\n  for ( int i = 0 , j = l - 1 ;\n  i <= j ;\n  i ++ , j -- ) {\n    if ( s . charAt ( i ) != s . charAt ( j ) ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "K_TH_MISSING_ELEMENT_INCREASING_SEQUENCE_NOT_PRESENT_GIVEN_SEQUENCE": "static int find ( int a [ ] , int b [ ] , int k , int n1 , int n2 ) {\n  LinkedHashSet < Integer > s = new LinkedHashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < n2 ;\n  i ++ ) s . add ( b [ i ] ) ;\n  int missing = 0 ;\n  for ( int i = 0 ;\n  i < n1 ;\n  i ++ ) {\n    if ( ! s . contains ( a [ i ] ) ) missing ++ ;\n    if ( missing == k ) return a [ i ] ;\n  }\n  return - 1 ;\n}\n", "PROGRAM_CHECK_ISBN": "static boolean 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 . charAt ( i ) - '0' ;\n    if ( 0 > digit || 9 < digit ) return false ;\n    sum += ( digit * ( 10 - i ) ) ;\n  }\n  char last = isbn . charAt ( 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": "static int waysToIncreaseLCSBy1 ( String str1 , String str2 ) {\n  int m = str1 . length ( ) , n = str2 . length ( ) ;\n  Vector < Integer > [ ] position = new Vector [ M ] ;\n  for ( int i = 0 ;\n  i < M ;\n  i ++ ) position [ i ] = new Vector < > ( ) ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) position [ str2 . charAt ( i - 1 ) - 'a' ] . add ( i ) ;\n  int [ ] [ ] lcsl = new int [ m + 2 ] [ n + 2 ] ;\n  int [ ] [ ] lcsr = new int [ 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 . charAt ( i - 1 ) == str2 . charAt ( j - 1 ) ) lcsl [ i ] [ j ] = 1 + lcsl [ i - 1 ] [ j - 1 ] ;\n      else lcsl [ i ] [ j ] = Math . 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 . charAt ( i - 1 ) == str2 . charAt ( j - 1 ) ) lcsr [ i ] [ j ] = 1 + lcsr [ i + 1 ] [ j + 1 ] ;\n      else lcsr [ i ] [ j ] = Math . 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 d = 0 ;\n    d < 26 ;\n    d ++ ) {\n      for ( int j = 0 ;\n      j < position [ d ] . size ( ) ;\n      j ++ ) {\n        int p = position [ d ] . elementAt ( 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": "static int eggDrop ( int n , int k ) {\n  int eggFloor [ ] [ ] = new int [ 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 ] = Integer . MAX_VALUE ;\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": "static int countWays ( int n ) {\n  int table [ ] = new int [ n + 1 ] ;\n  Arrays . fill ( table , 0 ) ;\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": "static 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": "static int countUnique ( int mat [ ] [ ] , int n , int m ) {\n  int [ ] rowsum = new int [ n ] ;\n  int [ ] colsum = new int [ m ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = 0 ;\n  j < m ;\n  j ++ ) if ( mat [ i ] [ j ] != 0 ) {\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 ] != 0 && rowsum [ i ] == 1 && colsum [ j ] == 1 ) uniquecount ++ ;\n  return uniquecount ;\n}\n", "GREEDY_ALGORITHM_TO_FIND_MINIMUM_NUMBER_OF_COINS": "static void findMin ( int V ) {\n  Vector < Integer > ans = new Vector < > ( ) ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    while ( V >= deno [ i ] ) {\n      V -= deno [ i ] ;\n      ans . add ( deno [ i ] ) ;\n    }\n  }\n  for ( int i = 0 ;\n  i < ans . size ( ) ;\n  i ++ ) {\n    System . out . print ( \" \" + ans . elementAt ( i ) ) ;\n  }\n}\n", "CHECK_INTEGER_OVERFLOW_MULTIPLICATION": "static Boolean isOverflow ( long a , long b ) {\n  if ( a == 0 || b == 0 ) return false ;\n  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": "static int findDiff ( int arr [ ] , int n ) {\n  Map < Integer , Integer > mp = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( mp . containsKey ( arr [ i ] ) ) {\n      mp . put ( arr [ i ] , mp . get ( arr [ i ] ) + 1 ) ;\n    }\n    else {\n      mp . put ( arr [ i ] , 1 ) ;\n    }\n  }\n  int max_count = 0 , min_count = n ;\n  for ( Map . Entry < Integer , Integer > x : mp . entrySet ( ) ) {\n    max_count = Math . max ( max_count , x . getValue ( ) ) ;\n    min_count = Math . min ( min_count , x . getValue ( ) ) ;\n  }\n  return ( max_count - min_count ) ;\n}\n", "COMPOSITE_NUMBER": "static boolean isComposite ( int n ) {\n  if ( n <= 1 ) System . out . println ( \"False\" ) ;\n  if ( n <= 3 ) System . out . println ( \"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": "static void findLIS ( int A [ ] , int n ) {\n  Map < Integer , Integer > hash = new HashMap < Integer , Integer > ( ) ;\n  int LIS_size = 1 ;\n  int LIS_index = 0 ;\n  hash . put ( A [ 0 ] , 1 ) ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    hash . put ( A [ i ] , hash . get ( A [ i ] - 1 ) == null ? 1 : hash . get ( A [ i ] - 1 ) + 1 ) ;\n    if ( LIS_size < hash . get ( A [ i ] ) ) {\n      LIS_size = hash . get ( A [ i ] ) ;\n      LIS_index = A [ i ] ;\n    }\n  }\n  System . out . println ( \"LIS_size = \" + LIS_size ) ;\n  System . out . print ( \"LIS : \" ) ;\n  int start = LIS_index - LIS_size + 1 ;\n  while ( start <= LIS_index ) {\n    System . out . print ( start + \" \" ) ;\n    start ++ ;\n  }\n}\n", "COUNT_SET_BITS_IN_AN_INTEGER_2": "static int countSetBits ( int n ) {\n  int count = 0 ;\n  while ( n > 0 ) {\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": "boolean findPairs ( int arr [ ] ) {\n  HashMap < Integer , pair > map = new HashMap < Integer , pair > ( ) ;\n  int n = arr . length ;\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 ( ! map . containsKey ( sum ) ) map . put ( sum , new pair ( i , j ) ) ;\n      else {\n        pair p = map . get ( sum ) ;\n        System . out . println ( \"(\" + arr [ p . first ] + \", \" + arr [ p . second ] + \") and (\" + arr [ i ] + \", \" + arr [ j ] + \")\" ) ;\n        return true ;\n      }\n    }\n  }\n  return false ;\n}\n", "COUNT_OBTUSE_ANGLES_CIRCLE_K_EQUIDISTANT_POINTS_2_GIVEN_POINTS": "static 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": "public static double numberOfTriangles ( int n ) {\n  double ans = 2 * ( pow ( 3 , n ) ) - 1 ;\n  return ans ;\n}\n", "FIND_A_REPEATING_AND_A_MISSING_NUMBER": "static void printTwoElements ( int arr [ ] , int size ) {\n  int i ;\n  System . out . print ( \"The repeating element is \" ) ;\n  for ( i = 0 ;\n  i < size ;\n  i ++ ) {\n    int abs_val = Math . abs ( arr [ i ] ) ;\n    if ( arr [ abs_val - 1 ] > 0 ) arr [ abs_val - 1 ] = - arr [ abs_val - 1 ] ;\n    else System . out . println ( abs_val ) ;\n  }\n  System . out . print ( \"And the missing element is \" ) ;\n  for ( i = 0 ;\n  i < size ;\n  i ++ ) {\n    if ( arr [ i ] > 0 ) System . out . println ( i + 1 ) ;\n  }\n}\n", "MINIMUM_DIFFERENCE_BETWEEN_GROUPS_OF_SIZE_TWO": "static long calculate ( long a [ ] , int n ) {\n  Arrays . sort ( a ) ;\n  int i , j ;\n  Vector < Long > s = new Vector < > ( ) ;\n  for ( i = 0 , j = n - 1 ;\n  i < j ;\n  i ++ , j -- ) s . add ( ( a [ i ] + a [ j ] ) ) ;\n  long mini = Collections . min ( s ) ;\n  long maxi = Collections . max ( s ) ;\n  return Math . abs ( maxi - mini ) ;\n}\n", "FIND_PERIMETER_CYLINDER": "static int perimeter ( int diameter , int height ) {\n  return 2 * ( diameter + height ) ;\n}\n", "MAGICAL_INDICES_ARRAY": "static int solve ( int [ ] A , int n ) {\n  int i , cnt = 0 , j ;\n  int [ ] parent = new int [ n + 1 ] ;\n  int [ ] vis = new int [ n + 1 ] ;\n  for ( i = 0 ;\n  i < n + 1 ;\n  i ++ ) {\n    parent [ i ] = - 1 ;\n    vis [ i ] = 0 ;\n  }\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 ] == 0 ) {\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": "static 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": "static int findLargestPlus ( int mat [ ] [ ] ) {\n  int left [ ] [ ] = new int [ N ] [ N ] ;\n  int right [ ] [ ] = new int [ N ] [ N ] ;\n  int top [ ] [ ] = new int [ N ] [ N ] ;\n  int bottom [ ] [ ] = new int [ 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 = Math . min ( Math . min ( top [ i ] [ j ] , bottom [ i ] [ j ] ) , Math . min ( left [ i ] [ j ] , right [ i ] [ j ] ) ) ;\n      if ( len > n ) n = len ;\n    }\n  }\n  if ( n > 0 ) return 4 * ( n - 1 ) + 1 ;\n  return 0 ;\n}\n", "LEVEL_NODE_TREE_SOURCE_NODE_USING_BFS": "static void printLevels ( Vector < Vector < Integer >> graph , int V , int x ) {\n  int level [ ] = new int [ V ] ;\n  boolean marked [ ] = new boolean [ V ] ;\n  Queue < Integer > que = new LinkedList < Integer > ( ) ;\n  que . add ( x ) ;\n  level [ x ] = 0 ;\n  marked [ x ] = true ;\n  while ( que . size ( ) > 0 ) {\n    x = que . peek ( ) ;\n    que . remove ( ) ;\n    for ( int i = 0 ;\n    i < graph . get ( x ) . size ( ) ;\n    i ++ ) {\n      int b = graph . get ( x ) . get ( i ) ;\n      if ( ! marked [ b ] ) {\n        que . add ( b ) ;\n        level [ b ] = level [ x ] + 1 ;\n        marked [ b ] = true ;\n      }\n    }\n  }\n  System . out . println ( \"Nodes\" + \" \" + \"Level\" ) ;\n  for ( int i = 0 ;\n  i < V ;\n  i ++ ) System . out . println ( \" \" + i + \" --> \" + level [ i ] ) ;\n}\n", "FIND_SQUARE_ROOT_UNDER_MODULO_P_SET_1_WHEN_P_IS_IN_FORM_OF_4I_3": "static 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      System . out . println ( \"Square \" + \"root is \" + x ) ;\n      return ;\n    }\n  }\n  System . out . println ( \"Square root \" + \"doesn't exist\" ) ;\n}\n", "CHECK_IF_ARRAY_ELEMENTS_ARE_CONSECUTIVE": "boolean 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    boolean visited [ ] = new boolean [ n ] ;\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": "static 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  Arrays . sort ( arr ) ;\n  int res = 0 , curr_sum = 0 ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\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": "static long calculateSum ( int n ) {\n  long sum = 0 ;\n  sum = 1 << n ;\n  return ( sum - 1 ) ;\n}\n", "SWAP_TWO_NIBBLES_BYTE": "static int swapNibbles ( int x ) {\n  return ( ( x & 0x0F ) << 4 | ( x & 0xF0 ) >> 4 ) ;\n}\n", "CHECK_CHARACTERS_GIVEN_STRING_CAN_REARRANGED_FORM_PALINDROME_1": "static boolean canFormPalindrome ( String str ) {\n  List < Character > list = new ArrayList < Character > ( ) ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( list . contains ( str . charAt ( i ) ) ) list . remove ( ( Character ) str . charAt ( i ) ) ;\n    else list . add ( str . charAt ( i ) ) ;\n  }\n  if ( str . length ( ) % 2 == 0 && list . isEmpty ( ) || ( str . length ( ) % 2 == 1 && list . size ( ) == 1 ) ) return true ;\n  else return false ;\n}\n", "WAYS_SPLIT_STRING_PARTITION_STARTS_DISTINCT_CHARACTER": "static int countWays ( String s ) {\n  int count [ ] = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) count [ s . charAt ( i ) - 'a' ] ++ ;\n  count [ s . charAt ( 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": "static int zigzag ( int n , int k ) {\n  int dp [ ] [ ] = new int [ n + 1 ] [ k + 1 ] ;\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 <= Math . min ( i , k ) ;\n    j ++ ) dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ i - j ] ;\n  }\n  return dp [ n ] [ k ] ;\n}\n", "COUNT_PAIRS_DIFFERENCE_EQUAL_K": "static 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": "static 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": "static void printGrouped ( String str ) {\n  int n = str . length ( ) ;\n  int count [ ] = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) count [ str . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    while ( count [ str . charAt ( i ) - 'a' ] != 0 ) {\n      System . out . print ( str . charAt ( i ) ) ;\n      count [ str . charAt ( i ) - 'a' ] -- ;\n    }\n    count [ str . charAt ( i ) - 'a' ] = 0 ;\n  }\n}\n", "MAXIMUM_PATH_SUM_POSITION_JUMPS_DIVISIBILITY_CONDITION": "static void printMaxSum ( int arr [ ] , int n ) {\n  int dp [ ] = new int [ n ] ;\n  Arrays . fill ( dp , 0 ) ;\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 <= Math . 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 ++ ) System . out . print ( dp [ i ] + \" \" ) ;\n}\n", "PROGRAM_CIRCUMFERENCE_PARALLELOGRAM": "static float circumferenceparallelogram ( float a , float b ) {\n  return ( ( 2 * a ) + ( 2 * b ) ) ;\n}\n", "COUNT_POSSIBLE_PATHS_TOP_LEFT_BOTTOM_RIGHT_NXM_MATRIX_2": "static int numberOfPaths ( int m , int n ) {\n  int [ ] dp = new int [ n ] ;\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": "static int remAnagram ( String str1 , String str2 ) {\n  int count1 [ ] = new int [ 26 ] ;\n  int count2 [ ] = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < str1 . length ( ) ;\n  i ++ ) count1 [ str1 . charAt ( i ) - 'a' ] ++ ;\n  for ( int i = 0 ;\n  i < str2 . length ( ) ;\n  i ++ ) count2 [ str2 . charAt ( i ) - 'a' ] ++ ;\n  int result = 0 ;\n  for ( int i = 0 ;\n  i < 26 ;\n  i ++ ) result += Math . abs ( count1 [ i ] - count2 [ i ] ) ;\n  return result ;\n}\n", "SUM_DIVISORS_1_N_1": "static 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": "static int maxSubsequenceSubstring ( char x [ ] , char y [ ] , int n , int m ) {\n  int dp [ ] [ ] = new int [ 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 = Math . max ( ans , dp [ i ] [ n ] ) ;\n  return ans ;\n}\n", "SUM_FAI_AJ_PAIRS_ARRAY_N_INTEGERS": "public static int sum ( int a [ ] , int n ) {\n  Map < Integer , Integer > cnt = new HashMap < Integer , Integer > ( ) ;\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 . containsKey ( a [ i ] - 1 ) ) ans -= cnt . get ( a [ i ] - 1 ) ;\n    if ( cnt . containsKey ( a [ i ] + 1 ) ) ans += cnt . get ( a [ i ] + 1 ) ;\n    if ( cnt . containsKey ( a [ i ] ) ) {\n      cnt . put ( a [ i ] , cnt . get ( a [ i ] ) + 1 ) ;\n    }\n    else {\n      cnt . put ( a [ i ] , 1 ) ;\n    }\n  }\n  return ans ;\n}\n", "BINARY_REPRESENTATION_OF_A_GIVEN_NUMBER": "static void bin ( int n ) {\n  if ( n > 1 ) bin ( n / 2 ) ;\n  System . out . print ( n % 2 ) ;\n}\n", "KNAPSACK_PROBLEM": "static 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": "static int doublefactorial ( 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  return res ;\n}\n", "COUNT_DIGITS_FACTORIAL_SET_2": "static long findDigits ( int n ) {\n  if ( n < 0 ) return 0 ;\n  if ( n <= 1 ) return 1 ;\n  double x = ( n * Math . log10 ( n / M_E ) + Math . log10 ( 2 * M_PI * n ) / 2.0 ) ;\n  return ( long ) Math . floor ( x ) + 1 ;\n}\n", "DELANNOY_NUMBER_1": "static int dealnnoy ( int n , int m ) {\n  int dp [ ] [ ] = new int [ 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": "static 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": "static int findNumberOfTriangles ( int arr [ ] ) {\n  int n = arr . length ;\n  Arrays . sort ( arr ) ;\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": "public static int numberOfTriangles ( int n ) {\n  int [ ] answer = new int [ n + 1 ] ;\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": "static boolean areSumSame ( int a [ ] [ ] , int n , int m ) {\n  int sum1 = 0 , sum2 = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    sum1 = 0 ;\n    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": "static boolean isPowerOfTwo ( int n ) {\n  if ( n == 0 ) return false ;\n  while ( n != 1 ) {\n    if ( n % 2 != 0 ) return false ;\n    n = n / 2 ;\n  }\n  return true ;\n}\n", "PUT_SPACES_WORDS_STARTING_CAPITAL_LETTERS": "public static void amendSentence ( String sstr ) {\n  char [ ] str = sstr . toCharArray ( ) ;\n  for ( int i = 0 ;\n  i < str . length ;\n  i ++ ) {\n    if ( str [ i ] >= 'A' && str [ i ] <= 'Z' ) {\n      str [ i ] = ( char ) ( str [ i ] + 32 ) ;\n      if ( i != 0 ) System . out . print ( \" \" ) ;\n      System . out . print ( str [ i ] ) ;\n    }\n    else System . out . print ( str [ i ] ) ;\n  }\n}\n", "CHECK_DIVISIBILITY_BINARY_STRING_2K": "static boolean isDivisible ( String str , int k ) {\n  int n = str . length ( ) ;\n  int c = 0 ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) if ( str . charAt ( n - i - 1 ) == '0' ) c ++ ;\n  return ( c == k ) ;\n}\n", "SUBSEQUENCES_SIZE_THREE_ARRAY_WHOSE_SUM_DIVISIBLE_M": "static 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": "static int findLongestConseqSubseq ( int arr [ ] , int n ) {\n  HashSet < Integer > S = new HashSet < Integer > ( ) ;\n  int ans = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) S . add ( arr [ i ] ) ;\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) {\n    if ( ! S . contains ( arr [ i ] - 1 ) ) {\n      int j = arr [ i ] ;\n      while ( S . contains ( j ) ) j ++ ;\n      if ( ans < j - arr [ i ] ) ans = j - arr [ i ] ;\n    }\n  }\n  return ans ;\n}\n", "FIND_INDEX_GIVEN_FIBONACCI_NUMBER_CONSTANT_TIME_1": "static int findIndex ( int n ) {\n  float fibo = 2.078087F * ( float ) Math . log ( n ) + 1.672276F ;\n  return Math . round ( fibo ) ;\n}\n", "LARGEST_DIVISIBLE_PAIRS_SUBSET": "static int largestSubset ( int [ ] a , int n ) {\n  Arrays . sort ( a ) ;\n  int [ ] dp = new int [ 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 ++ ) {\n      if ( a [ j ] % a [ i ] == 0 ) {\n        mxm = Math . max ( mxm , dp [ j ] ) ;\n      }\n    }\n    dp [ i ] = 1 + mxm ;\n  }\n  return Arrays . stream ( dp ) . max ( ) . getAsInt ( ) ;\n}\n", "FIND_WHETHER_A_GIVEN_NUMBER_IS_A_POWER_OF_4_OR_NOT_2": "static boolean isPowerOfFour ( int n ) {\n  return n != 0 && ( ( n & ( n - 1 ) ) == 0 ) && ( n & 0xAAAAAAAA ) == 0 ;\n}\n", "COMPUTE_NCR_P_SET_1_INTRODUCTION_AND_DYNAMIC_PROGRAMMING_SOLUTION": "static int nCrModp ( int n , int r , int p ) {\n  int C [ ] = new int [ r + 1 ] ;\n  Arrays . fill ( C , 0 ) ;\n  C [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = Math . 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": "static 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": "static void twoWaySort ( int arr [ ] , int n ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( ( arr [ i ] & 1 ) != 0 ) arr [ i ] *= - 1 ;\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( ( arr [ i ] & 1 ) != 0 ) arr [ i ] *= - 1 ;\n}\n", "POINT_CLIPPING_ALGORITHM_COMPUTER_GRAPHICS": "static void pointClip ( int XY [ ] [ ] , int n , int Xmin , int Ymin , int Xmax , int Ymax ) {\n  System . out . printf ( \"Point inside the viewing pane:\\n\" ) ;\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 ) ) System . out . printf ( \"[%d, %d] \" , XY [ i ] [ 0 ] , XY [ i ] [ 1 ] ) ;\n    }\n  }\n  System . out . printf ( \"\\nPoint outside the viewing pane:\\n\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ( XY [ i ] [ 0 ] < Xmin ) || ( XY [ i ] [ 0 ] > Xmax ) ) System . out . printf ( \"[%d, %d] \" , XY [ i ] [ 0 ] , XY [ i ] [ 1 ] ) ;\n    if ( ( XY [ i ] [ 1 ] < Ymin ) || ( XY [ i ] [ 1 ] > Ymax ) ) System . out . printf ( \"[%d, %d] \" , XY [ i ] [ 0 ] , XY [ i ] [ 1 ] ) ;\n  }\n}\n", "WAYS_TRANSFORMING_ONE_STRING_REMOVING_0_CHARACTERS": "static int countTransformation ( String a , String b ) {\n  int n = a . length ( ) , m = b . length ( ) ;\n  if ( m == 0 ) {\n    return 1 ;\n  }\n  int dp [ ] [ ] = new int [ m + 1 ] [ n + 1 ] ;\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 ) {\n          dp [ i ] [ j ] = ( a . charAt ( j ) == b . charAt ( i ) ) ? 1 : 0 ;\n        }\n        else if ( a . charAt ( j ) == b . charAt ( i ) ) {\n          dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + 1 ;\n        }\n        else {\n          dp [ i ] [ j ] = dp [ i ] [ j - 1 ] ;\n        }\n      }\n      else if ( a . charAt ( j ) == b . charAt ( i ) ) {\n        dp [ i ] [ j ] = dp [ i ] [ j - 1 ] + dp [ i - 1 ] [ j - 1 ] ;\n      }\n      else {\n        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": "static 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      System . out . print ( 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 ) System . out . print ( arr1 [ i ] + \" \" ) ;\n}\n", "COUNT_INDEX_PAIRS_EQUAL_ELEMENTS_ARRAY": "static 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": "static void findSymPairs ( int arr [ ] [ ] ) {\n  HashMap < Integer , Integer > hM = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    int first = arr [ i ] [ 0 ] ;\n    int sec = arr [ i ] [ 1 ] ;\n    Integer val = hM . get ( sec ) ;\n    if ( val != null && val == first ) System . out . println ( \"(\" + sec + \", \" + first + \")\" ) ;\n    else hM . put ( first , sec ) ;\n  }\n}\n", "COUNT_SUBSEQUENCES_PRODUCT_LESS_K": "public static int productSubSeqCount ( ArrayList < Integer > arr , int k ) {\n  int n = arr . size ( ) ;\n  int dp [ ] [ ] = new int [ k + 1 ] [ n + 1 ] ;\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 . get ( j - 1 ) <= i && arr . get ( j - 1 ) > 0 ) dp [ i ] [ j ] += dp [ i / arr . get ( j - 1 ) ] [ j - 1 ] + 1 ;\n    }\n  }\n  return dp [ k ] [ n ] ;\n}\n", "REARRANGE_ARRAY_ARRI_ARRJ_EVEN_ARRI": "public static void rearrangeArr ( int arr [ ] , int n ) {\n  int evenPos = n / 2 ;\n  int oddPos = n - evenPos ;\n  int [ ] tempArr = new int [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) tempArr [ i ] = arr [ i ] ;\n  Arrays . sort ( tempArr ) ;\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 ++ ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "MINIMUM_ROTATIONS_UNLOCK_CIRCULAR_LOCK": "static int minRotation ( int input , int unlock_code ) {\n  int rotation = 0 ;\n  int input_digit , code_digit ;\n  while ( input > 0 || unlock_code > 0 ) {\n    input_digit = input % 10 ;\n    code_digit = unlock_code % 10 ;\n    rotation += Math . min ( Math . abs ( input_digit - code_digit ) , 10 - Math . 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": "static 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 . charAt ( 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        System . out . print ( \"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        System . out . print ( \"1\" ) ;\n        count_1 -- ;\n      }\n    }\n  }\n}\n", "DYNAMIC_PROGRAMMING_SET_14_MAXIMUM_SUM_INCREASING_SUBSEQUENCE": "static int maxSumIS ( int arr [ ] , int n ) {\n  int i , j , max = 0 ;\n  int msis [ ] = new int [ 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": "static int countRect ( int n ) {\n  int ans = 0 ;\n  for ( int length = 1 ;\n  length <= Math . 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": "static void printSeries ( int n ) {\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    int num = i * ( i + 1 ) * ( i + 2 ) / 6 ;\n    System . out . print ( num + \" \" ) ;\n  }\n}\n", "PROGRAM_TO_FIND_TRANSPOSE_OF_A_MATRIX": "static void transpose ( int A [ ] [ ] , int B [ ] [ ] ) {\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": "public void decToBinary ( int n ) {\n  for ( int i = 31 ;\n  i >= 0 ;\n  i -- ) {\n    int k = n >> i ;\n    if ( ( k & 1 ) > 0 ) System . out . print ( \"1\" ) ;\n    else System . out . print ( \"0\" ) ;\n  }\n}\n", "REARRANGE_ARRAY_ORDER_SMALLEST_LARGEST_2ND_SMALLEST_2ND_LARGEST": "static void rearrangeArray ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  int [ ] tempArr = new int [ n ] ;\n  int ArrIndex = 0 ;\n  for ( int i = 0 , j = n - 1 ;\n  i <= n / 2 || j > n / 2 ;\n  i ++ , j -- ) {\n    if ( ArrIndex < n ) {\n      tempArr [ ArrIndex ] = arr [ i ] ;\n      ArrIndex ++ ;\n    }\n    if ( ArrIndex < n ) {\n      tempArr [ ArrIndex ] = arr [ j ] ;\n      ArrIndex ++ ;\n    }\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) arr [ i ] = tempArr [ i ] ;\n}\n", "SUM_AREA_RECTANGLES_POSSIBLE_ARRAY": "static int MaxTotalRectangleArea ( int [ ] a , int n ) {\n  Arrays . sort ( a ) ;\n  int sum = 0 ;\n  boolean flag = false ;\n  int len = 0 ;\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 [ ] , int n ) {\n  int res = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( str [ i ] == '1' ) {\n      for ( int j = i + 1 ;\n      j < n ;\n      j ++ ) {\n        if ( str [ j ] == '1' ) res ++ ;\n      }\n    }\n  }\n  return res ;\n}\n", "DYNAMIC_PROGRAMMING_SET_31_OPTIMAL_STRATEGY_FOR_A_GAME": "static int optimalStrategyOfGame ( int arr [ ] , int n ) {\n  int table [ ] [ ] = new int [ n ] [ n ] ;\n  int gap , i , j , x , y , z ;\n  for ( gap = 0 ;\n  gap < n ;\n  ++ gap ) {\n    for ( i = 0 , j = gap ;\n    j < n ;\n    ++ i , ++ j ) {\n      x = ( ( i + 2 ) <= j ) ? table [ i + 2 ] [ j ] : 0 ;\n      y = ( ( i + 1 ) <= ( j - 1 ) ) ? table [ i + 1 ] [ j - 1 ] : 0 ;\n      z = ( i <= ( j - 2 ) ) ? table [ i ] [ j - 2 ] : 0 ;\n      table [ i ] [ j ] = Math . max ( arr [ i ] + Math . min ( x , y ) , arr [ j ] + Math . min ( y , z ) ) ;\n    }\n  }\n  return table [ 0 ] [ n - 1 ] ;\n}\n", "REPLACE_CHARACTER_C1_C2_C2_C1_STRING_S": "static String replace ( String s , char c1 , char c2 ) {\n  int l = s . length ( ) ;\n  char [ ] arr = s . toCharArray ( ) ;\n  for ( int i = 0 ;\n  i < l ;\n  i ++ ) {\n    if ( arr [ i ] == c1 ) arr [ i ] = c2 ;\n    else if ( arr [ i ] == c2 ) arr [ i ] = c1 ;\n  }\n  return String . valueOf ( arr ) ;\n}\n", "FIND_THE_LARGEST_SUBARRAY_WITH_0_SUM_1": "static int maxLen ( int arr [ ] ) {\n  HashMap < Integer , Integer > hM = new HashMap < Integer , Integer > ( ) ;\n  int sum = 0 ;\n  int max_len = 0 ;\n  for ( int i = 0 ;\n  i < arr . length ;\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    Integer prev_i = hM . get ( sum ) ;\n    if ( prev_i != null ) max_len = Math . max ( max_len , i - prev_i ) ;\n    else hM . put ( sum , i ) ;\n  }\n  return max_len ;\n}\n", "PROGRAM_PRINT_SUM_GIVEN_NTH_TERM_1": "static int summingSeries ( long n ) {\n  return ( int ) Math . pow ( n , 2 ) ;\n}\n", "RECURSIVE_C_PROGRAM_LINEARLY_SEARCH_ELEMENT_GIVEN_ARRAY": "static 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": "static void printPath ( String str ) {\n  int i = 0 ;\n  int curX = 0 , curY = 0 ;\n  while ( i < str . length ( ) ) {\n    int nextX = ( str . charAt ( i ) - 'A' ) / 5 ;\n    int nextY = ( str . charAt ( i ) - 'B' + 1 ) % 5 ;\n    while ( curX > nextX ) {\n      System . out . println ( \"Move Up\" ) ;\n      curX -- ;\n    }\n    while ( curY > nextY ) {\n      System . out . println ( \"Move Left\" ) ;\n      curY -- ;\n    }\n    while ( curX < nextX ) {\n      System . out . println ( \"Move Down\" ) ;\n      curX ++ ;\n    }\n    while ( curY < nextY ) {\n      System . out . println ( \"Move Right\" ) ;\n      curY ++ ;\n    }\n    System . out . println ( \"Press OK\" ) ;\n    i ++ ;\n  }\n}\n", "COUNT_ENTRIES_EQUAL_TO_X_IN_A_SPECIAL_MATRIX": "static 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": "static void lineFromPoints ( Pair P , Pair Q ) {\n  int a = Q . second - P . second ;\n  int b = P . first - Q . first ;\n  int c = a * ( P . first ) + b * ( P . second ) ;\n  if ( b < 0 ) {\n    System . out . println ( \"The line passing through points P and Q is: \" + a + \"x \" + b + \"y = \" + c ) ;\n  }\n  else {\n    System . out . println ( \"The line passing through points P and Q is: \" + a + \"x + \" + b + \"y = \" + c ) ;\n  }\n}\n", "REMOVE_ARRAY_END_ELEMENT_MAXIMIZE_SUM_PRODUCT": "static int solve ( int dp [ ] [ ] , int a [ ] , int low , int high , int turn ) {\n  if ( low == high ) {\n    return a [ low ] * turn ;\n  }\n  if ( dp [ low ] [ high ] != 0 ) {\n    return dp [ low ] [ high ] ;\n  }\n  dp [ low ] [ high ] = Math . 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": "public static boolean containsOdd ( int G [ ] [ ] , int src ) {\n  int colorArr [ ] = new int [ V ] ;\n  for ( int i = 0 ;\n  i < V ;\n  ++ i ) colorArr [ i ] = - 1 ;\n  colorArr [ src ] = 1 ;\n  LinkedList < Integer > q = new LinkedList < Integer > ( ) ;\n  q . add ( src ) ;\n  while ( ! q . isEmpty ( ) ) {\n    int u = q . peek ( ) ;\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 ] == 1 && colorArr [ v ] == - 1 ) {\n        colorArr [ v ] = 1 - colorArr [ u ] ;\n        q . push ( v ) ;\n      }\n      else if ( G [ u ] [ v ] == 1 && colorArr [ v ] == colorArr [ u ] ) return true ;\n    }\n  }\n  return false ;\n}\n", "SUM_SERIES_ALTERNATE_SIGNED_SQUARES_AP": "static int seiresSum ( int n , int [ ] a ) {\n  int res = 0 , i ;\n  for ( 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": "static void decToBinary ( int n ) {\n  int [ ] binaryNum = new int [ 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 -- ) System . out . print ( binaryNum [ j ] ) ;\n}\n", "LONGEST_ALTERNATING_POSITIVE_NEGATIVE_SUBARRAY_STARTING_EVERY_INDEX": "public static void longestAlternating ( int arr [ ] , int n ) {\n  int [ ] count = new int [ 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 ++ ) System . out . print ( count [ i ] + \" \" ) ;\n}\n", "FIND_STRING_LEXICOGRAPHIC_ORDER_GIVEN_TWO_STRINGS": "static String lexNext ( String str , int n ) {\n  char [ ] s = str . toCharArray ( ) ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    if ( s [ i ] != 'z' ) {\n      s [ i ] ++ ;\n      return String . valueOf ( s ) ;\n    }\n    s [ i ] = 'a' ;\n  }\n  return null ;\n}\n", "NUMBER_DECIMAL_NUMBERS_LENGTH_K_STRICT_MONOTONE": "static int getNumStrictMonotone ( int len ) {\n  int [ ] [ ] DP = new int [ len ] [ DP_s ] ;\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": "static void constructTree ( int n , int d , int h ) {\n  if ( d == 1 ) {\n    if ( n == 2 && h == 1 ) {\n      System . out . println ( \"1 2\" ) ;\n      return ;\n    }\n    System . out . println ( \"-1\" ) ;\n    return ;\n  }\n  if ( d > 2 * h ) {\n    System . out . println ( \"-1\" ) ;\n    return ;\n  }\n  for ( int i = 1 ;\n  i <= h ;\n  i ++ ) System . out . println ( i + \" \" + ( i + 1 ) ) ;\n  if ( d > h ) {\n    System . out . println ( \"1\" + \" \" + ( h + 2 ) ) ;\n    for ( int i = h + 2 ;\n    i <= d ;\n    i ++ ) {\n      System . out . println ( i + \" \" + ( i + 1 ) ) ;\n    }\n  }\n  for ( int i = d + 1 ;\n  i < n ;\n  i ++ ) {\n    int k = 1 ;\n    if ( d == h ) k = 2 ;\n    System . out . println ( k + \" \" + ( i + 1 ) ) ;\n  }\n}\n", "MINIMAL_OPERATIONS_MAKE_NUMBER_MAGICAL": "static 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 . charAt ( 0 ) - '0' ) c ++ ;\n                if ( j != s . charAt ( 1 ) - '0' ) c ++ ;\n                if ( k != s . charAt ( 2 ) - '0' ) c ++ ;\n                if ( l != s . charAt ( 3 ) - '0' ) c ++ ;\n                if ( m != s . charAt ( 4 ) - '0' ) c ++ ;\n                if ( n != s . charAt ( 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": "boolean 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          System . out . print ( \"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": "static float getArea ( int a ) {\n  float area = ( float ) ( Math . PI * a * a ) / 4 ;\n  return area ;\n}\n", "GIVEN_TWO_UNSORTED_ARRAYS_FIND_PAIRS_WHOSE_SUM_X_1": "public static void findPairs ( int arr1 [ ] , int arr2 [ ] , int n , int m , int x ) {\n  HashMap < Integer , Integer > s = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) s . put ( arr1 [ i ] , 0 ) ;\n  for ( int j = 0 ;\n  j < m ;\n  j ++ ) if ( s . containsKey ( x - arr2 [ j ] ) ) System . out . println ( x - arr2 [ j ] + \" \" + arr2 [ j ] ) ;\n}\n", "QUICK_WAY_CHECK_CHARACTERS_STRING": "static boolean allCharactersSame ( String s ) {\n  int n = s . length ( ) ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) if ( s . charAt ( i ) != s . charAt ( 0 ) ) return false ;\n  return true ;\n}\n", "REARRANGE_ARRAY_ARRI": "public static int [ ] fix ( int [ ] A ) {\n  for ( int i = 0 ;\n  i < A . length ;\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  return A ;\n}\n", "PAIR_WITH_GIVEN_PRODUCT_SET_1_FIND_IF_ANY_PAIR_EXISTS": "boolean isProduct ( int arr [ ] , int n , int x ) {\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 ] == x ) return true ;\n  return false ;\n}\n", "SORT_GIVEN_STRING_USING_CHARACTER_SEARCH": "static 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 . charAt ( j ) == i ) new_str += str . charAt ( j ) ;\n  return new_str ;\n}\n", "COUNT_OF_OCCURRENCES_OF_A_101_PATTERN_IN_A_STRING": "static int countPattern ( String str ) {\n  int len = str . length ( ) ;\n  boolean oneSeen = false ;\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < len ;\n  i ++ ) {\n    char getChar = str . charAt ( i ) ;\n    if ( getChar == '1' && oneSeen == true ) {\n      if ( str . charAt ( i - 1 ) == '0' ) count ++ ;\n    }\n    if ( getChar == '1' && oneSeen == false ) oneSeen = true ;\n    if ( getChar != '0' && str . charAt ( i ) != '1' ) oneSeen = false ;\n  }\n  return count ;\n}\n", "C_PROGRAM_CYCLICALLY_ROTATE_ARRAY_ONE": "static void rotate ( ) {\n  int x = arr [ arr . length - 1 ] , i ;\n  for ( i = arr . length - 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": "static void firstNonRepeating ( String str ) {\n  int [ ] charCount = new int [ MAX_CHAR ] ;\n  Queue < Character > q = new LinkedList < Character > ( ) ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    char ch = str . charAt ( i ) ;\n    q . add ( ch ) ;\n    charCount [ ch - 'a' ] ++ ;\n    while ( ! q . isEmpty ( ) ) {\n      if ( charCount [ q . peek ( ) - 'a' ] > 1 ) q . remove ( ) ;\n      else {\n        System . out . print ( q . peek ( ) + \" \" ) ;\n        break ;\n      }\n    }\n    if ( q . isEmpty ( ) ) System . out . print ( - 1 + \" \" ) ;\n  }\n  System . out . println ( ) ;\n}\n", "CHECK_LARGE_NUMBER_DIVISIBLE_6_NOT": "static boolean check ( String str ) {\n  int n = str . length ( ) ;\n  if ( ( str . charAt ( n - 1 ) - '0' ) % 2 != 0 ) return false ;\n  int digitSum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) digitSum += ( str . charAt ( i ) - '0' ) ;\n  return ( digitSum % 3 == 0 ) ;\n}\n", "MINIMUM_NUMBER_OF_SQUARES_WHOSE_SUM_EQUALS_TO_GIVEN_NUMBER_N": "static int getMinSquares ( int n ) {\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 = Math . min ( res , 1 + getMinSquares ( n - temp ) ) ;\n  }\n  return res ;\n}\n", "OVERLAPPING_SUM_TWO_ARRAY": "static int findSum ( int [ ] A , int [ ] B , int n ) {\n  HashMap < Integer , Integer > hash = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( hash . containsKey ( A [ i ] ) ) hash . put ( A [ i ] , 1 + hash . get ( A [ i ] ) ) ;\n    else hash . put ( A [ i ] , 1 ) ;\n    if ( hash . containsKey ( B [ i ] ) ) hash . put ( B [ i ] , 1 + hash . get ( B [ i ] ) ) ;\n    else hash . put ( B [ i ] , 1 ) ;\n  }\n  int sum = 0 ;\n  for ( Map . Entry entry : hash . entrySet ( ) ) {\n    if ( Integer . parseInt ( ( entry . getValue ( ) ) . toString ( ) ) == 1 ) sum += Integer . parseInt ( ( entry . getKey ( ) ) . toString ( ) ) ;\n  }\n  return sum ;\n}\n", "MOBILE_NUMERIC_KEYPAD_PROBLEM": "static int getCount ( char keypad [ ] [ ] , int n ) {\n  if ( keypad == null || n <= 0 ) return 0 ;\n  if ( n == 1 ) return 10 ;\n  int [ ] odd = new int [ 10 ] ;\n  int [ ] even = new int [ 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": "static void findLarger ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  for ( int i = n - 1 ;\n  i >= n / 2 ;\n  i -- ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "SUM_BINOMIAL_COEFFICIENTS": "static int binomialCoeffSum ( int n ) {\n  int C [ ] [ ] = new int [ n + 1 ] [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j <= Math . 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": "static int findCommon ( int mat [ ] [ ] ) {\n  HashMap < Integer , Integer > cnt = new HashMap < Integer , Integer > ( ) ;\n  int i , j ;\n  for ( i = 0 ;\n  i < M ;\n  i ++ ) {\n    if ( cnt . containsKey ( mat [ i ] [ 0 ] ) ) {\n      cnt . put ( mat [ i ] [ 0 ] , cnt . get ( mat [ i ] [ 0 ] ) + 1 ) ;\n    }\n    else {\n      cnt . put ( mat [ i ] [ 0 ] , 1 ) ;\n    }\n    for ( j = 1 ;\n    j < N ;\n    j ++ ) {\n      if ( mat [ i ] [ j ] != mat [ i ] [ j - 1 ] ) if ( cnt . containsKey ( mat [ i ] [ j ] ) ) {\n        cnt . put ( mat [ i ] [ j ] , cnt . get ( mat [ i ] [ j ] ) + 1 ) ;\n      }\n      else {\n        cnt . put ( mat [ i ] [ j ] , 1 ) ;\n      }\n    }\n  }\n  for ( Map . Entry < Integer , Integer > ele : cnt . entrySet ( ) ) {\n    if ( ele . getValue ( ) == M ) return ele . getKey ( ) ;\n  }\n  return - 1 ;\n}\n", "SIEVE_ERATOSTHENES_0N_TIME_COMPLEXITY": "static void manipulated_seive ( int N ) {\n  isprime . set ( 0 , false ) ;\n  isprime . set ( 1 , false ) ;\n  for ( int i = 2 ;\n  i < N ;\n  i ++ ) {\n    if ( isprime . get ( i ) ) {\n      prime . add ( i ) ;\n      SPF . set ( i , i ) ;\n    }\n    for ( int j = 0 ;\n    j < prime . size ( ) && i * prime . get ( j ) < N && prime . get ( j ) <= SPF . get ( i ) ;\n    j ++ ) {\n      isprime . set ( i * prime . get ( j ) , false ) ;\n      SPF . set ( i * prime . get ( j ) , prime . get ( j ) ) ;\n    }\n  }\n}\n", "COUNT_SORTED_ROWS_MATRIX": "static int sortedCount ( int mat [ ] [ ] , 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": "static int numOfways ( int n , int k ) {\n  int p = 1 ;\n  if ( k % 2 != 0 ) p = - 1 ;\n  return ( int ) ( Math . pow ( n - 1 , k ) + p * ( n - 1 ) ) / n ;\n}\n", "DICE_THROW_PROBLEM": "public static long findWays ( int m , int n , int x ) {\n  long [ ] [ ] table = new long [ n + 1 ] [ x + 1 ] ;\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 ++ ) {\n    for ( int j = 1 ;\n    j <= x ;\n    j ++ ) {\n      for ( int k = 1 ;\n      k < j && k <= m ;\n      k ++ ) table [ i ] [ j ] += table [ i - 1 ] [ j - k ] ;\n    }\n  }\n  return table [ n ] [ x ] ;\n}\n", "MINIMUM_NUMBER_DELETIONS_MAKE_STRING_PALINDROME_SET_2": "static int getLevenstein ( StringBuilder input ) {\n  StringBuilder revInput = new StringBuilder ( input ) ;\n  revInput = revInput . reverse ( ) ;\n  int n = input . length ( ) ;\n  int [ ] [ ] dp = new int [ n + 1 ] [ n + 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 . charAt ( i - 1 ) == revInput . charAt ( j - 1 ) ) dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] ;\n      else dp [ i ] [ j ] = 1 + Math . min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) ;\n    }\n  }\n  int res = Integer . MAX_VALUE ;\n  for ( int i = n , j = 0 ;\n  i >= 0 ;\n  i -- , j ++ ) {\n    res = Math . min ( res , dp [ i ] [ j ] ) ;\n    if ( i < n ) res = Math . min ( res , dp [ i + 1 ] [ j ] ) ;\n    if ( i > 0 ) res = Math . min ( res , dp [ i - 1 ] [ j ] ) ;\n  }\n  return res ;\n}\n", "DYNAMIC_PROGRAMMING_SET_37_BOOLEAN_PARENTHESIZATION_PROBLEM": "static int countParenth ( char symb [ ] , char oper [ ] , int n ) {\n  int F [ ] [ ] = new int [ n ] [ n ] ;\n  int T [ ] [ ] = new int [ 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": "static int Circumference ( int l , int w ) {\n  return ( 2 * ( l + w ) ) ;\n}\n", "THIRD_LARGEST_ELEMENT_ARRAY_DISTINCT_ELEMENTS_1": "static void thirdLargest ( int arr [ ] , int arr_size ) {\n  if ( arr_size < 3 ) {\n    System . out . printf ( \" Invalid Input \" ) ;\n    return ;\n  }\n  int first = arr [ 0 ] , second = Integer . MIN_VALUE , third = Integer . MIN_VALUE ;\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 ) {\n      third = arr [ i ] ;\n    }\n  }\n  System . out . printf ( \"The third Largest element is %d\\n\" , third ) ;\n}\n", "MINIMUM_ROOMS_FOR_M_EVENTS_OF_N_BATCHES_WITH_GIVEN_SCHEDULE": "static int findMinRooms ( String slots [ ] , int n , int m ) {\n  int counts [ ] = new int [ m ] ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) counts [ i ] = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = 0 ;\n  j < m ;\n  j ++ ) if ( slots [ i ] . charAt ( j ) == '1' ) counts [ j ] ++ ;\n  int max = - 1 ;\n  for ( int i = 0 ;\n  i < m ;\n  i ++ ) if ( max < counts [ i ] ) max = counts [ i ] ;\n  return max ;\n}\n", "DYNAMIC_PROGRAMMING_SUBSET_SUM_PROBLEM": "static boolean 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": "static int chordCnt ( int A ) {\n  int n = 2 * A ;\n  int [ ] dpArray = new int [ n + 1 ] ;\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": "static long count_of_ways ( long n ) {\n  long count = 0 ;\n  count = ( n + 1 ) * ( n + 2 ) / 2 ;\n  return count ;\n}\n", "PRINT_DIGITS_POSITION_REMOVED_MAKE_NUMBER_DIVISIBLE_6": "static void greatest ( String s ) {\n  int n = s . length ( ) ;\n  int [ ] a = new int [ n ] ;\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    a [ i ] = s . charAt ( i ) - '0' ;\n    sum += a [ i ] ;\n  }\n  if ( a [ n - 1 ] % 2 != 0 ) {\n    if ( a [ n - 2 ] % 2 != 0 || ( sum - a [ n - 1 ] ) % 3 != 0 ) {\n      System . out . println ( \"-1\" ) ;\n    }\n    else {\n      System . out . println ( n ) ;\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 && re == a [ n - 1 ] % 3 ) del = n - 1 ;\n    }\n    if ( del == - 1 ) System . out . println ( - 1 ) ;\n    else {\n      System . out . println ( del + 1 ) ;\n    }\n  }\n}\n", "MAXIMUM_HEIGHT_OF_TRIANGULAR_ARRANGEMENT_OF_ARRAY_VALUES": "static int MaximumHeight ( int [ ] a , int n ) {\n  int result = 1 ;\n  for ( int i = 1 ;\n  i <= n ;\n  ++ i ) {\n    int 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": "static 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": "static int evaluateBoolExpr ( StringBuffer s ) {\n  int n = s . length ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i += 2 ) {\n    if ( i + 1 < n && i + 2 < n ) {\n      if ( s . charAt ( i + 1 ) == 'A' ) {\n        if ( s . charAt ( i + 2 ) == '0' || s . charAt ( i ) == 0 ) s . setCharAt ( i + 2 , '0' ) ;\n        else s . setCharAt ( i + 2 , '1' ) ;\n      }\n      else if ( ( i + 1 ) < n && s . charAt ( i + 1 ) == 'B' ) {\n        if ( s . charAt ( i + 2 ) == '1' || s . charAt ( i ) == '1' ) s . setCharAt ( i + 2 , '1' ) ;\n        else s . setCharAt ( i + 2 , '0' ) ;\n      }\n      else {\n        if ( s . charAt ( i + 2 ) == s . charAt ( i ) ) s . setCharAt ( i + 2 , '0' ) ;\n        else s . setCharAt ( i + 2 , '1' ) ;\n      }\n    }\n  }\n  return s . charAt ( n - 1 ) - '0' ;\n}\n", "PROGRAMMING_PUZZLE_ASSIGN_VALUE_WITHOUT_CONTROL_STATEMENT": "static int assignValue ( int a , int b , int x ) {\n  int arr [ ] = {\n    a , b };\n    return ( arr [ x ] ) ;\n  }\n  ", "MINIMUM_SUM_SQUARES_CHARACTERS_COUNTS_GIVEN_STRING_REMOVING_K_CHARACTERS": "static int minStringValue ( String str , int k ) {\n  int l = str . length ( ) ;\n  if ( k >= l ) return 0 ;\n  int [ ] frequency = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < l ;\n  i ++ ) frequency [ str . charAt ( i ) - 'a' ] ++ ;\n  Comparator < Integer > c = new IntCompare ( ) ;\n  PriorityQueue < Integer > q = new PriorityQueue < > ( c ) ;\n  for ( int i = 0 ;\n  i < MAX_CHAR ;\n  i ++ ) {\n    if ( frequency [ i ] != 0 ) q . add ( frequency [ i ] ) ;\n  }\n  while ( k != 0 ) {\n    int temp = q . peek ( ) ;\n    q . poll ( ) ;\n    temp = temp - 1 ;\n    q . add ( temp ) ;\n    k -- ;\n  }\n  int result = 0 ;\n  while ( ! q . isEmpty ( ) ) {\n    int temp = q . peek ( ) ;\n    result += temp * temp ;\n    q . poll ( ) ;\n  }\n  return result ;\n}\n", "MAJORITY_ELEMENT_1": "private static void findMajority ( int [ ] arr ) {\n  HashMap < Integer , Integer > map = new HashMap < Integer , Integer > ( ) ;\n  for ( int i = 0 ;\n  i < arr . length ;\n  i ++ ) {\n    if ( map . containsKey ( arr [ i ] ) ) {\n      int count = map . get ( arr [ i ] ) + 1 ;\n      if ( count > arr . length / 2 ) {\n        System . out . println ( \"Majority found :- \" + arr [ i ] ) ;\n        return ;\n      }\n      else map . put ( arr [ i ] , count ) ;\n    }\n    else map . put ( arr [ i ] , 1 ) ;\n  }\n  System . out . println ( \" No Majority element\" ) ;\n}\n", "LARGEST_SUBSET_GRAPH_VERTICES_EDGES_2_COLORS": "static int subsetGraph ( int C [ ] [ ] ) {\n  HashSet < Integer > vertices = new HashSet < > ( ) ;\n  for ( int i = 0 ;\n  i < N ;\n  ++ i ) {\n    vertices . add ( i ) ;\n  }\n  while ( ! vertices . isEmpty ( ) ) {\n    if ( vertices . size ( ) == 1 ) {\n      return 1 ;\n    }\n    boolean someone_removed = false ;\n    for ( int x : vertices ) {\n      HashSet < Integer > values = new HashSet < > ( ) ;\n      for ( int y : vertices ) {\n        if ( y != x ) {\n          values . add ( C [ x ] [ y ] ) ;\n        }\n      }\n      if ( values . size ( ) == 1 ) {\n        vertices . remove ( x ) ;\n        someone_removed = true ;\n        break ;\n      }\n    }\n    if ( ! someone_removed ) {\n      break ;\n    }\n  }\n  return ( vertices . size ( ) ) ;\n}\n", "FLOOR_IN_A_SORTED_ARRAY_1": "static 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": "static int longestPrefixSuffix ( String s ) {\n  int n = s . length ( ) ;\n  int lps [ ] = new int [ n ] ;\n  lps [ 0 ] = 0 ;\n  int len = 0 ;\n  int i = 1 ;\n  while ( i < n ) {\n    if ( s . charAt ( i ) == s . charAt ( 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": "public static 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": "public static int findRepeatFirst ( String s ) {\n  int p = - 1 , i , k ;\n  int MAX_CHAR = 256 ;\n  int hash [ ] = new int [ MAX_CHAR ] ;\n  int pos [ ] = new int [ MAX_CHAR ] ;\n  for ( i = 0 ;\n  i < s . length ( ) ;\n  i ++ ) {\n    k = ( int ) s . charAt ( 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": "static 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": "static int kthLargestSum ( int arr [ ] , int n , int k ) {\n  int sum [ ] = new int [ 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  PriorityQueue < Integer > Q = new PriorityQueue < Integer > ( ) ;\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 . add ( x ) ;\n      else {\n        if ( Q . peek ( ) < x ) {\n          Q . poll ( ) ;\n          Q . add ( x ) ;\n        }\n      }\n    }\n  }\n  return Q . poll ( ) ;\n}\n", "FIND_THE_LARGEST_THREE_ELEMENTS_IN_AN_ARRAY": "void find3largest ( int [ ] arr ) {\n  Arrays . sort ( arr ) ;\n  int n = arr . length ;\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        System . out . print ( arr [ n - i ] + \" \" ) ;\n        check = arr [ n - i ] ;\n        count ++ ;\n      }\n    }\n    else break ;\n  }\n}\n", "MAXIMUM_DISTINCT_LOWERCASE_ALPHABETS_TWO_UPPERCASE": "static int maxLower ( String str ) {\n  int n = str . length ( ) ;\n  int i = 0 ;\n  for ( ;\n  i < n ;\n  i ++ ) {\n    if ( str . charAt ( i ) >= 'A' && str . charAt ( i ) <= 'Z' ) {\n      i ++ ;\n      break ;\n    }\n  }\n  int maxCount = 0 ;\n  int count [ ] = new int [ MAX_CHAR ] ;\n  for ( ;\n  i < n ;\n  i ++ ) {\n    if ( str . charAt ( i ) >= 'A' && str . charAt ( i ) <= 'Z' ) {\n      int currCount = 0 ;\n      for ( int j = 0 ;\n      j < MAX_CHAR ;\n      j ++ ) {\n        if ( count [ j ] > 0 ) {\n          currCount ++ ;\n        }\n      }\n      maxCount = Math . max ( maxCount , currCount ) ;\n      Arrays . fill ( count , 0 ) ;\n    }\n    if ( str . charAt ( i ) >= 'a' && str . charAt ( i ) <= 'z' ) {\n      count [ str . charAt ( i ) - 'a' ] ++ ;\n    }\n  }\n  return maxCount ;\n}\n", "CHECK_IF_A_STRING_HAS_ALL_CHARACTERS_WITH_SAME_FREQUENCY_WITH_ONE_VARIATION_ALLOWED": "static boolean isValidString ( String str ) {\n  int freq [ ] = new int [ CHARS ] ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    freq [ str . charAt ( i ) - 'a' ] ++ ;\n  }\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 ) {\n        count_freq1 ++ ;\n      }\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 ) {\n        count_freq1 ++ ;\n      }\n      if ( freq [ k ] == freq2 ) {\n        count_freq2 ++ ;\n      }\n      else {\n        return false ;\n      }\n    }\n    if ( count_freq1 > 1 && count_freq2 > 1 ) {\n      return false ;\n    }\n  }\n  return true ;\n}\n", "MAXIMUM_AVERAGE_SUM_PARTITION_ARRAY": "static double largestSumOfAverages ( int [ ] A , int K ) {\n  int n = A . length ;\n  double [ ] pre_sum = new double [ 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 = new double [ n ] ;\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 ] = Math . 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": "public static void subArraySum ( int [ ] arr , int n , int sum ) {\n  int cur_sum = 0 ;\n  int start = 0 ;\n  int end = - 1 ;\n  HashMap < Integer , Integer > hashMap = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    cur_sum = cur_sum + arr [ i ] ;\n    if ( cur_sum - sum == 0 ) {\n      start = 0 ;\n      end = i ;\n      break ;\n    }\n    if ( hashMap . containsKey ( cur_sum - sum ) ) {\n      start = hashMap . get ( cur_sum - sum ) + 1 ;\n      end = i ;\n      break ;\n    }\n    hashMap . put ( cur_sum , i ) ;\n  }\n  if ( end == - 1 ) {\n    System . out . println ( \"No subarray with given sum exists\" ) ;\n  }\n  else {\n    System . out . println ( \"Sum found between indexes \" + start + \" to \" + end ) ;\n  }\n}\n", "REMOVE_MINIMUM_ELEMENTS_EITHER_SIDE_2MIN_MAX": "static 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 = Integer . MAX_VALUE , max = Integer . MIN_VALUE ;\n    for ( int end = start ;\n    end < n ;\n    end ++ ) {\n      int val = arr [ end ] ;\n      if ( val < min ) {\n        min = val ;\n      }\n      if ( val > max ) {\n        max = val ;\n      }\n      if ( 2 * min <= max ) {\n        break ;\n      }\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 ) {\n    return n ;\n  }\n  return ( n - ( longest_end - longest_start + 1 ) ) ;\n}\n", "FIND_THE_MISSING_NUMBER_1": "static int getMissingNo ( int a [ ] , int n ) {\n  int total = 1 ;\n  for ( int 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": "static int SieveOfSundaram ( int n ) {\n  int nNew = ( n - 2 ) / 2 ;\n  boolean marked [ ] = new boolean [ nNew + 1 ] ;\n  Arrays . fill ( marked , false ) ;\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 ) System . out . print ( 2 + \" \" ) ;\n  for ( int i = 1 ;\n  i <= nNew ;\n  i ++ ) if ( marked [ i ] == false ) System . out . print ( 2 * i + 1 + \" \" ) ;\n  return - 1 ;\n}\n", "MAXIMUM_PRODUCT_SUBSET_ARRAY": "static int maxProductSubset ( int a [ ] , int n ) {\n  if ( n == 1 ) {\n    return a [ 0 ] ;\n  }\n  int max_neg = Integer . MIN_VALUE ;\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 = Math . max ( max_neg , a [ i ] ) ;\n    }\n    prod = prod * a [ i ] ;\n  }\n  if ( count_zero == n ) {\n    return 0 ;\n  }\n  if ( count_neg % 2 == 1 ) {\n    if ( count_neg == 1 && count_zero > 0 && count_zero + count_neg == n ) {\n      return 0 ;\n    }\n    prod = prod / max_neg ;\n  }\n  return prod ;\n}\n", "FIND_THE_NEAREST_SMALLER_NUMBERS_ON_LEFT_SIDE_IN_AN_ARRAY": "static void printPrevSmaller ( int [ ] arr , int n ) {\n  System . out . print ( \"_, \" ) ;\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        System . out . print ( arr [ j ] + \", \" ) ;\n        break ;\n      }\n    }\n    if ( j == - 1 ) System . out . print ( \"_, \" ) ;\n  }\n}\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0_1": "static int calculate ( int a [ ] , int n ) {\n  int maximum = Arrays . stream ( a ) . max ( ) . getAsInt ( ) ;\n  int frequency [ ] = new int [ maximum + 1 ] ;\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": "static int binomialCoeffSum ( int n ) {\n  return ( 1 << n ) ;\n}\n", "MAXIMUM_SUM_PAIRS_SPECIFIC_DIFFERENCE_1": "static int maxSumPairWithDifferenceLessThanK ( int arr [ ] , int N , int k ) {\n  int maxSum = 0 ;\n  Arrays . sort ( arr ) ;\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": "static void printkthnode ( Vector < pair > adj [ ] , int wt [ ] , int n , int k ) {\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) Collections . sort ( adj [ i ] , new Comparator < pair > ( ) {\n    public int compare ( pair p1 , pair p2 ) {\n      return p1 . first - p2 . first ;\n    }\n  }\n  ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( adj [ i ] . size ( ) >= k ) System . out . print ( adj [ i ] . get ( adj [ i ] . size ( ) - k ) . second + \" \" ) ;\n    else System . out . print ( \"-1\" ) ;\n  }\n}\n", "SPACE_OPTIMIZED_DP_SOLUTION_0_1_KNAPSACK_PROBLEM": "static int KnapSack ( int val [ ] , int wt [ ] , int n , int W ) {\n  int mat [ ] [ ] = new int [ 2 ] [ W + 1 ] ;\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 ) {\n          mat [ 1 ] [ j ] = Math . max ( val [ i ] + mat [ 0 ] [ j - wt [ i ] ] , mat [ 0 ] [ j ] ) ;\n        }\n        else {\n          mat [ 1 ] [ j ] = mat [ 0 ] [ j ] ;\n        }\n      }\n    }\n    else {\n      while ( ++ j <= W ) {\n        if ( wt [ i ] <= j ) {\n          mat [ 0 ] [ j ] = Math . max ( val [ i ] + mat [ 1 ] [ j - wt [ i ] ] , mat [ 1 ] [ j ] ) ;\n        }\n        else {\n          mat [ 0 ] [ j ] = mat [ 1 ] [ j ] ;\n        }\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": "static void bin ( Integer n ) {\n  if ( n > 1 ) bin ( n >> 1 ) ;\n  System . out . printf ( \"%d\" , n & 1 ) ;\n}\n", "PRIME_FACTORS_BIG_NUMBER": "static void factorize ( long n ) {\n  int count = 0 ;\n  while ( ! ( n % 2 > 0 ) ) {\n    n >>= 1 ;\n    count ++ ;\n  }\n  if ( count > 0 ) {\n    System . out . println ( \"2\" + \" \" + count ) ;\n  }\n  for ( long i = 3 ;\n  i <= ( long ) Math . sqrt ( n ) ;\n  i += 2 ) {\n    count = 0 ;\n    while ( n % i == 0 ) {\n      count ++ ;\n      n = n / i ;\n    }\n    if ( count > 0 ) {\n      System . out . println ( i + \" \" + count ) ;\n    }\n  }\n  if ( n > 2 ) {\n    System . out . println ( n + \" \" + \"1\" ) ;\n  }\n}\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS_1": "static int countSubstringWithEqualEnds ( String s ) {\n  int result = 0 ;\n  int n = s . length ( ) ;\n  int [ ] count = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) count [ s . charAt ( 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": "static void printSubStr ( String str , int low , int high ) {\n  System . out . println ( str . substring ( low , high + 1 ) ) ;\n}\n", "FIND_THE_SMALLEST_WINDOW_IN_A_STRING_CONTAINING_ALL_CHARACTERS_OF_ANOTHER_STRING": "static String findSubString ( String str , String pat ) {\n  int len1 = str . length ( ) ;\n  int len2 = pat . length ( ) ;\n  if ( len1 < len2 ) {\n    System . out . println ( \"No such window exists\" ) ;\n    return \"\" ;\n  }\n  int hash_pat [ ] = new int [ no_of_chars ] ;\n  int hash_str [ ] = new int [ no_of_chars ] ;\n  for ( int i = 0 ;\n  i < len2 ;\n  i ++ ) hash_pat [ pat . charAt ( i ) ] ++ ;\n  int start = 0 , start_index = - 1 , min_len = Integer . MAX_VALUE ;\n  int count = 0 ;\n  for ( int j = 0 ;\n  j < len1 ;\n  j ++ ) {\n    hash_str [ str . charAt ( j ) ] ++ ;\n    if ( hash_pat [ str . charAt ( j ) ] != 0 && hash_str [ str . charAt ( j ) ] <= hash_pat [ str . charAt ( j ) ] ) count ++ ;\n    if ( count == len2 ) {\n      while ( hash_str [ str . charAt ( start ) ] > hash_pat [ str . charAt ( start ) ] || hash_pat [ str . charAt ( start ) ] == 0 ) {\n        if ( hash_str [ str . charAt ( start ) ] > hash_pat [ str . charAt ( start ) ] ) hash_str [ str . charAt ( 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    System . out . println ( \"No such window exists\" ) ;\n    return \"\" ;\n  }\n  return str . substring ( start_index , start_index + min_len ) ;\n}\n", "MARKOV_MATRIX": "static boolean checkMarkov ( double m [ ] [ ] ) {\n  for ( int i = 0 ;\n  i < m . length ;\n  i ++ ) {\n    double sum = 0 ;\n    for ( int j = 0 ;\n    j < m [ i ] . length ;\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": "static void leafNode ( int preorder [ ] , int n ) {\n  Stack < Integer > s = new Stack < Integer > ( ) ;\n  for ( int i = 0 , j = 1 ;\n  j < n ;\n  i ++ , j ++ ) {\n    boolean found = false ;\n    if ( preorder [ i ] > preorder [ j ] ) s . push ( preorder [ i ] ) ;\n    else {\n      while ( ! s . isEmpty ( ) ) {\n        if ( preorder [ j ] > s . peek ( ) ) {\n          s . pop ( ) ;\n          found = true ;\n        }\n        else break ;\n      }\n    }\n    if ( found ) System . out . print ( preorder [ i ] + \" \" ) ;\n  }\n  System . out . println ( preorder [ n - 1 ] ) ;\n}\n", "SMALLEST_POWER_OF_2_GREATER_THAN_OR_EQUAL_TO_N": "static int nextPowerOf2 ( int n ) {\n  int count = 0 ;\n  if ( n > 0 && ( n & ( n - 1 ) ) == 0 ) 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": "static void overflow ( int H , int r , int h , int N , int R ) {\n  double tank_cap = 3.14 * r * r * H ;\n  double water_vol = 3.14 * r * r * h ;\n  double balls_vol = N * ( 4 / 3 ) * 3.14 * R * R * R ;\n  double vol = water_vol + balls_vol ;\n  if ( vol > tank_cap ) {\n    System . out . println ( \"Overflow\" ) ;\n  }\n  else {\n    System . out . println ( \"Not in overflow state\" ) ;\n  }\n}\n", "SMALLEST_DERANGEMENT_SEQUENCE": "static void generate_derangement ( int N ) {\n  int S [ ] = new int [ N + 1 ] ;\n  for ( int i = 1 ;\n  i <= N ;\n  i ++ ) S [ i ] = i ;\n  int D [ ] = new int [ N + 1 ] ;\n  for ( int i = 1 ;\n  i <= N ;\n  i += 2 ) {\n    if ( i == N ) {\n      D [ N ] = S [ N - 1 ] ;\n      D [ N - 1 ] = S [ N ] ;\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 ++ ) System . out . print ( D [ i ] + \" \" ) ;\n  System . out . println ( ) ;\n}\n", "MAXIMUM_PRODUCT_INCREASING_SUBSEQUENCE": "static int lis ( int [ ] arr , int n ) {\n  int [ ] mpis = new int [ n ] ;\n  int max = Integer . MIN_VALUE ;\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  for ( int k = 0 ;\n  k < mpis . length ;\n  k ++ ) {\n    if ( mpis [ k ] > max ) {\n      max = mpis [ k ] ;\n    }\n  }\n  return max ;\n}\n", "CHANGE_BITS_CAN_MADE_ONE_FLIP": "static boolean canMakeAllSame ( String str ) {\n  int zeros = 0 , ones = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    char ch = str . charAt ( i ) ;\n    if ( ch == '0' ) ++ zeros ;\n    else ++ ones ;\n  }\n  return ( zeros == 1 || ones == 1 ) ;\n}\n", "FIND_NUMBER_PAIRS_ARRAY_XOR_0": "static int calculate ( int a [ ] , int n ) {\n  Arrays . sort ( a ) ;\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": "static int findRoot ( pair arr [ ] , int n ) {\n  int root = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    root += ( arr [ i ] . first - arr [ i ] . second ) ;\n  }\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": "static int findMinZero ( int p ) {\n  int first = 1 , second = 1 , number = 2 , next = 1 ;\n  while ( next > 0 ) {\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": "public static void kLargest ( Integer [ ] arr , int k ) {\n  Arrays . sort ( arr , Collections . reverseOrder ( ) ) ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) System . out . print ( arr [ i ] + \" \" ) ;\n}\n", "C_PROGRAM_FIND_AREA_CIRCLE": "static double findArea ( int r ) {\n  return PI * Math . pow ( r , 2 ) ;\n}\n", "SUM_TWO_LARGE_NUMBERS": "static String findSum ( String str1 , String str2 ) {\n  if ( str1 . length ( ) > str2 . length ( ) ) {\n    String t = str1 ;\n    str1 = str2 ;\n    str2 = t ;\n  }\n  String str = \"\" ;\n  int n1 = str1 . length ( ) , n2 = str2 . length ( ) ;\n  str1 = new StringBuilder ( str1 ) . reverse ( ) . toString ( ) ;\n  str2 = new StringBuilder ( str2 ) . reverse ( ) . toString ( ) ;\n  int carry = 0 ;\n  for ( int i = 0 ;\n  i < n1 ;\n  i ++ ) {\n    int sum = ( ( int ) ( str1 . charAt ( i ) - '0' ) + ( int ) ( str2 . charAt ( i ) - '0' ) + carry ) ;\n    str += ( char ) ( sum % 10 + '0' ) ;\n    carry = sum / 10 ;\n  }\n  for ( int i = n1 ;\n  i < n2 ;\n  i ++ ) {\n    int sum = ( ( int ) ( str2 . charAt ( i ) - '0' ) + carry ) ;\n    str += ( char ) ( sum % 10 + '0' ) ;\n    carry = sum / 10 ;\n  }\n  if ( carry > 0 ) str += ( char ) ( carry + '0' ) ;\n  str = new StringBuilder ( str ) . reverse ( ) . toString ( ) ;\n  return str ;\n}\n", "ARRAY_RANGE_QUERIES_ELEMENTS_FREQUENCY_VALUE": "static int solveQuery ( int start , int end , int arr [ ] ) {\n  Map < Integer , Integer > mp = new HashMap < > ( ) ;\n  for ( int i = start ;\n  i <= end ;\n  i ++ ) mp . put ( arr [ i ] , mp . get ( arr [ i ] ) == null ? 1 : mp . get ( arr [ i ] ) + 1 ) ;\n  int count = 0 ;\n  for ( Map . Entry < Integer , Integer > entry : mp . entrySet ( ) ) if ( entry . getKey ( ) == entry . getValue ( ) ) count ++ ;\n  return count ;\n}\n", "COUNT_SUBSTRINGS_WITH_SAME_FIRST_AND_LAST_CHARACTERS": "static 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 . charAt ( i ) == s . charAt ( j ) ) result ++ ;\n  return result ;\n}\n", "DYNAMIC_PROGRAMMING_HIGH_EFFORT_VS_LOW_EFFORT_TASKS_PROBLEM": "static int maxTasks ( int high [ ] , int low [ ] , int n ) {\n  if ( n <= 0 ) return 0 ;\n  return Math . 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": "static int maxRowDiff ( int mat [ ] [ ] , int m , int n ) {\n  int rowSum [ ] = new int [ 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": "static int minimumSquare ( int a , int b ) {\n  int result = 0 , rem = 0 ;\n  if ( a < b ) swap ( a , b ) ;\n  while ( b > 0 ) {\n    result += a / b ;\n    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": "static 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 + Math . abs ( arr [ i ] - x ) ;\n  }\n  System . out . println ( \"number is not\" + \" present!\" ) ;\n  return - 1 ;\n}\n", "PANGRAM_CHECKING": "public static boolean checkPangram ( String str ) {\n  boolean [ ] mark = new boolean [ 26 ] ;\n  int index = 0 ;\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( 'A' <= str . charAt ( i ) && str . charAt ( i ) <= 'Z' ) index = str . charAt ( i ) - 'A' ;\n    else if ( 'a' <= str . charAt ( i ) && str . charAt ( i ) <= 'z' ) index = str . charAt ( 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": "static String printShortestSuperSeq ( String X , String Y ) {\n  int m = X . length ( ) ;\n  int n = Y . length ( ) ;\n  int dp [ ] [ ] = new int [ 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 ) {\n        dp [ i ] [ j ] = j ;\n      }\n      else if ( j == 0 ) {\n        dp [ i ] [ j ] = i ;\n      }\n      else if ( X . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) {\n        dp [ i ] [ j ] = 1 + dp [ i - 1 ] [ j - 1 ] ;\n      }\n      else {\n        dp [ i ] [ j ] = 1 + Math . min ( dp [ i - 1 ] [ j ] , dp [ i ] [ j - 1 ] ) ;\n      }\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 . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) {\n      str += ( X . charAt ( i - 1 ) ) ;\n      i -- ;\n      j -- ;\n      index -- ;\n    }\n    else if ( dp [ i - 1 ] [ j ] > dp [ i ] [ j - 1 ] ) {\n      str += ( Y . charAt ( j - 1 ) ) ;\n      j -- ;\n      index -- ;\n    }\n    else {\n      str += ( X . charAt ( i - 1 ) ) ;\n      i -- ;\n      index -- ;\n    }\n  }\n  while ( i > 0 ) {\n    str += ( X . charAt ( i - 1 ) ) ;\n    i -- ;\n    index -- ;\n  }\n  while ( j > 0 ) {\n    str += ( Y . charAt ( j - 1 ) ) ;\n    j -- ;\n    index -- ;\n  }\n  str = reverse ( str ) ;\n  return str ;\n}\n", "FIND_PAIR_MAXIMUM_GCD_ARRAY_1": "public static int findMaxGCD ( int arr [ ] , int n ) {\n  int high = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) high = Math . max ( high , arr [ i ] ) ;\n  int count [ ] = new int [ high + 1 ] ;\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    while ( j <= high ) {\n      if ( count [ j ] > 0 ) counter += count [ j ] ;\n      j += i ;\n      if ( counter == 2 ) return i ;\n    }\n    counter = 0 ;\n  }\n  return 1 ;\n}\n", "PROGRAM_CALCULATE_AREA_OCTAGON": "static double areaOctagon ( double side ) {\n  return ( float ) ( 2 * ( 1 + Math . sqrt ( 2 ) ) * side * side ) ;\n}\n", "FIND_INDEX_OF_AN_EXTRA_ELEMENT_PRESENT_IN_ONE_SORTED_ARRAY_1": "static 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": "public static int nobleInteger ( int arr [ ] ) {\n  Arrays . sort ( arr ) ;\n  int n = arr . length ;\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": "static int maxSquare ( int b , int m ) {\n  return ( b / m - 1 ) * ( b / m ) / 2 ;\n}\n", "HOW_TO_COMPUTE_MOD_OF_A_BIG_NUMBER": "static 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 . charAt ( i ) - '0' ) % a ;\n  return res ;\n}\n", "LONGEST_COMMON_SUBSTRING_1": "static int lcs ( int i , int j , int count ) {\n  if ( i == 0 || j == 0 ) {\n    return count ;\n  }\n  if ( X . charAt ( i - 1 ) == Y . charAt ( j - 1 ) ) {\n    count = lcs ( i - 1 , j - 1 , count + 1 ) ;\n  }\n  count = Math . max ( count , Math . max ( lcs ( i , j - 1 , 0 ) , lcs ( i - 1 , j , 0 ) ) ) ;\n  return count ;\n}\n", "FIND_PATTERNS_101_GIVEN_STRING": "static int patternCount ( String str ) {\n  char last = str . charAt ( 0 ) ;\n  int i = 1 , counter = 0 ;\n  while ( i < str . length ( ) ) {\n    if ( str . charAt ( i ) == '0' && last == '1' ) {\n      while ( str . charAt ( i ) == '0' ) i ++ ;\n      if ( str . charAt ( i ) == '1' ) counter ++ ;\n    }\n    last = str . charAt ( i ) ;\n    i ++ ;\n  }\n  return counter ;\n}\n", "LONGEST_INCREASING_ODD_EVEN_SUBSEQUENCE": "public static int longOddEvenIncSeq ( int arr [ ] , int n ) {\n  int [ ] lioes = new int [ 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 res = 0 ;\n  int n = str . length ( ) ;\n  int cnt [ ] = new int [ 26 ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int dist_count = 0 ;\n    Arrays . fill ( cnt , 0 ) ;\n    for ( int j = i ;\n    j < n ;\n    j ++ ) {\n      if ( cnt [ str . charAt ( j ) - 'a' ] == 0 ) dist_count ++ ;\n      cnt [ str . charAt ( j ) - 'a' ] ++ ;\n      if ( dist_count == k ) res ++ ;\n    }\n  }\n  return res ;\n}\n", "C_PROGRAM_FACTORIAL_NUMBER_1": "static int factorial ( 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": "static void kmax ( int arr [ ] , int k , int n ) {\n  for ( int c = 0 ;\n  c < k ;\n  c ++ ) {\n    int max_so_far = Integer . MIN_VALUE ;\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    System . out . println ( \"Maximum non-overlapping sub-arraysum\" + ( c + 1 ) + \": \" + max_so_far + \", starting index: \" + start + \", ending index: \" + end + \".\" ) ;\n    for ( int l = start ;\n    l <= end ;\n    l ++ ) arr [ l ] = Integer . MIN_VALUE ;\n  }\n  System . out . println ( ) ;\n}\n", "DISTANCE_NEAREST_CELL_1_BINARY_MATRIX": "static void printDistance ( int mat [ ] [ ] ) {\n  int ans [ ] [ ] = new int [ N ] [ M ] ;\n  for ( int i = 0 ;\n  i < N ;\n  i ++ ) for ( int j = 0 ;\n  j < M ;\n  j ++ ) ans [ i ] [ j ] = Integer . MAX_VALUE ;\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 ] = Math . min ( ans [ i ] [ j ] , Math . abs ( i - k ) + Math . 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 ++ ) System . out . print ( ans [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "MINIMUM_NUMBER_OF_BRACKET_REVERSALS_NEEDED_TO_MAKE_AN_EXPRESSION_BALANCED": "static int countMinReversals ( String expr ) {\n  int len = expr . length ( ) ;\n  if ( len % 2 != 0 ) return - 1 ;\n  Stack < Character > s = new Stack < > ( ) ;\n  for ( int i = 0 ;\n  i < len ;\n  i ++ ) {\n    char c = expr . charAt ( i ) ;\n    if ( c == '}\n' && ! s . empty ( ) ) {\n      if ( s . peek ( ) == '{\n' ) s . pop ( ) ;\n        else s . push ( c ) ;\n      }\n      else s . push ( c ) ;\n    }\n    int red_len = s . size ( ) ;\n    int n = 0 ;\n    while ( ! s . empty ( ) && s . peek ( ) == '{\n' ) {\n        s . pop ( ) ;\n        n ++ ;\n      }\n      return ( red_len / 2 + n % 2 ) ;\n    }\n    public static void main ( String [ ] args ) {\n      String expr = \" }\n    }\n    ", "FIRST_NEGATIVE_INTEGER_EVERY_WINDOW_SIZE_K_1": "static void printFirstNegativeInteger ( int arr [ ] , int n , int k ) {\n  LinkedList < Integer > Di = new LinkedList < > ( ) ;\n  int i ;\n  for ( i = 0 ;\n  i < k ;\n  i ++ ) if ( arr [ i ] < 0 ) Di . add ( i ) ;\n  for ( ;\n  i < n ;\n  i ++ ) {\n    if ( ! Di . isEmpty ( ) ) System . out . print ( arr [ Di . peek ( ) ] + \" \" ) ;\n    else System . out . print ( \"0\" + \" \" ) ;\n    while ( ( ! Di . isEmpty ( ) ) && Di . peek ( ) < ( i - k + 1 ) ) Di . remove ( ) ;\n    if ( arr [ i ] < 0 ) Di . add ( i ) ;\n  }\n  if ( ! Di . isEmpty ( ) ) System . out . print ( arr [ Di . peek ( ) ] + \" \" ) ;\n  else System . out . print ( \"0\" + \" \" ) ;\n}\n", "MAGIC_SQUARE": "static void generateSquare ( int n ) {\n  int [ ] [ ] magicSquare = new int [ n ] [ n ] ;\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 ] != 0 ) {\n      j -= 2 ;\n      i ++ ;\n      continue ;\n    }\n    else magicSquare [ i ] [ j ] = num ++ ;\n    j ++ ;\n    i -- ;\n  }\n  System . out . println ( \"The Magic Square for \" + n + \":\" ) ;\n  System . out . println ( \"Sum of each row or column \" + n * ( n * n + 1 ) / 2 + \":\" ) ;\n  for ( i = 0 ;\n  i < n ;\n  i ++ ) {\n    for ( j = 0 ;\n    j < n ;\n    j ++ ) System . out . print ( magicSquare [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "PROGRAM_BINOMIAL_COEFFICIENTS_TABLE": "static void printbinomial ( int max ) {\n  for ( int m = 0 ;\n  m <= max ;\n  m ++ ) {\n    System . out . print ( 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      System . out . print ( binom + \" \" ) ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "CHINESE_REMAINDER_THEOREM_SET_1_INTRODUCTION": "static 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}\n", "MINIMUM_NUMBER_POINTS_REMOVED_GET_REMAINING_POINTS_ONE_SIDE_AXIS": "static 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 Math . min ( Math . min ( a , b ) , Math . min ( c , d ) ) ;\n}\n", "REPLACE_OCCURRENCES_STRING_AB_C_WITHOUT_USING_EXTRA_SPACE": "static void translate ( char str [ ] ) {\n  for ( int i = 1 ;\n  i < str . length ;\n  i ++ ) {\n    if ( str [ i - 1 ] == 'A' && str [ i ] == 'B' ) {\n      str [ i - 1 ] = 'C' ;\n      int j ;\n      for ( j = i ;\n      j < str . length - 1 ;\n      j ++ ) str [ j ] = str [ j + 1 ] ;\n      str [ j ] = ' ' ;\n    }\n  }\n  return ;\n}\n", "PAIRS_OF_POSITIVE_NEGATIVE_VALUES_IN_AN_ARRAY": "public static void printPairs ( int arr [ ] , int n ) {\n  Vector < Integer > v = new Vector < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) for ( int j = i + 1 ;\n  j < n ;\n  j ++ ) if ( Math . abs ( arr [ i ] ) == Math . abs ( arr [ j ] ) ) v . add ( Math . abs ( arr [ i ] ) ) ;\n  if ( v . size ( ) == 0 ) return ;\n  Collections . sort ( v ) ;\n  for ( int i = 0 ;\n  i < v . size ( ) ;\n  i ++ ) System . out . print ( - v . get ( i ) + \" \" + v . get ( i ) ) ;\n}\n", "NON_REPEATING_ELEMENT_1": "static int firstNonRepeating ( int arr [ ] , int n ) {\n  Map < Integer , Integer > m = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( m . containsKey ( arr [ i ] ) ) {\n      m . put ( arr [ i ] , m . get ( arr [ i ] ) + 1 ) ;\n    }\n    else {\n      m . put ( arr [ i ] , 1 ) ;\n    }\n  }\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) if ( m . get ( arr [ i ] ) == 1 ) return arr [ i ] ;\n  return - 1 ;\n}\n", "PRINT_FIBONACCI_SERIES_REVERSE_ORDER": "static void reverseFibonacci ( int n ) {\n  int a [ ] = new int [ 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    System . out . print ( a [ i ] + \" \" ) ;\n  }\n}\n", "FIND_MINIMUM_DIFFERENCE_PAIR_1": "static int findMinDiff ( int [ ] arr , int n ) {\n  Arrays . sort ( arr ) ;\n  int diff = Integer . MAX_VALUE ;\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": "static int findPlatform ( int arr [ ] , int dep [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  Arrays . sort ( dep ) ;\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": "static 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 ;\n    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": "static long answer ( int n ) {\n  int dp [ ] [ ] = new int [ 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 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": "static void fill0X ( int m , int n ) {\n  int i , k = 0 , l = 0 ;\n  int r = m , c = n ;\n  char a [ ] [ ] = new char [ 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 ++ ) System . out . print ( a [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "FIND_SUM_UNIQUE_SUB_ARRAY_SUM_GIVEN_ARRAY": "static int findSubarraySum ( int [ ] arr , int n ) {\n  int res = 0 ;\n  HashMap < Integer , Integer > m = new HashMap < Integer , Integer > ( ) ;\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      if ( m . containsKey ( sum ) ) {\n        m . put ( sum , m . get ( sum ) + 1 ) ;\n      }\n      else {\n        m . put ( sum , 1 ) ;\n      }\n    }\n  }\n  for ( Map . Entry < Integer , Integer > x : m . entrySet ( ) ) if ( x . getValue ( ) == 1 ) res += x . getKey ( ) ;\n  return res ;\n}\n", "REVERSE_A_STRING_USING_RECURSION": "void reverse ( String str ) {\n  if ( ( str == null ) || ( str . length ( ) <= 1 ) ) System . out . println ( str ) ;\n  else {\n    System . out . print ( str . charAt ( str . length ( ) - 1 ) ) ;\n    reverse ( str . substring ( 0 , str . length ( ) - 1 ) ) ;\n  }\n}\n", "PRINTING_ITEMS_01_KNAPSACK": "static void printknapSack ( int W , int wt [ ] , int val [ ] , int n ) {\n  int i , w ;\n  int K [ ] [ ] = new int [ 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 ] = Math . 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  System . out . println ( 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      System . out . print ( wt [ i - 1 ] + \" \" ) ;\n      res = res - val [ i - 1 ] ;\n      w = w - wt [ i - 1 ] ;\n    }\n  }\n}\n", "FIND_LARGEST_PRIME_FACTOR_NUMBER": "static long maxPrimeFactors ( long n ) {\n  long maxPrime = - 1 ;\n  while ( n % 2 == 0 ) {\n    maxPrime = 2 ;\n    n >>= 1 ;\n  }\n  for ( int i = 3 ;\n  i <= Math . 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": "static int findElement ( int [ ] arr , int n ) {\n  int [ ] leftMax = new int [ n ] ;\n  leftMax [ 0 ] = Integer . MIN_VALUE ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) leftMax [ i ] = Math . max ( leftMax [ i - 1 ] , arr [ i - 1 ] ) ;\n  int rightMin = Integer . MAX_VALUE ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    if ( leftMax [ i ] < arr [ i ] && rightMin > arr [ i ] ) return i ;\n    rightMin = Math . min ( rightMin , arr [ i ] ) ;\n  }\n  return - 1 ;\n}\n", "COMMON_CHARACTERS_N_STRINGS": "public static void commonCharacters ( String str [ ] , int n ) {\n  Boolean [ ] prim = new Boolean [ MAX_CHAR ] ;\n  Arrays . fill ( prim , new Boolean ( true ) ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    Boolean [ ] sec = new Boolean [ MAX_CHAR ] ;\n    Arrays . fill ( sec , new Boolean ( false ) ) ;\n    for ( int j = 0 ;\n    j < str [ i ] . length ( ) ;\n    j ++ ) {\n      if ( prim [ str [ i ] . charAt ( j ) - 'a' ] ) sec [ str [ i ] . charAt ( j ) - 'a' ] = true ;\n    }\n    System . arraycopy ( sec , 0 , prim , 0 , MAX_CHAR ) ;\n  }\n  for ( int i = 0 ;\n  i < 26 ;\n  i ++ ) if ( prim [ i ] ) {\n    System . out . print ( Character . toChars ( i + 97 ) ) ;\n    System . out . print ( \" \" ) ;\n  }\n}\n", "MINIMAL_MOVES_FORM_STRING_ADDING_CHARACTERS_APPENDING_STRING": "static int minimalSteps ( String s , int n ) {\n  int [ ] dp = new int [ n ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) dp [ i ] = Integer . MAX_VALUE ;\n  String s1 = \"\" , s2 = \"\" ;\n  dp [ 0 ] = 1 ;\n  s1 += s . charAt ( 0 ) ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    s1 += s . charAt ( i ) ;\n    s2 = s . substring ( i + 1 , i + 1 ) ;\n    dp [ i ] = Math . min ( dp [ i ] , dp [ i - 1 ] + 1 ) ;\n    if ( s1 == s2 ) dp [ i * 2 + 1 ] = Math . 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": "static 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": "static void freq ( int ar [ ] [ ] , 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  System . out . print ( \" Frequency of odd number =\" + odd + \" \\n\" ) ;\n  System . out . print ( \" Frequency of even number = \" + even + \" \\n\" ) ;\n}\n", "COUNT_SUBARRAYS_WITH_SAME_EVEN_AND_ODD_ELEMENTS": "static int countSubarrays ( int [ ] arr , int n ) {\n  int difference = 0 ;\n  int ans = 0 ;\n  int [ ] hash_positive = new int [ n + 1 ] ;\n  int [ ] hash_negative = new int [ n + 1 ] ;\n  hash_positive [ 0 ] = 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ( arr [ i ] & 1 ) == 1 ) {\n      difference ++ ;\n    }\n    else {\n      difference -- ;\n    }\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": "public static 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      System . out . print ( C + \" \" ) ;\n      C = C * ( line - i ) / i ;\n    }\n    System . out . println ( ) ;\n  }\n}\n", "NUMBER_OF_TRIANGLES_IN_A_PLANE_IF_NO_MORE_THAN_TWO_POINTS_ARE_COLLINEAR": "static int countNumberOfTriangles ( int n ) {\n  return n * ( n - 1 ) * ( n - 2 ) / 6 ;\n}\n", "MERGE_TWO_SORTED_ARRAYS_O1_EXTRA_SPACE": "static void merge ( int m , int n ) {\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    int j , last = arr1 [ m - 1 ] ;\n    for ( j = m - 2 ;\n    j >= 0 && arr1 [ j ] > arr2 [ i ] ;\n    j -- ) arr1 [ j + 1 ] = arr1 [ j ] ;\n    if ( j != m - 2 || last > arr2 [ i ] ) {\n      arr1 [ j + 1 ] = arr2 [ i ] ;\n      arr2 [ i ] = last ;\n    }\n  }\n}\n", "NEWMAN_SHANKS_WILLIAMS_PRIME": "static 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": "static int smallest ( int x , int y , int z ) {\n  int c = 0 ;\n  while ( x != 0 && y != 0 && z != 0 ) {\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": "static 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": "static 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 = - 1 ;\n  int maximum = - 999999 ;\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 = new int [ n ] ;\n  int 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 p = 0 ;\n  p < n ;\n  p ++ ) arr [ p ] = new_arr [ p ] ;\n}\n", "PROGRAM_TO_FIND_THE_AREA_OF_PENTAGON": "static float findArea ( float a ) {\n  float area ;\n  area = ( float ) ( Math . sqrt ( 5 * ( 5 + 2 * ( Math . sqrt ( 5 ) ) ) ) * a * a ) / 4 ;\n  return area ;\n}\n", "MAXIMIZE_SUM_CONSECUTIVE_DIFFERENCES_CIRCULAR_ARRAY": "static int maxSum ( int arr [ ] , int n ) {\n  int sum = 0 ;\n  Arrays . sort ( arr ) ;\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": "public static int countarray ( int n , int k , int x ) {\n  int [ ] dp = new int [ 109 ] ;\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": "static 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": "static void printPrevSmaller ( int arr [ ] , int n ) {\n  Stack < Integer > S = new Stack < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    while ( ! S . empty ( ) && S . peek ( ) >= arr [ i ] ) {\n      S . pop ( ) ;\n    }\n    if ( S . empty ( ) ) {\n      System . out . print ( \"_, \" ) ;\n    }\n    else {\n      System . out . print ( S . peek ( ) + \", \" ) ;\n    }\n    S . push ( arr [ i ] ) ;\n  }\n}\n", "FIND_NUMBER_OF_TRIANGLES_POSSIBLE_1": "static void CountTriangles ( int [ ] A ) {\n  int n = A . length ;\n  Arrays . sort ( A ) ;\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 {\n        l ++ ;\n      }\n    }\n  }\n  System . out . print ( \"No of possible solutions: \" + count ) ;\n}\n", "MAXIMUM_GAMES_PLAYED_WINNER": "static int maxGameByWinner ( int N ) {\n  int [ ] dp = new int [ 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": "static int countSubstr ( String s ) {\n  int n = s . length ( ) ;\n  int [ ] auxArr = new int [ n ] ;\n  if ( s . charAt ( 0 ) == '1' ) auxArr [ 0 ] = 1 ;\n  for ( int i = 1 ;\n  i < n ;\n  i ++ ) {\n    if ( s . charAt ( 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 . charAt ( 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": "static int countNum ( int arr [ ] , int n ) {\n  HashSet < Integer > s = new HashSet < > ( ) ;\n  int count = 0 , maxm = Integer . MIN_VALUE , minm = Integer . MAX_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    s . add ( 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 . contains ( i ) ) count ++ ;\n  return count ;\n}\n", "WRITE_A_C_PROGRAM_TO_CALCULATE_POWXN_1": "static 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": "public static int nthTerm ( int n ) {\n  return ( n * n ) + ( n * n * n ) ;\n}\n", "FIND_THE_NUMBER_OCCURRING_ODD_NUMBER_OF_TIMES": "static int getOddOccurrence ( int arr [ ] , int arr_size ) {\n  int i ;\n  for ( 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": "static String findTwoscomplement ( StringBuffer str ) {\n  int n = str . length ( ) ;\n  int i ;\n  for ( i = n - 1 ;\n  i >= 0 ;\n  i -- ) if ( str . charAt ( i ) == '1' ) break ;\n  if ( i == - 1 ) return \"1\" + str ;\n  for ( int k = i - 1 ;\n  k >= 0 ;\n  k -- ) {\n    if ( str . charAt ( k ) == '1' ) str . replace ( k , k + 1 , \"0\" ) ;\n    else str . replace ( k , k + 1 , \"1\" ) ;\n  }\n  return str . toString ( ) ;\n}\n", "PAPER_CUT_MINIMUM_NUMBER_SQUARES_SET_2": "static int minimumSquare ( int m , int n ) {\n  int vertical_min = Integer . MAX_VALUE ;\n  int horizontal_min = Integer . MAX_VALUE ;\n  if ( m == n ) return 1 ;\n  if ( dp [ m ] [ n ] != 0 ) return dp [ m ] [ n ] ;\n  for ( int i = 1 ;\n  i <= m / 2 ;\n  i ++ ) {\n    horizontal_min = Math . 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 = Math . min ( minimumSquare ( m , j ) + minimumSquare ( m , n - j ) , vertical_min ) ;\n  }\n  dp [ m ] [ n ] = Math . min ( vertical_min , horizontal_min ) ;\n  return dp [ m ] [ n ] ;\n}\n", "MINIMIZE_ABSOLUTE_DIFFERENCE_SUM_TWO_SUBSETS": "static void subsetDifference ( int n ) {\n  int s = n * ( n + 1 ) / 2 ;\n  if ( n % 4 == 0 ) {\n    System . out . println ( \"First subset sum = \" + s / 2 ) ;\n    System . out . println ( \"Second subset sum = \" + s / 2 ) ;\n    System . out . println ( \"Difference = \" + 0 ) ;\n  }\n  else {\n    if ( n % 4 == 1 || n % 4 == 2 ) {\n      System . out . println ( \"First subset sum = \" + s / 2 ) ;\n      System . out . println ( \"Second subset sum = \" + ( ( s / 2 ) + 1 ) ) ;\n      System . out . println ( \"Difference = \" + 1 ) ;\n    }\n    else {\n      System . out . println ( \"First subset sum = \" + s / 2 ) ;\n      System . out . println ( \"Second subset sum = \" + s / 2 ) ;\n      System . out . println ( \"Difference = \" + 0 ) ;\n    }\n  }\n}\n", "PROGRAM_CALCULATE_VOLUME_ELLIPSOID": "public static float volumeOfEllipsoid ( float r1 , float r2 , float r3 ) {\n  float pi = ( float ) 3.14 ;\n  return ( float ) 1.33 * pi * r1 * r2 * r3 ;\n}\n", "DYNAMIC_PROGRAMMING_SET_13_CUTTING_A_ROD": "static int cutRod ( int price [ ] , int n ) {\n  int val [ ] = new int [ n + 1 ] ;\n  val [ 0 ] = 0 ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    int max_val = Integer . MIN_VALUE ;\n    for ( int j = 0 ;\n    j < i ;\n    j ++ ) max_val = Math . max ( max_val , price [ j ] + val [ i - j - 1 ] ) ;\n    val [ i ] = max_val ;\n  }\n  return val [ n ] ;\n}\n", "RECURSIVE_INSERTION_SORT": "static 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": "static boolean findDuplicateparenthesis ( String s ) {\n  Stack < Character > Stack = new Stack < > ( ) ;\n  char [ ] str = s . toCharArray ( ) ;\n  for ( char ch : str ) {\n    if ( ch == ')' ) {\n      char top = Stack . peek ( ) ;\n      Stack . pop ( ) ;\n      int elementsInside = 0 ;\n      while ( top != '(' ) {\n        elementsInside ++ ;\n        top = Stack . peek ( ) ;\n        Stack . pop ( ) ;\n      }\n      if ( elementsInside < 1 ) {\n        return true ;\n      }\n    }\n    else {\n      Stack . push ( ch ) ;\n    }\n  }\n  return false ;\n}\n", "FIND_REPETITIVE_ELEMENT_1_N_1": "static int findRepeating ( int [ ] arr , int n ) {\n  int sum = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) sum += arr [ i ] ;\n  return sum - ( ( ( n - 1 ) * n ) / 2 ) ;\n}\n", "CHECK_ARRAY_CONTAINS_CONTIGUOUS_INTEGERS_DUPLICATES_ALLOWED": "static boolean areElementsContiguous ( int arr [ ] , int n ) {\n  int max = Integer . MIN_VALUE ;\n  int min = Integer . MAX_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    max = Math . max ( max , arr [ i ] ) ;\n    min = Math . min ( min , arr [ i ] ) ;\n  }\n  int m = max - min + 1 ;\n  if ( m > n ) return false ;\n  boolean visited [ ] = new boolean [ n ] ;\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": "static int maxLength ( String s , int n ) {\n  int invalidOpenBraces = 0 ;\n  int invalidCloseBraces = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( s . charAt ( 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": "static 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 static 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": "static int minCoins ( int coins [ ] , int m , int V ) {\n  if ( V == 0 ) return 0 ;\n  int res = Integer . MAX_VALUE ;\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 != Integer . MAX_VALUE && sub_res + 1 < res ) res = sub_res + 1 ;\n    }\n  }\n  return res ;\n}\n", "BELL_NUMBERS_NUMBER_OF_WAYS_TO_PARTITION_A_SET": "static int bellNumber ( int n ) {\n  int [ ] [ ] bell = new int [ 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": "static int findElement ( int [ ] arr , int [ ] [ ] ranges , 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": "public static int countDyckPaths ( 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": "static 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": "static 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  System . out . println ( astro_sign ) ;\n}\n", "PROGRAM_REVERSE_STRING_ITERATIVE_RECURSIVE_2": "static void recursiveReverse ( char [ ] str , int i ) {\n  int n = str . length ;\n  if ( i == n / 2 ) return ;\n  swap ( str , i , n - i - 1 ) ;\n  recursiveReverse ( str , i + 1 ) ;\n}\n", "K_TH_DIGIT_RAISED_POWER_B": "public static int kthdigit ( int a , int b , int k ) {\n  int p = ( int ) Math . 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": "static int findSmallestDifference ( int A [ ] , int B [ ] , int m , int n ) {\n  Arrays . sort ( A ) ;\n  Arrays . sort ( B ) ;\n  int a = 0 , b = 0 ;\n  int result = Integer . MAX_VALUE ;\n  while ( a < m && b < n ) {\n    if ( Math . abs ( A [ a ] - B [ b ] ) < result ) result = Math . 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": "static int findArea ( int arr [ ] , int n ) {\n  Set < Integer > s = new HashSet < > ( ) ;\n  int first = 0 , second = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! s . contains ( arr [ i ] ) ) {\n      s . add ( 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": "static int pageFaults ( int pages [ ] , int n , int capacity ) {\n  HashSet < Integer > s = new HashSet < > ( capacity ) ;\n  Queue < Integer > indexes = new LinkedList < > ( ) ;\n  int page_faults = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( s . size ( ) < capacity ) {\n      if ( ! s . contains ( pages [ i ] ) ) {\n        s . add ( pages [ i ] ) ;\n        page_faults ++ ;\n        indexes . add ( pages [ i ] ) ;\n      }\n    }\n    else {\n      if ( ! s . contains ( pages [ i ] ) ) {\n        int val = indexes . peek ( ) ;\n        indexes . poll ( ) ;\n        s . remove ( val ) ;\n        s . add ( pages [ i ] ) ;\n        indexes . add ( 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": "static int findFourElements ( int [ ] arr , int n ) {\n  HashMap < Integer , Indexes > map = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n - 1 ;\n  i ++ ) {\n    for ( int j = i + 1 ;\n    j < n ;\n    j ++ ) {\n      map . put ( arr [ i ] + arr [ j ] , new Indexes ( i , j ) ) ;\n    }\n  }\n  int d = Integer . MIN_VALUE ;\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 = Math . abs ( arr [ i ] - arr [ j ] ) ;\n      if ( map . containsKey ( abs_diff ) ) {\n        Indexes indexes = map . get ( abs_diff ) ;\n        if ( indexes . getI ( ) != i && indexes . getI ( ) != j && indexes . getJ ( ) != i && indexes . getJ ( ) != j ) {\n          d = Math . max ( d , Math . max ( arr [ i ] , arr [ j ] ) ) ;\n        }\n      }\n    }\n  }\n  return d ;\n}\n", "PRINT_GIVEN_MATRIX_REVERSE_SPIRAL_FORM": "public static void ReversespiralPrint ( int m , int n , int a [ ] [ ] ) {\n  long b [ ] = new long [ 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 x = size - 1 ;\n  x >= 0 ;\n  -- x ) {\n    System . out . print ( b [ x ] + \" \" ) ;\n  }\n}\n", "NUMBER_N_DIGITS_NON_DECREASING_INTEGERS": "static int nonDecNums ( int n ) {\n  int [ ] [ ] a = new int [ 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": "static int findLength ( String str ) {\n  int n = str . length ( ) ;\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 . charAt ( i + k ) - '0' ) ;\n        rightsum += ( str . charAt ( 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": "static void worstFit ( int blockSize [ ] , int m , int processSize [ ] , int n ) {\n  int allocation [ ] = new int [ n ] ;\n  for ( int i = 0 ;\n  i < allocation . length ;\n  i ++ ) allocation [ i ] = - 1 ;\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  System . out . println ( \"\\nProcess No.\\tProcess Size\\tBlock no.\" ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    System . out . print ( \"   \" + ( i + 1 ) + \"\\t\\t\" + processSize [ i ] + \"\\t\\t\" ) ;\n    if ( allocation [ i ] != - 1 ) System . out . print ( allocation [ i ] + 1 ) ;\n    else System . out . print ( \"Not Allocated\" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "SUM_SUBSETS_SET_FORMED_FIRST_N_NATURAL_NUMBERS": "static long findSumSubsets ( int n ) {\n  return ( n * ( n + 1 ) / 2 ) * ( 1 << ( n - 1 ) ) ;\n}\n", "ADD_TWO_NUMBERS_WITHOUT_USING_ARITHMETIC_OPERATORS": "static 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": "static int maxcoefficientvalue ( int n ) {\n  int [ ] [ ] C = new int [ n + 1 ] [ n + 1 ] ;\n  for ( int i = 0 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 0 ;\n    j <= Math . 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 = Math . max ( maxvalue , C [ n ] [ i ] ) ;\n  return maxvalue ;\n}\n", "EULERIAN_PATH_UNDIRECTED_GRAPH": "static void findpath ( int [ ] [ ] graph , int n ) {\n  Vector < Integer > numofadj = new Vector < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) numofadj . add ( accumulate ( graph [ i ] , 0 ) ) ;\n  int startPoint = 0 , numofodd = 0 ;\n  for ( int i = n - 1 ;\n  i >= 0 ;\n  i -- ) {\n    if ( numofadj . elementAt ( i ) % 2 == 1 ) {\n      numofodd ++ ;\n      startPoint = i ;\n    }\n  }\n  if ( numofodd > 2 ) {\n    System . out . println ( \"No Solution\" ) ;\n    return ;\n  }\n  Stack < Integer > stack = new Stack < > ( ) ;\n  Vector < Integer > path = new Vector < > ( ) ;\n  int cur = startPoint ;\n  while ( ! stack . isEmpty ( ) || accumulate ( graph [ cur ] , 0 ) != 0 ) {\n    if ( accumulate ( graph [ cur ] , 0 ) == 0 ) {\n      path . add ( cur ) ;\n      cur = stack . pop ( ) ;\n    }\n    else {\n      for ( int i = 0 ;\n      i < n ;\n      i ++ ) {\n        if ( graph [ cur ] [ i ] == 1 ) {\n          stack . add ( cur ) ;\n          graph [ cur ] [ i ] = 0 ;\n          graph [ i ] [ cur ] = 0 ;\n          cur = i ;\n          break ;\n        }\n      }\n    }\n  }\n  for ( int ele : path ) System . out . print ( ele + \" -> \" ) ;\n  System . out . println ( cur ) ;\n}\n", "RECURSIVE_SOLUTION_COUNT_SUBSTRINGS_FIRST_LAST_CHARACTERS": "static 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 . charAt ( i ) == str . charAt ( j ) ) res ++ ;\n  return res ;\n}\n", "FIND_NUMBER_TIMES_STRING_OCCURS_GIVEN_STRING_1": "static int count ( String a , String b ) {\n  int m = a . length ( ) ;\n  int n = b . length ( ) ;\n  int lookup [ ] [ ] = new int [ m + 1 ] [ n + 1 ] ;\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 . charAt ( i - 1 ) == b . charAt ( 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": "public static 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 Math . abs ( area / 2.0 ) ;\n}\n", "PRINT_POSSIBLE_SUMS_CONSECUTIVE_NUMBERS_SUM_N": "static void findConsecutive ( int N ) {\n  int start = 1 ;\n  int 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 ++ ) System . out . print ( j + \" \" ) ;\n        System . out . println ( ) ;\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": "static long arrangeBraces ( int n , int pos [ ] , int k ) {\n  boolean h [ ] = new boolean [ N ] ;\n  int dp [ ] [ ] = new int [ N ] [ N ] ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) {\n    h [ pos [ i ] ] = true ;\n  }\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 ) {\n          dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] ;\n        }\n        else {\n          dp [ i ] [ j ] = 0 ;\n        }\n      }\n      else if ( j != 0 ) {\n        dp [ i ] [ j ] = dp [ i - 1 ] [ j - 1 ] + dp [ i - 1 ] [ j + 1 ] ;\n      }\n      else {\n        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": "public static void ZigZag ( int rows , int columns , int numbers [ ] ) {\n  int k = 0 ;\n  int [ ] [ ] arr = new int [ 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 && 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 && 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 ++ ) System . out . print ( arr [ i ] [ j ] + \" \" ) ;\n    System . out . println ( ) ;\n  }\n}\n", "CONVERT_STRING_BINARY_SEQUENCE": "static void strToBinary ( String s ) {\n  int n = s . length ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    int val = Integer . valueOf ( s . charAt ( i ) ) ;\n    String bin = \"\" ;\n    while ( val > 0 ) {\n      if ( val % 2 == 1 ) {\n        bin += '1' ;\n      }\n      else bin += '0' ;\n      val /= 2 ;\n    }\n    bin = reverse ( bin ) ;\n    System . out . print ( bin + \" \" ) ;\n  }\n}\n", "LUCKY_NUMBERS": "static boolean isLucky ( int n ) {\n  int next_position = n ;\n  if ( counter > n ) return true ;\n  if ( n % counter == 0 ) return false ;\n  next_position -= next_position / counter ;\n  counter ++ ;\n  return isLucky ( next_position ) ;\n}\n", "SMALLEST_SUM_CONTIGUOUS_SUBARRAY": "static int smallestSumSubarr ( int arr [ ] , int n ) {\n  int min_ending_here = 2147483647 ;\n  int min_so_far = 2147483647 ;\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 = Math . min ( min_so_far , min_ending_here ) ;\n  }\n  return min_so_far ;\n}\n", "PRINT_N_TERMS_NEWMAN_CONWAY_SEQUENCE": "public static void sequence ( int n ) {\n  int f [ ] = new int [ n + 1 ] ;\n  f [ 0 ] = 0 ;\n  f [ 1 ] = 1 ;\n  f [ 2 ] = 1 ;\n  System . out . print ( 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    System . out . print ( f [ i ] + \" \" ) ;\n  }\n}\n", "MASTER_THEOREM_SUBTRACT_CONQUER_RECURRENCES": "static 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": "static int cost ( int [ ] a , int n ) {\n  int min = a [ 0 ] ;\n  for ( int i = 1 ;\n  i < a . length ;\n  i ++ ) {\n    if ( a [ i ] < min ) min = a [ i ] ;\n  }\n  return ( n - 1 ) * min ;\n}\n", "CHOCOLATE_DISTRIBUTION_PROBLEM": "static int findMinDiff ( int arr [ ] , int n , int m ) {\n  if ( m == 0 || n == 0 ) return 0 ;\n  Arrays . sort ( arr ) ;\n  if ( n < m ) return - 1 ;\n  int min_diff = Integer . MAX_VALUE ;\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": "static char findExtraCharcter ( String strA , String strB ) {\n  int res = 0 , i ;\n  for ( i = 0 ;\n  i < strA . length ( ) ;\n  i ++ ) {\n    res ^= strA . charAt ( i ) ;\n  }\n  for ( i = 0 ;\n  i < strB . length ( ) ;\n  i ++ ) {\n    res ^= strB . charAt ( i ) ;\n  }\n  return ( ( char ) ( res ) ) ;\n}\n", "CHECK_WHETHER_TWO_STRINGS_ARE_ANAGRAM_OF_EACH_OTHER": "static boolean areAnagram ( char [ ] str1 , char [ ] str2 ) {\n  int n1 = str1 . length ;\n  int n2 = str2 . length ;\n  if ( n1 != n2 ) return false ;\n  Arrays . sort ( str1 ) ;\n  Arrays . sort ( str2 ) ;\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": "static int calcMaxValue ( String str ) {\n  int res = str . charAt ( 0 ) - '0' ;\n  for ( int i = 1 ;\n  i < str . length ( ) ;\n  i ++ ) {\n    if ( str . charAt ( i ) == '0' || str . charAt ( i ) == '1' || res < 2 ) res += ( str . charAt ( i ) - '0' ) ;\n    else res *= ( str . charAt ( i ) - '0' ) ;\n  }\n  return res ;\n}\n", "FIND_SUM_MODULO_K_FIRST_N_NATURAL_NUMBER": "static 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": "static boolean checkCount ( int arr [ ] , int n , int k ) {\n  HashMap < Integer , Integer > hash = new HashMap < > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( ! hash . containsKey ( arr [ i ] ) ) hash . put ( arr [ i ] , 0 ) ;\n    hash . put ( arr [ i ] , hash . get ( arr [ i ] ) + 1 ) ;\n  }\n  for ( Map . Entry x : hash . entrySet ( ) ) if ( ( int ) x . getValue ( ) > 2 * k ) return false ;\n  return true ;\n}\n", "SEARCH_IN_ROW_WISE_AND_COLUMN_WISE_SORTED_MATRIX": "private static void search ( int [ ] [ ] mat , int n , int x ) {\n  int i = 0 , j = n - 1 ;\n  while ( i < n && j >= 0 ) {\n    if ( mat [ i ] [ j ] == x ) {\n      System . out . print ( \"n Found at \" + i + \" \" + j ) ;\n      return ;\n    }\n    if ( mat [ i ] [ j ] > x ) j -- ;\n    else i ++ ;\n  }\n  System . out . print ( \"n Element not found\" ) ;\n  return ;\n}\n", "RETURN_PREVIOUS_ELEMENT_IN_AN_EXPANDING_MATRIX": "static StringBuilder findLeft ( StringBuilder str ) {\n  int n = str . length ( ) ;\n  while ( n > 0 ) {\n    n -- ;\n    if ( str . charAt ( n ) == 'd' ) {\n      str . setCharAt ( n , 'c' ) ;\n      break ;\n    }\n    if ( str . charAt ( n ) == 'b' ) {\n      str . setCharAt ( n , 'a' ) ;\n      break ;\n    }\n    if ( str . charAt ( n ) == 'a' ) str . setCharAt ( n , 'b' ) ;\n    else if ( str . charAt ( n ) == 'c' ) str . setCharAt ( n , 'd' ) ;\n  }\n  return str ;\n}\n", "SUM_FACTORS_NUMBER": "static int divSum ( int n ) {\n  int result = 0 ;\n  for ( int i = 2 ;\n  i <= Math . 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": "static int sumDigits ( int no ) {\n  return no == 0 ? 0 : no % 10 + sumDigits ( no / 10 ) ;\n}\n", "CHECK_POSSIBLE_SORT_ARRAY_CONDITIONAL_SWAPPING_ADJACENT_ALLOWED": "static boolean 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 ) {\n        int temp = arr [ i ] ;\n        arr [ i ] = arr [ i + 1 ] ;\n        arr [ i + 1 ] = temp ;\n      }\n      else return false ;\n    }\n  }\n  return true ;\n}\n", "SUPER_PRIME": "static void SieveOfEratosthenes ( int n , boolean 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": "static 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 . charAt ( i ) == '1' ) dec_value += base ;\n    base = base * 2 ;\n  }\n  return dec_value ;\n}\n", "LEONARDO_NUMBER": "static 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": "static Boolean areElementsContiguous ( int arr [ ] , int n ) {\n  HashSet < Integer > us = new HashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) us . add ( arr [ i ] ) ;\n  int count = 1 ;\n  int curr_ele = arr [ 0 ] - 1 ;\n  while ( us . contains ( curr_ele ) == true ) {\n    count ++ ;\n    curr_ele -- ;\n  }\n  curr_ele = arr [ 0 ] + 1 ;\n  while ( us . contains ( curr_ele ) == true ) {\n    count ++ ;\n    curr_ele ++ ;\n  }\n  return ( count == ( us . size ( ) ) ) ;\n}\n", "SQUARE_ROOT_OF_AN_INTEGER": "static 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": "static 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": "static int breakSum ( int n ) {\n  if ( n == 0 || n == 1 ) return n ;\n  return Math . max ( ( breakSum ( n / 2 ) + breakSum ( n / 3 ) + breakSum ( n / 4 ) ) , n ) ;\n}\n", "MINIMUM_NUMBER_SWAPS_REQUIRED_SORT_ARRAY": "public static int minSwaps ( int [ ] arr ) {\n  int n = arr . length ;\n  ArrayList < Pair < Integer , Integer >> arrpos = new ArrayList < Pair < Integer , Integer >> ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) arrpos . add ( new Pair < Integer , Integer > ( arr [ i ] , i ) ) ;\n  arrpos . sort ( new Comparator < Pair < Integer , Integer >> ( ) {\n    @ Override public int compare ( Pair < Integer , Integer > o1 , Pair < Integer , Integer > o2 ) {\n      if ( o1 . getKey ( ) > o2 . getKey ( ) ) return - 1 ;\n      else if ( o1 . getKey ( ) . equals ( o2 . getKey ( ) ) ) return 0 ;\n      else return 1 ;\n    }\n  }\n  ) ;\n  Boolean [ ] vis = new Boolean [ n ] ;\n  Arrays . fill ( vis , false ) ;\n  int ans = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( vis [ i ] || arrpos . get ( i ) . getValue ( ) == i ) continue ;\n    int cycle_size = 0 ;\n    int j = i ;\n    while ( ! vis [ j ] ) {\n      vis [ j ] = true ;\n      j = arrpos . get ( j ) . getValue ( ) ;\n      cycle_size ++ ;\n    }\n    if ( cycle_size > 0 ) {\n      ans += ( cycle_size - 1 ) ;\n    }\n  }\n  return ans ;\n}\n", "DIAGONALLY_DOMINANT_MATRIX": "static boolean isDDM ( int m [ ] [ ] , 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 += Math . abs ( m [ i ] [ j ] ) ;\n    sum -= Math . abs ( m [ i ] [ i ] ) ;\n    if ( Math . abs ( m [ i ] [ i ] ) < sum ) return false ;\n  }\n  return true ;\n}\n", "SPLIT_N_MAXIMUM_COMPOSITE_NUMBERS": "static 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  return 0 ;\n}\n", "FIND_DIMENSIONS_RIGHT_ANGLED_TRIANGLE": "static void findDimen ( int H , int A ) {\n  if ( H * H < 4 * A ) {\n    System . out . println ( \"Not Possible\" ) ;\n    return ;\n  }\n  double apb = Math . sqrt ( H * H + 4 * A ) ;\n  double asb = Math . sqrt ( H * H - 4 * A ) ;\n  System . out . println ( \"P = \" + Math . round ( ( ( apb - asb ) / 2.0 ) * 100.0 ) / 100.0 ) ;\n  System . out . print ( \"B = \" + Math . round ( ( ( apb + asb ) / 2.0 ) * 100.0 ) / 100.0 ) ;\n}\n", "PRODUCT_MAXIMUM_FIRST_ARRAY_MINIMUM_SECOND_1": "public static 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": "static double vol_of_octahedron ( double side ) {\n  return ( ( side * side * side ) * ( Math . sqrt ( 2 ) / 3 ) ) ;\n}\n", "SORT_STRING_CHARACTERS_1": "public static String sortString ( String inputString ) {\n  char tempArray [ ] = inputString . toCharArray ( ) ;\n  Arrays . sort ( tempArray ) ;\n  return new String ( tempArray ) ;\n}\n", "MOVE_SPACES_FRONT_STRING_SINGLE_TRAVERSAL": "static void moveSpaceInFront ( char str [ ] ) {\n  int i = str . length - 1 ;\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": "static int minOps ( int arr [ ] , int n , int k ) {\n  Arrays . sort ( arr ) ;\n  int max = arr [ arr . length - 1 ] ;\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": "static int factorial ( 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": "static 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 ] + Math . min ( excl , incl ) ;\n    int excl_new = incl ;\n    incl = incl_new ;\n    excl = excl_new ;\n  }\n  return Math . min ( incl , excl ) ;\n}\n", "CHECK_IF_TWO_ARRAYS_ARE_EQUAL_OR_NOT": "public static boolean areEqual ( int arr1 [ ] , int arr2 [ ] ) {\n  int n = arr1 . length ;\n  int m = arr2 . length ;\n  if ( n != m ) return false ;\n  Arrays . sort ( arr1 ) ;\n  Arrays . sort ( arr2 ) ;\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": "static int minDifferenceAmongMaxMin ( int arr [ ] , int N , int K ) {\n  Arrays . sort ( arr ) ;\n  int res = 2147483647 ;\n  for ( int i = 0 ;\n  i <= ( N - K ) ;\n  i ++ ) {\n    int curSeqDiff = arr [ i + K - 1 ] - arr [ i ] ;\n    res = Math . min ( res , curSeqDiff ) ;\n  }\n  return res ;\n}\n", "SWAP_BITS_IN_A_GIVEN_NUMBER": "static int swapBits ( int x , int p1 , int p2 , int n ) {\n  int set1 = ( x >> p1 ) & ( ( 1 << n ) - 1 ) ;\n  int set2 = ( x >> p2 ) & ( ( 1 << n ) - 1 ) ;\n  int xor = ( set1 ^ set2 ) ;\n  xor = ( xor << p1 ) | ( xor << p2 ) ;\n  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": "static int count ( int n ) {\n  int [ ] dp = new int [ 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 {\n      dp [ i ] = dp [ i - 1 ] + dp [ i - 4 ] ;\n    }\n  }\n  return dp [ n ] ;\n}\n", "MAXIMUM_CONSECUTIVE_REPEATING_CHARACTER_STRING_1": "static char maxRepeating ( String str ) {\n  int n = str . length ( ) ;\n  int count = 0 ;\n  char res = str . charAt ( 0 ) ;\n  int cur_count = 1 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( i < n - 1 && str . charAt ( i ) == str . charAt ( i + 1 ) ) cur_count ++ ;\n    else {\n      if ( cur_count > count ) {\n        count = cur_count ;\n        res = str . charAt ( i ) ;\n      }\n      cur_count = 1 ;\n    }\n  }\n  return res ;\n}\n", "PASCAL_TRIANGLE": "public static void printPascal ( int n ) {\n  int [ ] [ ] arr = new int [ 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      System . out . print ( arr [ line ] [ i ] ) ;\n    }\n    System . out . println ( \"\" ) ;\n  }\n}\n", "TURN_OFF_THE_RIGHTMOST_SET_BIT": "static int fun ( int n ) {\n  return n & ( n - 1 ) ;\n}\n", "REARRANGE_ARRAY_MAXIMUM_MINIMUM_FORM_SET_2_O1_EXTRA_SPACE": "public static 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": "static int countZeroes ( int mat [ ] [ ] ) {\n  int row = N - 1 , col = 0 ;\n  int count = 0 ;\n  while ( col < N ) {\n    while ( mat [ row ] [ col ] > 0 ) 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": "static int minCost ( int coin [ ] , int n , int k ) {\n  Arrays . sort ( coin ) ;\n  int coins_needed = ( int ) Math . 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": "static int countDistictSubarray ( int arr [ ] , int n ) {\n  HashMap < Integer , Integer > vis = new HashMap < Integer , Integer > ( ) {\n    @ Override public Integer get ( Object key ) {\n      if ( ! containsKey ( key ) ) return 0 ;\n      return super . get ( key ) ;\n    }\n  };\n  for ( int i = 0 ;\n  i < n ;\n  ++ i ) vis . put ( 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 . put ( arr [ right ] , vis . get ( arr [ right ] ) + 1 ) ;\n      if ( vis . get ( arr [ right ] ) == 1 ) ++ window ;\n      ++ right ;\n    }\n    if ( window == k ) ans += ( n - right + 1 ) ;\n    vis . put ( arr [ left ] , vis . get ( arr [ left ] ) - 1 ) ;\n    if ( vis . get ( arr [ left ] ) == 0 ) -- window ;\n  }\n  return ans ;\n}\n", "FIND_POSSIBLE_ROTATE_PAGE_ANGLE_NOT": "static void possibleOrNot ( long a1 , long a2 , long b1 , long b2 , long c1 , long c2 ) {\n  long dis1 = ( long ) Math . pow ( b1 - a1 , 2 ) + ( long ) Math . pow ( b2 - a2 , 2 ) ;\n  long dis2 = ( long ) Math . pow ( c1 - b1 , 2 ) + ( long ) Math . pow ( c2 - b2 , 2 ) ;\n  if ( dis1 != dis2 ) System . out . print ( \"No\" ) ;\n  else if ( b1 == ( ( a1 + c1 ) / 2.0 ) && b2 == ( ( a2 + c2 ) / 2.0 ) ) System . out . print ( \"No\" ) ;\n  else System . out . print ( \"Yes\" ) ;\n}\n", "TIME_MEET_ANIMALS": "static void timeToMeet ( double s , double v ) {\n  double V = 3 * v / 2 ;\n  double time = s / V ;\n  System . out . println ( ( float ) time ) ;\n}\n", "BRESENHAMS_LINE_GENERATION_ALGORITHM": "static 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    System . out . print ( \"(\" + 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": "static int maxNumOfChocolates ( int arr [ ] , int n , int k ) {\n  HashMap < Integer , Integer > um = new HashMap < Integer , Integer > ( ) ;\n  int [ ] sum = new int [ n ] ;\n  int 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 . containsKey ( curr_rem ) ) um . put ( curr_rem , i ) ;\n    else if ( maxSum < ( sum [ i ] - sum [ um . get ( curr_rem ) ] ) ) maxSum = sum [ i ] - sum [ um . get ( curr_rem ) ] ;\n  }\n  return ( maxSum / k ) ;\n}\n", "CHECK_TWO_STRINGS_K_ANAGRAMS_NOT_1": "static boolean areKAnagrams ( String str1 , String str2 , int k ) {\n  int n = str1 . length ( ) ;\n  if ( str2 . length ( ) != n ) return false ;\n  int [ ] hash_str1 = new int [ MAX_CHAR ] ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) hash_str1 [ str1 . charAt ( i ) - 'a' ] ++ ;\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( hash_str1 [ str2 . charAt ( i ) - 'a' ] > 0 ) hash_str1 [ str2 . charAt ( i ) - 'a' ] -- ;\n    else count ++ ;\n    if ( count > k ) return false ;\n  }\n  return true ;\n}\n", "DIVISIBILITY_CHECK": "static void divisibilityCheck ( List < Integer > arr , int n ) {\n  List < Integer > s = new ArrayList < Integer > ( ) ;\n  int max_ele = Integer . MIN_VALUE ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    s . add ( arr . get ( i ) ) ;\n    max_ele = Math . max ( max_ele , arr . get ( i ) ) ;\n  }\n  LinkedHashSet < Integer > res = new LinkedHashSet < Integer > ( ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    if ( arr . get ( i ) != 0 ) for ( int j = arr . get ( i ) * 2 ;\n    j <= max_ele ;\n    j += arr . get ( i ) ) {\n      if ( s . contains ( j ) ) res . add ( j ) ;\n    }\n  }\n  List < Integer > list = new ArrayList < Integer > ( res ) ;\n  Collections . reverse ( list ) ;\n  for ( Integer temp : list ) System . out . print ( temp + \" \" ) ;\n}\n", "MAXIMUM_LENGTH_PREFIX_ONE_STRING_OCCURS_SUBSEQUENCE_ANOTHER": "static int maxPrefix ( String s , String t ) {\n  int count = 0 ;\n  for ( int i = 0 ;\n  i < t . length ( ) ;\n  i ++ ) {\n    if ( count == t . length ( ) ) break ;\n    if ( t . charAt ( i ) == s . charAt ( count ) ) count ++ ;\n  }\n  return count ;\n}\n", "COUNT_DISTINCT_ELEMENTS_IN_EVERY_WINDOW_OF_SIZE_K": "static void countDistinct ( int arr [ ] , int k ) {\n  HashMap < Integer , Integer > hM = new HashMap < Integer , Integer > ( ) ;\n  int dist_count = 0 ;\n  for ( int i = 0 ;\n  i < k ;\n  i ++ ) {\n    if ( hM . get ( arr [ i ] ) == null ) {\n      hM . put ( arr [ i ] , 1 ) ;\n      dist_count ++ ;\n    }\n    else {\n      int count = hM . get ( arr [ i ] ) ;\n      hM . put ( arr [ i ] , count + 1 ) ;\n    }\n  }\n  System . out . println ( dist_count ) ;\n  for ( int i = k ;\n  i < arr . length ;\n  i ++ ) {\n    if ( hM . get ( arr [ i - k ] ) == 1 ) {\n      hM . remove ( arr [ i - k ] ) ;\n      dist_count -- ;\n    }\n    else {\n      int count = hM . get ( arr [ i - k ] ) ;\n      hM . put ( arr [ i - k ] , count - 1 ) ;\n    }\n    if ( hM . get ( arr [ i ] ) == null ) {\n      hM . put ( arr [ i ] , 1 ) ;\n      dist_count ++ ;\n    }\n    else {\n      int count = hM . get ( arr [ i ] ) ;\n      hM . put ( arr [ i ] , count + 1 ) ;\n    }\n    System . out . println ( dist_count ) ;\n  }\n}\n", "LCS_FORMED_CONSECUTIVE_SEGMENTS_LEAST_LENGTH_K": "static int longestSubsequenceCommonSegment ( int k , String s1 , String s2 ) {\n  int n = s1 . length ( ) ;\n  int m = s2 . length ( ) ;\n  int lcs [ ] [ ] = new int [ n + 1 ] [ m + 1 ] ;\n  int cnt [ ] [ ] = new int [ n + 1 ] [ m + 1 ] ;\n  for ( int i = 1 ;\n  i <= n ;\n  i ++ ) {\n    for ( int j = 1 ;\n    j <= m ;\n    j ++ ) {\n      lcs [ i ] [ j ] = Math . max ( lcs [ i - 1 ] [ j ] , lcs [ i ] [ j - 1 ] ) ;\n      if ( s1 . charAt ( i - 1 ) == s2 . charAt ( 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 ] = Math . 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": "static void printDistinct ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\n  for ( int i = 0 ;\n  i < n ;\n  i ++ ) {\n    while ( i < n - 1 && arr [ i ] == arr [ i + 1 ] ) i ++ ;\n    System . out . print ( arr [ i ] + \" \" ) ;\n  }\n}\n", "PRIMALITY_TEST_SET_5USING_LUCAS_LEHMER_SERIES": "static boolean isPrime ( int p ) {\n  double checkNumber = Math . pow ( 2 , p ) - 1 ;\n  double 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": "static int kthNonRepeating ( String str , int k ) {\n  int n = str . length ( ) ;\n  int [ ] count = new int [ MAX_CHAR ] ;\n  int [ ] index = new int [ 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 . charAt ( i ) ;\n    ++ count [ x ] ;\n    if ( count [ x ] == 1 ) index [ x ] = i ;\n    if ( count [ x ] == 2 ) index [ x ] = n ;\n  }\n  Arrays . sort ( index ) ;\n  return ( index [ k - 1 ] != n ) ? index [ k - 1 ] : - 1 ;\n}\n", "FIRST_UPPERCASE_LETTER_IN_A_STRING_ITERATIVE_AND_RECURSIVE": "static char first ( String str ) {\n  for ( int i = 0 ;\n  i < str . length ( ) ;\n  i ++ ) if ( Character . isUpperCase ( str . charAt ( i ) ) ) return str . charAt ( i ) ;\n  return 0 ;\n}\n", "GIVEN_TWO_STRINGS_FIND_FIRST_STRING_SUBSEQUENCE_SECOND": "static boolean isSubSequence ( String str1 , String str2 , int m , int n ) {\n  if ( m == 0 ) return true ;\n  if ( n == 0 ) return false ;\n  if ( str1 . charAt ( m - 1 ) == str2 . charAt ( 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": "static int largest ( int [ ] arr , int n ) {\n  Arrays . sort ( arr ) ;\n  return arr [ n - 1 ] ;\n}\n", "DIFFERENCE_BETWEEN_HIGHEST_AND_LEAST_FREQUENCIES_IN_AN_ARRAY": "static int findDiff ( int arr [ ] , int n ) {\n  Arrays . sort ( arr ) ;\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 = Math . max ( max_count , count ) ;\n      min_count = Math . min ( min_count , count ) ;\n      count = 0 ;\n    }\n  }\n  return ( max_count - min_count ) ;\n}\n", "PROGRAM_FOR_FACTORIAL_OF_A_NUMBER": "static int factorial ( int n ) {\n  if ( n == 0 ) return 1 ;\n  return n * factorial ( n - 1 ) ;\n}\n"}