diff --git a/README.md b/README.md
index f90d2ea2..0326b234 100644
--- a/README.md
+++ b/README.md
@@ -30,7 +30,7 @@
 
 |  |  |  |  |  | 
 |-|-|-|-|-|-
-| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find | 324 | 24.06
+| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find | 181 | 93.83
 | 1254 |[Number of Closed Islands](src/main/kotlin/g1201_1300/s1254_number_of_closed_islands)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find | 177 | 89.47
 
 #### Day 3 Matrix Related Problems
@@ -152,7 +152,7 @@
 
 |  |  |  |  |  | 
 |-|-|-|-|-|-
-| 1965 |[Employees With Missing Information](src/main/kotlin/g1901_2000/s1965_employees_with_missing_information)| Easy | Database | 1355 | 23.96
+| 1965 |[Employees With Missing Information](src/main/kotlin/g1901_2000/s1965_employees_with_missing_information)| Easy | Database | 949 | 88.66
 | 1795 |[Rearrange Products Table](src/main/kotlin/g1701_1800/s1795_rearrange_products_table)| Easy | Database | 1027 | 67.57
 | 0608 |[Tree Node](src/main/kotlin/g0601_0700/s0608_tree_node)| Medium | LeetCode_Curated_SQL_70, Database | 794 | 48.38
 | 0176 |[Second Highest Salary](src/main/kotlin/g0101_0200/s0176_second_highest_salary)| Medium | Database | 219 | 92.54
@@ -986,7 +986,7 @@
 |  |  |  |  |  | 
 |-|-|-|-|-|-
 | 0733 |[Flood Fill](src/main/kotlin/g0701_0800/s0733_flood_fill)| Easy | Array, Depth_First_Search, Breadth_First_Search, Matrix | 230 | 97.76
-| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find | 324 | 24.06
+| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find | 181 | 93.83
 
 #### Day 8 Breadth First Search Depth First Search
 
@@ -1580,7 +1580,7 @@
 |  |  |  |  |  | 
 |-|-|-|-|-|-
 | 1523 |[Count Odd Numbers in an Interval Range](src/main/kotlin/g1501_1600/s1523_count_odd_numbers_in_an_interval_range)| Easy | Math | 114 | 97.22
-| 1491 |[Average Salary Excluding the Minimum and Maximum Salary](src/main/kotlin/g1401_1500/s1491_average_salary_excluding_the_minimum_and_maximum_salary)| Easy | Array, Sorting | 165 | 27.87
+| 1491 |[Average Salary Excluding the Minimum and Maximum Salary](src/main/kotlin/g1401_1500/s1491_average_salary_excluding_the_minimum_and_maximum_salary)| Easy | Array, Sorting | 137 | 91.67
 
 #### Day 2 Operator
 
@@ -1648,7 +1648,7 @@
 
 |  |  |  |  |  | 
 |-|-|-|-|-|-
-| 1290 |[Convert Binary Number in a Linked List to Integer](src/main/kotlin/g1201_1300/s1290_convert_binary_number_in_a_linked_list_to_integer)| Easy | Math, Linked_List | 145 | 25.93
+| 1290 |[Convert Binary Number in a Linked List to Integer](src/main/kotlin/g1201_1300/s1290_convert_binary_number_in_a_linked_list_to_integer)| Easy | Math, Linked_List | 138 | 65.79
 | 0876 |[Middle of the Linked List](src/main/kotlin/g0801_0900/s0876_middle_of_the_linked_list)| Easy | Two_Pointers, Linked_List | 136 | 76.52
 | 0104 |[Maximum Depth of Binary Tree](src/main/kotlin/g0101_0200/s0104_maximum_depth_of_binary_tree)| Easy | Top_100_Liked_Questions, Top_Interview_Questions, Depth_First_Search, Breadth_First_Search, Tree, Binary_Tree, Big_O_Time_O(N)_Space_O(H) | 166 | 83.53
 | 0404 |[Sum of Left Leaves](src/main/kotlin/g0401_0500/s0404_sum_of_left_leaves)| Easy | Depth_First_Search, Breadth_First_Search, Tree, Binary_Tree | 173 | 86.05
@@ -1816,6 +1816,18 @@
 
 | #    |      Title     | Difficulty  | Tag         | Time, ms | Time, %
 |------|----------------|-------------|-------------|----------|--------
+| 3149 |[Find the Minimum Cost Array Permutation](src/main/kotlin/g3101_3200/s3149_find_the_minimum_cost_array_permutation)| Hard | Array, Dynamic_Programming, Bit_Manipulation, Bitmask | 329 | 100.00
+| 3148 |[Maximum Difference Score in a Grid](src/main/kotlin/g3101_3200/s3148_maximum_difference_score_in_a_grid)| Medium | Array, Dynamic_Programming, Matrix | 777 | 84.62
+| 3147 |[Taking Maximum Energy From the Mystic Dungeon](src/main/kotlin/g3101_3200/s3147_taking_maximum_energy_from_the_mystic_dungeon)| Medium | Array, Prefix_Sum | 671 | 79.17
+| 3146 |[Permutation Difference between Two Strings](src/main/kotlin/g3101_3200/s3146_permutation_difference_between_two_strings)| Easy | String, Hash_Table | 177 | 58.21
+| 3145 |[Find Products of Elements of Big Array](src/main/kotlin/g3101_3200/s3145_find_products_of_elements_of_big_array)| Hard | Array, Binary_Search, Bit_Manipulation | 210 | 100.00
+| 3144 |[Minimum Substring Partition of Equal Character Frequency](src/main/kotlin/g3101_3200/s3144_minimum_substring_partition_of_equal_character_frequency)| Medium | String, Hash_Table, Dynamic_Programming, Counting | 232 | 88.00
+| 3143 |[Maximum Points Inside the Square](src/main/kotlin/g3101_3200/s3143_maximum_points_inside_the_square)| Medium | Array, String, Hash_Table, Sorting, Binary_Search | 650 | 59.52
+| 3142 |[Check if Grid Satisfies Conditions](src/main/kotlin/g3101_3200/s3142_check_if_grid_satisfies_conditions)| Easy | Array, Matrix | 170 | 91.84
+| 3139 |[Minimum Cost to Equalize Array](src/main/kotlin/g3101_3200/s3139_minimum_cost_to_equalize_array)| Hard | Array, Greedy, Enumeration | 495 | 100.00
+| 3138 |[Minimum Length of Anagram Concatenation](src/main/kotlin/g3101_3200/s3138_minimum_length_of_anagram_concatenation)| Medium | String, Hash_Table, Counting | 219 | 91.67
+| 3137 |[Minimum Number of Operations to Make Word K-Periodic](src/main/kotlin/g3101_3200/s3137_minimum_number_of_operations_to_make_word_k_periodic)| Medium | String, Hash_Table, Counting | 291 | 96.30
+| 3136 |[Valid Word](src/main/kotlin/g3101_3200/s3136_valid_word)| Easy | String | 160 | 92.50
 | 3134 |[Find the Median of the Uniqueness Array](src/main/kotlin/g3101_3200/s3134_find_the_median_of_the_uniqueness_array)| Hard | Array, Hash_Table, Binary_Search, Sliding_Window | 733 | 100.00
 | 3133 |[Minimum Array End](src/main/kotlin/g3101_3200/s3133_minimum_array_end)| Medium | Bit_Manipulation | 131 | 90.91
 | 3132 |[Find the Integer Added to Array II](src/main/kotlin/g3101_3200/s3132_find_the_integer_added_to_array_ii)| Medium | Array, Sorting, Two_Pointers, Enumeration | 189 | 84.85
@@ -1972,7 +1984,7 @@
 | 2925 |[Maximum Score After Applying Operations on a Tree](src/main/kotlin/g2901_3000/s2925_maximum_score_after_applying_operations_on_a_tree)| Medium | Dynamic_Programming, Depth_First_Search, Tree | 706 | 81.82
 | 2924 |[Find Champion II](src/main/kotlin/g2901_3000/s2924_find_champion_ii)| Medium | Graph | 422 | 81.82
 | 2923 |[Find Champion I](src/main/kotlin/g2901_3000/s2923_find_champion_i)| Easy | Array, Matrix | 320 | 58.62
-| 2920 |[Maximum Points After Collecting Coins From All Nodes](src/main/kotlin/g2901_3000/s2920_maximum_points_after_collecting_coins_from_all_nodes)| Hard | Array, Dynamic_Programming, Depth_First_Search, Tree, Bit_Manipulation | 2255 | 25.00
+| 2920 |[Maximum Points After Collecting Coins From All Nodes](src/main/kotlin/g2901_3000/s2920_maximum_points_after_collecting_coins_from_all_nodes)| Hard | Array, Dynamic_Programming, Depth_First_Search, Tree, Bit_Manipulation | 1007 | 100.00
 | 2919 |[Minimum Increment Operations to Make Array Beautiful](src/main/kotlin/g2901_3000/s2919_minimum_increment_operations_to_make_array_beautiful)| Medium | Array, Dynamic_Programming | 520 | 62.50
 | 2918 |[Minimum Equal Sum of Two Arrays After Replacing Zeros](src/main/kotlin/g2901_3000/s2918_minimum_equal_sum_of_two_arrays_after_replacing_zeros)| Medium | Array, Greedy | 598 | 100.00
 | 2917 |[Find the K-or of an Array](src/main/kotlin/g2901_3000/s2917_find_the_k_or_of_an_array)| Easy | Array, Bit_Manipulation | 191 | 76.47
@@ -2355,7 +2367,7 @@
 | 2440 |[Create Components With Same Value](src/main/kotlin/g2401_2500/s2440_create_components_with_same_value)| Hard | Array, Math, Depth_First_Search, Tree, Enumeration | 751 | 100.00
 | 2439 |[Minimize Maximum of Array](src/main/kotlin/g2401_2500/s2439_minimize_maximum_of_array)| Medium | Array, Dynamic_Programming, Greedy, Binary_Search, Prefix_Sum | 508 | 100.00
 | 2438 |[Range Product Queries of Powers](src/main/kotlin/g2401_2500/s2438_range_product_queries_of_powers)| Medium | Array, Bit_Manipulation, Prefix_Sum | 1115 | 100.00
-| 2437 |[Number of Valid Clock Times](src/main/kotlin/g2401_2500/s2437_number_of_valid_clock_times)| Easy | String, Enumeration | 134 | 28.57
+| 2437 |[Number of Valid Clock Times](src/main/kotlin/g2401_2500/s2437_number_of_valid_clock_times)| Easy | String, Enumeration | 133 | 64.29
 | 2435 |[Paths in Matrix Whose Sum Is Divisible by K](src/main/kotlin/g2401_2500/s2435_paths_in_matrix_whose_sum_is_divisible_by_k)| Hard | Array, Dynamic_Programming, Matrix | 752 | 100.00
 | 2434 |[Using a Robot to Print the Lexicographically Smallest String](src/main/kotlin/g2401_2500/s2434_using_a_robot_to_print_the_lexicographically_smallest_string)| Medium | String, Hash_Table, Greedy, Stack | 319 | 100.00
 | 2433 |[Find The Original Array of Prefix Xor](src/main/kotlin/g2401_2500/s2433_find_the_original_array_of_prefix_xor)| Medium | Array, Bit_Manipulation | 618 | 80.00
@@ -2557,7 +2569,7 @@
 | 2185 |[Counting Words With a Given Prefix](src/main/kotlin/g2101_2200/s2185_counting_words_with_a_given_prefix)| Easy | Array, String | 172 | 100.00
 | 2183 |[Count Array Pairs Divisible by K](src/main/kotlin/g2101_2200/s2183_count_array_pairs_divisible_by_k)| Hard | Array, Math, Number_Theory | 756 | 100.00
 | 2182 |[Construct String With Repeat Limit](src/main/kotlin/g2101_2200/s2182_construct_string_with_repeat_limit)| Medium | String, Greedy, Heap_Priority_Queue, Counting | 311 | 100.00
-| 2181 |[Merge Nodes in Between Zeros](src/main/kotlin/g2101_2200/s2181_merge_nodes_in_between_zeros)| Medium | Simulation, Linked_List | 980 | 25.00
+| 2181 |[Merge Nodes in Between Zeros](src/main/kotlin/g2101_2200/s2181_merge_nodes_in_between_zeros)| Medium | Simulation, Linked_List | 794 | 100.00
 | 2180 |[Count Integers With Even Digit Sum](src/main/kotlin/g2101_2200/s2180_count_integers_with_even_digit_sum)| Easy | Math, Simulation | 126 | 100.00
 | 2179 |[Count Good Triplets in an Array](src/main/kotlin/g2101_2200/s2179_count_good_triplets_in_an_array)| Hard | Array, Binary_Search, Ordered_Set, Divide_and_Conquer, Segment_Tree, Binary_Indexed_Tree, Merge_Sort | 563 | 100.00
 | 2178 |[Maximum Split of Positive Even Integers](src/main/kotlin/g2101_2200/s2178_maximum_split_of_positive_even_integers)| Medium | Math, Greedy | 486 | 55.56
@@ -2725,7 +2737,7 @@
 | 1969 |[Minimum Non-Zero Product of the Array Elements](src/main/kotlin/g1901_2000/s1969_minimum_non_zero_product_of_the_array_elements)| Medium | Math, Greedy, Recursion | 131 | 100.00
 | 1968 |[Array With Elements Not Equal to Average of Neighbors](src/main/kotlin/g1901_2000/s1968_array_with_elements_not_equal_to_average_of_neighbors)| Medium | Array, Sorting, Greedy | 973 | 83.33
 | 1967 |[Number of Strings That Appear as Substrings in Word](src/main/kotlin/g1901_2000/s1967_number_of_strings_that_appear_as_substrings_in_word)| Easy | String | 157 | 100.00
-| 1965 |[Employees With Missing Information](src/main/kotlin/g1901_2000/s1965_employees_with_missing_information)| Easy | Database, SQL_I_Day_4_Union_and_Select | 1355 | 23.96
+| 1965 |[Employees With Missing Information](src/main/kotlin/g1901_2000/s1965_employees_with_missing_information)| Easy | Database, SQL_I_Day_4_Union_and_Select | 949 | 88.66
 | 1964 |[Find the Longest Valid Obstacle Course at Each Position](src/main/kotlin/g1901_2000/s1964_find_the_longest_valid_obstacle_course_at_each_position)| Hard | Array, Binary_Search, Binary_Indexed_Tree | 846 | 40.00
 | 1963 |[Minimum Number of Swaps to Make the String Balanced](src/main/kotlin/g1901_2000/s1963_minimum_number_of_swaps_to_make_the_string_balanced)| Medium | String, Greedy, Two_Pointers, Stack | 291 | 53.85
 | 1962 |[Remove Stones to Minimize the Total](src/main/kotlin/g1901_2000/s1962_remove_stones_to_minimize_the_total)| Medium | Array, Heap_Priority_Queue | 888 | 68.42
@@ -3102,7 +3114,7 @@
 | 1494 |[Parallel Courses II](src/main/kotlin/g1401_1500/s1494_parallel_courses_ii)| Hard | Dynamic_Programming, Bit_Manipulation, Graph, Bitmask | 381 | 100.00
 | 1493 |[Longest Subarray of 1's After Deleting One Element](src/main/kotlin/g1401_1500/s1493_longest_subarray_of_1s_after_deleting_one_element)| Medium | Dynamic_Programming, Math, Sliding_Window | 288 | 73.85
 | 1492 |[The kth Factor of n](src/main/kotlin/g1401_1500/s1492_the_kth_factor_of_n)| Medium | Math | 133 | 65.12
-| 1491 |[Average Salary Excluding the Minimum and Maximum Salary](src/main/kotlin/g1401_1500/s1491_average_salary_excluding_the_minimum_and_maximum_salary)| Easy | Array, Sorting, Programming_Skills_I_Day_1_Basic_Data_Type | 165 | 27.87
+| 1491 |[Average Salary Excluding the Minimum and Maximum Salary](src/main/kotlin/g1401_1500/s1491_average_salary_excluding_the_minimum_and_maximum_salary)| Easy | Array, Sorting, Programming_Skills_I_Day_1_Basic_Data_Type | 137 | 91.67
 | 1489 |[Find Critical and Pseudo-Critical Edges in Minimum Spanning Tree](src/main/kotlin/g1401_1500/s1489_find_critical_and_pseudo_critical_edges_in_minimum_spanning_tree)| Hard | Sorting, Graph, Union_Find, Minimum_Spanning_Tree, Strongly_Connected_Component | 342 | 100.00
 | 1488 |[Avoid Flood in The City](src/main/kotlin/g1401_1500/s1488_avoid_flood_in_the_city)| Medium | Array, Hash_Table, Greedy, Binary_Search, Heap_Priority_Queue, Binary_Search_II_Day_18 | 823 | 66.67
 | 1487 |[Making File Names Unique](src/main/kotlin/g1401_1500/s1487_making_file_names_unique)| Medium | Array, String, Hash_Table | 553 | 50.00
@@ -3222,7 +3234,7 @@
 | 1351 |[Count Negative Numbers in a Sorted Matrix](src/main/kotlin/g1301_1400/s1351_count_negative_numbers_in_a_sorted_matrix)| Easy | Array, Binary_Search, Matrix, Binary_Search_I_Day_8 | 206 | 71.43
 | 1349 |[Maximum Students Taking Exam](src/main/kotlin/g1301_1400/s1349_maximum_students_taking_exam)| Hard | Array, Dynamic_Programming, Matrix, Bit_Manipulation, Bitmask | 173 | 100.00
 | 1348 |[Tweet Counts Per Frequency](src/main/kotlin/g1301_1400/s1348_tweet_counts_per_frequency)| Medium | Hash_Table, Sorting, Binary_Search, Design, Ordered_Set | 701 | 100.00
-| 1347 |[Minimum Number of Steps to Make Two Strings Anagram](src/main/kotlin/g1301_1400/s1347_minimum_number_of_steps_to_make_two_strings_anagram)| Medium | String, Hash_Table, Counting | 271 | 23.08
+| 1347 |[Minimum Number of Steps to Make Two Strings Anagram](src/main/kotlin/g1301_1400/s1347_minimum_number_of_steps_to_make_two_strings_anagram)| Medium | String, Hash_Table, Counting | 250 | 67.35
 | 1346 |[Check If N and Its Double Exist](src/main/kotlin/g1301_1400/s1346_check_if_n_and_its_double_exist)| Easy | Array, Hash_Table, Sorting, Binary_Search, Two_Pointers, Binary_Search_I_Day_9 | 175 | 70.83
 | 1345 |[Jump Game IV](src/main/kotlin/g1301_1400/s1345_jump_game_iv)| Hard | Array, Hash_Table, Breadth_First_Search | 599 | 100.00
 | 1344 |[Angle Between Hands of a Clock](src/main/kotlin/g1301_1400/s1344_angle_between_hands_of_a_clock)| Medium | Math | 118 | 83.33
@@ -3274,7 +3286,7 @@
 | 1293 |[Shortest Path in a Grid with Obstacles Elimination](src/main/kotlin/g1201_1300/s1293_shortest_path_in_a_grid_with_obstacles_elimination)| Hard | Array, Breadth_First_Search, Matrix | 189 | 100.00
 | 1292 |[Maximum Side Length of a Square with Sum Less than or Equal to Threshold](src/main/kotlin/g1201_1300/s1292_maximum_side_length_of_a_square_with_sum_less_than_or_equal_to_threshold)| Medium | Array, Binary_Search, Matrix, Prefix_Sum, Binary_Search_II_Day_15 | 376 | 100.00
 | 1291 |[Sequential Digits](src/main/kotlin/g1201_1300/s1291_sequential_digits)| Medium | Enumeration, Udemy_Arrays | 114 | 100.00
-| 1290 |[Convert Binary Number in a Linked List to Integer](src/main/kotlin/g1201_1300/s1290_convert_binary_number_in_a_linked_list_to_integer)| Easy | Math, Linked_List, Programming_Skills_I_Day_10_Linked_List_and_Tree | 145 | 25.93
+| 1290 |[Convert Binary Number in a Linked List to Integer](src/main/kotlin/g1201_1300/s1290_convert_binary_number_in_a_linked_list_to_integer)| Easy | Math, Linked_List, Programming_Skills_I_Day_10_Linked_List_and_Tree | 138 | 65.79
 | 1289 |[Minimum Falling Path Sum II](src/main/kotlin/g1201_1300/s1289_minimum_falling_path_sum_ii)| Hard | Array, Dynamic_Programming, Matrix | 234 | 100.00
 | 1288 |[Remove Covered Intervals](src/main/kotlin/g1201_1300/s1288_remove_covered_intervals)| Medium | Array, Sorting | 184 | 100.00
 | 1287 |[Element Appearing More Than 25% In Sorted Array](src/main/kotlin/g1201_1300/s1287_element_appearing_more_than_25_in_sorted_array)| Easy | Array | 199 | 100.00
@@ -3416,7 +3428,7 @@
 | 1068 |[Product Sales Analysis I](src/main/kotlin/g1001_1100/s1068_product_sales_analysis_i)| Easy | Database | 1897 | 79.88
 | 1061 |[Lexicographically Smallest Equivalent String](src/main/kotlin/g1001_1100/s1061_lexicographically_smallest_equivalent_string)| Medium | String, Union_Find | 166 | 100.00
 | 1054 |[Distant Barcodes](src/main/kotlin/g1001_1100/s1054_distant_barcodes)| Medium | Array, Hash_Table, Sorting, Greedy, Heap_Priority_Queue, Counting | 622 | 75.00
-| 1053 |[Previous Permutation With One Swap](src/main/kotlin/g1001_1100/s1053_previous_permutation_with_one_swap)| Medium | Array, Greedy | 338 | 25.00
+| 1053 |[Previous Permutation With One Swap](src/main/kotlin/g1001_1100/s1053_previous_permutation_with_one_swap)| Medium | Array, Greedy | 288 | 100.00
 | 1052 |[Grumpy Bookstore Owner](src/main/kotlin/g1001_1100/s1052_grumpy_bookstore_owner)| Medium | Array, Sliding_Window | 268 | 80.00
 | 1051 |[Height Checker](src/main/kotlin/g1001_1100/s1051_height_checker)| Easy | Array, Sorting, Counting_Sort | 140 | 94.37
 | 1050 |[Actors and Directors Who Cooperated At Least Three Times](src/main/kotlin/g1001_1100/s1050_actors_and_directors_who_cooperated_at_least_three_times)| Easy | LeetCode_Curated_SQL_70, Database, SQL_I_Day_10_Where | 629 | 81.02
@@ -3755,7 +3767,7 @@
 | 0698 |[Partition to K Equal Sum Subsets](src/main/kotlin/g0601_0700/s0698_partition_to_k_equal_sum_subsets)| Medium | Array, Dynamic_Programming, Bit_Manipulation, Backtracking, Bitmask, Memoization | 191 | 100.00
 | 0697 |[Degree of an Array](src/main/kotlin/g0601_0700/s0697_degree_of_an_array)| Easy | Array, Hash_Table, Udemy_Arrays | 289 | 84.62
 | 0696 |[Count Binary Substrings](src/main/kotlin/g0601_0700/s0696_count_binary_substrings)| Easy | String, Two_Pointers | 222 | 100.00
-| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find, Algorithm_I_Day_7_Breadth_First_Search_Depth_First_Search, Graph_Theory_I_Day_2_Matrix_Related_Problems | 324 | 24.06
+| 0695 |[Max Area of Island](src/main/kotlin/g0601_0700/s0695_max_area_of_island)| Medium | Array, Depth_First_Search, Breadth_First_Search, Matrix, Union_Find, Algorithm_I_Day_7_Breadth_First_Search_Depth_First_Search, Graph_Theory_I_Day_2_Matrix_Related_Problems | 181 | 93.83
 | 0693 |[Binary Number with Alternating Bits](src/main/kotlin/g0601_0700/s0693_binary_number_with_alternating_bits)| Easy | Bit_Manipulation | 129 | 100.00
 | 0692 |[Top K Frequent Words](src/main/kotlin/g0601_0700/s0692_top_k_frequent_words)| Medium | String, Hash_Table, Sorting, Heap_Priority_Queue, Counting, Trie, Bucket_Sort, Level_1_Day_15_Heap | 239 | 81.10
 | 0691 |[Stickers to Spell Word](src/main/kotlin/g0601_0700/s0691_stickers_to_spell_word)| Hard | Array, String, Dynamic_Programming, Bit_Manipulation, Backtracking, Bitmask | 249 | 100.00
diff --git a/src/main/kotlin/g3101_3200/s3136_valid_word/readme.md b/src/main/kotlin/g3101_3200/s3136_valid_word/readme.md
new file mode 100644
index 00000000..fad081e4
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3136_valid_word/readme.md
@@ -0,0 +1,93 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3136\. Valid Word
+
+Easy
+
+A word is considered **valid** if:
+
+*   It contains a **minimum** of 3 characters.
+*   It contains only digits (0-9), and English letters (uppercase and lowercase).
+*   It includes **at least** one **vowel**.
+*   It includes **at least** one **consonant**.
+
+You are given a string `word`.
+
+Return `true` if `word` is valid, otherwise, return `false`.
+
+**Notes:**
+
+*   `'a'`, `'e'`, `'i'`, `'o'`, `'u'`, and their uppercases are **vowels**.
+*   A **consonant** is an English letter that is not a vowel.
+
+**Example 1:**
+
+**Input:** word = "234Adas"
+
+**Output:** true
+
+**Explanation:**
+
+This word satisfies the conditions.
+
+**Example 2:**
+
+**Input:** word = "b3"
+
+**Output:** false
+
+**Explanation:**
+
+The length of this word is fewer than 3, and does not have a vowel.
+
+**Example 3:**
+
+**Input:** word = "a3$e"
+
+**Output:** false
+
+**Explanation:**
+
+This word contains a `'$'` character and does not have a consonant.
+
+**Constraints:**
+
+*   `1 <= word.length <= 20`
+*   `word` consists of English uppercase and lowercase letters, digits, `'@'`, `'#'`, and `'$'`.
+
+## Solution
+
+```kotlin
+class Solution {
+    fun isValid(word: String): Boolean {
+        if (word.length < 3) {
+            return false
+        }
+        if (word.contains("@") || word.contains("#") || word.contains("$")) {
+            return false
+        }
+        val vowels = charArrayOf('a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U')
+        val consonants = charArrayOf(
+            'b', 'c', 'd', 'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'p', 'q', 'r', 's', 't', 'v',
+            'w', 'x', 'y', 'z', 'B', 'C', 'D', 'F', 'G', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'Q',
+            'R', 'S', 'T', 'V', 'W', 'X', 'Y', 'Z'
+        )
+        var flag1 = false
+        var flag2 = false
+        for (c in vowels) {
+            if (word.indexOf(c) != -1) {
+                flag1 = true
+                break
+            }
+        }
+        for (c in consonants) {
+            if (word.indexOf(c) != -1) {
+                flag2 = true
+                break
+            }
+        }
+        return flag1 && flag2
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3137_minimum_number_of_operations_to_make_word_k_periodic/readme.md b/src/main/kotlin/g3101_3200/s3137_minimum_number_of_operations_to_make_word_k_periodic/readme.md
new file mode 100644
index 00000000..271cd10f
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3137_minimum_number_of_operations_to_make_word_k_periodic/readme.md
@@ -0,0 +1,74 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3137\. Minimum Number of Operations to Make Word K-Periodic
+
+Medium
+
+You are given a string `word` of size `n`, and an integer `k` such that `k` divides `n`.
+
+In one operation, you can pick any two indices `i` and `j`, that are divisible by `k`, then replace the substring of length `k` starting at `i` with the substring of length `k` starting at `j`. That is, replace the substring `word[i..i + k - 1]` with the substring `word[j..j + k - 1]`.
+
+Return _the **minimum** number of operations required to make_ `word` _**k-periodic**_.
+
+We say that `word` is **k-periodic** if there is some string `s` of length `k` such that `word` can be obtained by concatenating `s` an arbitrary number of times. For example, if `word == “ababab”`, then `word` is 2-periodic for `s = "ab"`.
+
+**Example 1:**
+
+**Input:** word = "leetcodeleet", k = 4
+
+**Output:** 1
+
+**Explanation:**
+
+We can obtain a 4-periodic string by picking i = 4 and j = 0. After this operation, word becomes equal to "leetleetleet".
+
+**Example 2:**
+
+**Input:** word = "leetcoleet", k = 2
+
+**Output:** 3
+
+**Explanation:**
+
+We can obtain a 2-periodic string by applying the operations in the table below.
+
+    i  j  word
+    0  2  etetcoleet
+    4  0  etetetleet
+    6  0  etetetetet
+
+**Constraints:**
+
+*   1 <= n == word.length <= 105
+*   `1 <= k <= word.length`
+*   `k` divides `word.length`.
+*   `word` consists only of lowercase English letters.
+
+## Solution
+
+```kotlin
+import kotlin.math.max
+
+class Solution {
+    fun minimumOperationsToMakeKPeriodic(word: String, k: Int): Int {
+        val map: MutableMap = HashMap()
+        val n = word.length
+        var max = 0
+        var i = 0
+        while (i < n) {
+            var hash = 0
+            for (j in i until i + k) {
+                val idx = word[j].code - 'a'.code
+                hash = hash * 26 + idx
+            }
+            var count = map.getOrDefault(hash, 0)
+            count++
+            map[hash] = count
+            max = max(max, count)
+            i += k
+        }
+        return n / k - max
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3138_minimum_length_of_anagram_concatenation/readme.md b/src/main/kotlin/g3101_3200/s3138_minimum_length_of_anagram_concatenation/readme.md
new file mode 100644
index 00000000..697298e2
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3138_minimum_length_of_anagram_concatenation/readme.md
@@ -0,0 +1,96 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3138\. Minimum Length of Anagram Concatenation
+
+Medium
+
+You are given a string `s`, which is known to be a concatenation of **anagrams** of some string `t`.
+
+Return the **minimum** possible length of the string `t`.
+
+An **anagram** is formed by rearranging the letters of a string. For example, "aab", "aba", and, "baa" are anagrams of "aab".
+
+**Example 1:**
+
+**Input:** s = "abba"
+
+**Output:** 2
+
+**Explanation:**
+
+One possible string `t` could be `"ba"`.
+
+**Example 2:**
+
+**Input:** s = "cdef"
+
+**Output:** 4
+
+**Explanation:**
+
+One possible string `t` could be `"cdef"`, notice that `t` can be equal to `s`.
+
+**Constraints:**
+
+*   1 <= s.length <= 105
+*   `s` consist only of lowercase English letters.
+
+## Solution
+
+```kotlin
+import kotlin.math.sqrt
+
+class Solution {
+    fun minAnagramLength(s: String): Int {
+        val n = s.length
+        val sq = IntArray(n)
+        for (i in s.indices) {
+            val ch = s[i].code
+            if (i == 0) {
+                sq[i] = ch * ch
+            } else {
+                sq[i] = sq[i - 1] + ch * ch
+            }
+        }
+        val factors = getAllFactorsVer2(n)
+        factors.sort()
+        for (j in factors.indices) {
+            val factor = factors[j]
+            if (factor == 1) {
+                if (sq[0] * n == sq[n - 1]) {
+                    return 1
+                }
+            } else {
+                val sum = sq[factor - 1]
+                var start = 0
+                var i = factor - 1
+                while (i < n) {
+                    if (start + sum != sq[i]) {
+                        break
+                    }
+                    start += sum
+                    if (i == n - 1) {
+                        return factor
+                    }
+                    i += factor
+                }
+            }
+        }
+        return n - 1
+    }
+
+    private fun getAllFactorsVer2(n: Int): MutableList {
+        val factors: MutableList = ArrayList()
+        var i = 1
+        while (i <= sqrt(n.toDouble())) {
+            if (n % i == 0) {
+                factors.add(i)
+                factors.add(n / i)
+            }
+            i++
+        }
+        return factors
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3139_minimum_cost_to_equalize_array/readme.md b/src/main/kotlin/g3101_3200/s3139_minimum_cost_to_equalize_array/readme.md
new file mode 100644
index 00000000..bd8d49ef
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3139_minimum_cost_to_equalize_array/readme.md
@@ -0,0 +1,123 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3139\. Minimum Cost to Equalize Array
+
+Hard
+
+You are given an integer array `nums` and two integers `cost1` and `cost2`. You are allowed to perform **either** of the following operations **any** number of times:
+
+*   Choose an index `i` from `nums` and **increase** `nums[i]` by `1` for a cost of `cost1`.
+*   Choose two **different** indices `i`, `j`, from `nums` and **increase** `nums[i]` and `nums[j]` by `1` for a cost of `cost2`.
+
+Return the **minimum** **cost** required to make all elements in the array **equal**_._
+
+Since the answer may be very large, return it **modulo** 109 + 7.
+
+**Example 1:**
+
+**Input:** nums = [4,1], cost1 = 5, cost2 = 2
+
+**Output:** 15
+
+**Explanation:**
+
+The following operations can be performed to make the values equal:
+
+*   Increase `nums[1]` by 1 for a cost of 5. `nums` becomes `[4,2]`.
+*   Increase `nums[1]` by 1 for a cost of 5. `nums` becomes `[4,3]`.
+*   Increase `nums[1]` by 1 for a cost of 5. `nums` becomes `[4,4]`.
+
+The total cost is 15.
+
+**Example 2:**
+
+**Input:** nums = [2,3,3,3,5], cost1 = 2, cost2 = 1
+
+**Output:** 6
+
+**Explanation:**
+
+The following operations can be performed to make the values equal:
+
+*   Increase `nums[0]` and `nums[1]` by 1 for a cost of 1. `nums` becomes `[3,4,3,3,5]`.
+*   Increase `nums[0]` and `nums[2]` by 1 for a cost of 1. `nums` becomes `[4,4,4,3,5]`.
+*   Increase `nums[0]` and `nums[3]` by 1 for a cost of 1. `nums` becomes `[5,4,4,4,5]`.
+*   Increase `nums[1]` and `nums[2]` by 1 for a cost of 1. `nums` becomes `[5,5,5,4,5]`.
+*   Increase `nums[3]` by 1 for a cost of 2. `nums` becomes `[5,5,5,5,5]`.
+
+The total cost is 6.
+
+**Example 3:**
+
+**Input:** nums = [3,5,3], cost1 = 1, cost2 = 3
+
+**Output:** 4
+
+**Explanation:**
+
+The following operations can be performed to make the values equal:
+
+*   Increase `nums[0]` by 1 for a cost of 1. `nums` becomes `[4,5,3]`.
+*   Increase `nums[0]` by 1 for a cost of 1. `nums` becomes `[5,5,3]`.
+*   Increase `nums[2]` by 1 for a cost of 1. `nums` becomes `[5,5,4]`.
+*   Increase `nums[2]` by 1 for a cost of 1. `nums` becomes `[5,5,5]`.
+
+The total cost is 4.
+
+**Constraints:**
+
+*   1 <= nums.length <= 105
+*   1 <= nums[i] <= 106
+*   1 <= cost1 <= 106
+*   1 <= cost2 <= 106
+
+## Solution
+
+```kotlin
+import kotlin.math.max
+import kotlin.math.min
+
+class Solution {
+    fun minCostToEqualizeArray(nums: IntArray, cost1: Int, cost2: Int): Int {
+        var max = 0L
+        var min = Long.MAX_VALUE
+        var sum = 0L
+        for (num in nums) {
+            if (num > max) {
+                max = num.toLong()
+            }
+            if (num < min) {
+                min = num.toLong()
+            }
+            sum += num
+        }
+        val n = nums.size
+        var total = max * n - sum
+        // When operation one is always better:
+        if ((cost1 shl 1) <= cost2 || n <= 2) {
+            return (total * cost1 % LMOD).toInt()
+        }
+        // When operation two is moderately better:
+        var op1 = max(0L, (((max - min) shl 1L.toInt()) - total))
+        var op2 = total - op1
+        var result = (op1 + (op2 and 1L)) * cost1 + (op2 shr 1L.toInt()) * cost2
+        // When operation two is significantly better:
+        total += op1 / (n - 2L) * n
+        op1 %= n - 2L
+        op2 = total - op1
+        result = min(result, ((op1 + (op2 and 1L)) * cost1 + (op2 shr 1L.toInt()) * cost2))
+        // When operation two is always better:
+        for (i in 0..1) {
+            total += n.toLong()
+            result = min(result, ((total and 1L) * cost1 + (total shr 1L.toInt()) * cost2))
+        }
+        return (result % LMOD).toInt()
+    }
+
+    companion object {
+        private const val MOD = 1000000007
+        private const val LMOD = MOD.toLong()
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3142_check_if_grid_satisfies_conditions/readme.md b/src/main/kotlin/g3101_3200/s3142_check_if_grid_satisfies_conditions/readme.md
new file mode 100644
index 00000000..b2a2f61a
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3142_check_if_grid_satisfies_conditions/readme.md
@@ -0,0 +1,84 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3142\. Check if Grid Satisfies Conditions
+
+Easy
+
+You are given a 2D matrix `grid` of size `m x n`. You need to check if each cell `grid[i][j]` is:
+
+*   Equal to the cell below it, i.e. `grid[i][j] == grid[i + 1][j]` (if it exists).
+*   Different from the cell to its right, i.e. `grid[i][j] != grid[i][j + 1]` (if it exists).
+
+Return `true` if **all** the cells satisfy these conditions, otherwise, return `false`.
+
+**Example 1:**
+
+**Input:** grid = \[\[1,0,2],[1,0,2]]
+
+**Output:** true
+
+**Explanation:**
+
+****
+
+All the cells in the grid satisfy the conditions.
+
+**Example 2:**
+
+**Input:** grid = \[\[1,1,1],[0,0,0]]
+
+**Output:** false
+
+**Explanation:**
+
+****
+
+All cells in the first row are equal.
+
+**Example 3:**
+
+**Input:** grid = \[\[1],[2],[3]]
+
+**Output:** false
+
+**Explanation:**
+
+
+
+Cells in the first column have different values.
+
+**Constraints:**
+
+*   `1 <= n, m <= 10`
+*   `0 <= grid[i][j] <= 9`
+
+## Solution
+
+```kotlin
+class Solution {
+    fun satisfiesConditions(grid: Array): Boolean {
+        val m = grid.size
+        val n = grid[0].size
+        for (i in 0 until m - 1) {
+            if (n > 1) {
+                for (j in 0 until n - 1) {
+                    if ((grid[i][j] != grid[i + 1][j]) || (grid[i][j] == grid[i][j + 1])) {
+                        return false
+                    }
+                }
+            } else {
+                if (grid[i][0] != grid[i + 1][0]) {
+                    return false
+                }
+            }
+        }
+        for (j in 0 until n - 1) {
+            if (grid[m - 1][j] == grid[m - 1][j + 1]) {
+                return false
+            }
+        }
+        return true
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3143_maximum_points_inside_the_square/readme.md b/src/main/kotlin/g3101_3200/s3143_maximum_points_inside_the_square/readme.md
new file mode 100644
index 00000000..f8c24396
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3143_maximum_points_inside_the_square/readme.md
@@ -0,0 +1,95 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3143\. Maximum Points Inside the Square
+
+Medium
+
+You are given a 2D array `points` and a string `s` where, `points[i]` represents the coordinates of point `i`, and `s[i]` represents the **tag** of point `i`.
+
+A **valid** square is a square centered at the origin `(0, 0)`, has edges parallel to the axes, and **does not** contain two points with the same tag.
+
+Return the **maximum** number of points contained in a **valid** square.
+
+Note:
+
+*   A point is considered to be inside the square if it lies on or within the square's boundaries.
+*   The side length of the square can be zero.
+
+**Example 1:**
+
+
+
+**Input:** points = \[\[2,2],[-1,-2],[-4,4],[-3,1],[3,-3]], s = "abdca"
+
+**Output:** 2
+
+**Explanation:**
+
+The square of side length 4 covers two points `points[0]` and `points[1]`.
+
+**Example 2:**
+
+
+
+**Input:** points = \[\[1,1],[-2,-2],[-2,2]], s = "abb"
+
+**Output:** 1
+
+**Explanation:**
+
+The square of side length 2 covers one point, which is `points[0]`.
+
+**Example 3:**
+
+**Input:** points = \[\[1,1],[-1,-1],[2,-2]], s = "ccd"
+
+**Output:** 0
+
+**Explanation:**
+
+It's impossible to make any valid squares centered at the origin such that it covers only one point among `points[0]` and `points[1]`.
+
+**Constraints:**
+
+*   1 <= s.length, points.length <= 105
+*   `points[i].length == 2`
+*   -109 <= points[i][0], points[i][1] <= 109
+*   `s.length == points.length`
+*   `points` consists of distinct coordinates.
+*   `s` consists only of lowercase English letters.
+
+## Solution
+
+```kotlin
+import kotlin.math.abs
+import kotlin.math.max
+import kotlin.math.min
+
+class Solution {
+    fun maxPointsInsideSquare(points: Array, s: String): Int {
+        val tags = IntArray(26)
+        tags.fill(Int.MAX_VALUE)
+        var secondMin = Int.MAX_VALUE
+        for (i in s.indices) {
+            val dist = max(abs(points[i][0]), abs(points[i][1]))
+            val c = s[i]
+            if (tags[c.code - 'a'.code] == Int.MAX_VALUE) {
+                tags[c.code - 'a'.code] = dist
+            } else if (dist < tags[c.code - 'a'.code]) {
+                secondMin = min(secondMin, tags[c.code - 'a'.code])
+                tags[c.code - 'a'.code] = dist
+            } else {
+                secondMin = min(secondMin, dist)
+            }
+        }
+        var count = 0
+        for (dist in tags) {
+            if (dist < secondMin) {
+                count++
+            }
+        }
+        return count
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3144_minimum_substring_partition_of_equal_character_frequency/readme.md b/src/main/kotlin/g3101_3200/s3144_minimum_substring_partition_of_equal_character_frequency/readme.md
new file mode 100644
index 00000000..9f9857f5
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3144_minimum_substring_partition_of_equal_character_frequency/readme.md
@@ -0,0 +1,71 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3144\. Minimum Substring Partition of Equal Character Frequency
+
+Medium
+
+Given a string `s`, you need to partition it into one or more **balanced** substrings. For example, if `s == "ababcc"` then `("abab", "c", "c")`, `("ab", "abc", "c")`, and `("ababcc")` are all valid partitions, but ("a", **"bab"**, "cc"), (**"aba"**, "bc", "c"), and ("ab", **"abcc"**) are not. The unbalanced substrings are bolded.
+
+Return the **minimum** number of substrings that you can partition `s` into.
+
+**Note:** A **balanced** string is a string where each character in the string occurs the same number of times.
+
+**Example 1:**
+
+**Input:** s = "fabccddg"
+
+**Output:** 3
+
+**Explanation:**
+
+We can partition the string `s` into 3 substrings in one of the following ways: `("fab, "ccdd", "g")`, or `("fabc", "cd", "dg")`.
+
+**Example 2:**
+
+**Input:** s = "abababaccddb"
+
+**Output:** 2
+
+**Explanation:**
+
+We can partition the string `s` into 2 substrings like so: `("abab", "abaccddb")`.
+
+**Constraints:**
+
+*   `1 <= s.length <= 1000`
+*   `s` consists only of English lowercase letters.
+
+## Solution
+
+```kotlin
+import kotlin.math.min
+
+class Solution {
+    fun minimumSubstringsInPartition(s: String): Int {
+        val cs = s.toCharArray()
+        val n = cs.size
+        val dp = IntArray(n + 1)
+        dp.fill(n)
+        dp[0] = 0
+        for (i in 1..n) {
+            val count = IntArray(26)
+            var distinct = 0
+            var maxCount = 0
+            for (j in i - 1 downTo 0) {
+                val index = cs[j].code - 'a'.code
+                if (++count[index] == 1) {
+                    distinct++
+                }
+                if (count[index] > maxCount) {
+                    maxCount = count[index]
+                }
+                if (maxCount * distinct == i - j) {
+                    dp[i] = min(dp[i], (dp[j] + 1))
+                }
+            }
+        }
+        return dp[n]
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3145_find_products_of_elements_of_big_array/readme.md b/src/main/kotlin/g3101_3200/s3145_find_products_of_elements_of_big_array/readme.md
new file mode 100644
index 00000000..562ba2ea
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3145_find_products_of_elements_of_big_array/readme.md
@@ -0,0 +1,106 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3145\. Find Products of Elements of Big Array
+
+Hard
+
+A **powerful array** for an integer `x` is the shortest sorted array of powers of two that sum up to `x`. For example, the powerful array for 11 is `[1, 2, 8]`.
+
+The array `big_nums` is created by concatenating the **powerful** arrays for every positive integer `i` in ascending order: 1, 2, 3, and so forth. Thus, `big_nums` starts as [1, 2, 1, 2, 4, 1, 4, 2, 4, 1, 2, 4, 8, ...].
+
+You are given a 2D integer matrix `queries`, where for queries[i] = [fromi, toi, modi] you should calculate (big_nums[fromi] * big_nums[fromi + 1] * ... * big_nums[toi]) % modi.
+
+Return an integer array `answer` such that `answer[i]` is the answer to the ith query.
+
+**Example 1:**
+
+**Input:** queries = \[\[1,3,7]]
+
+**Output:** [4]
+
+**Explanation:**
+
+There is one query.
+
+`big_nums[1..3] = [2,1,2]`. The product of them is 4. The remainder of 4 under 7 is 4.
+
+**Example 2:**
+
+**Input:** queries = \[\[2,5,3],[7,7,4]]
+
+**Output:** [2,2]
+
+**Explanation:**
+
+There are two queries.
+
+First query: `big_nums[2..5] = [1,2,4,1]`. The product of them is 8. The remainder of 8 under 3 is 2.
+
+Second query: `big_nums[7] = 2`. The remainder of 2 under 4 is 2.
+
+**Constraints:**
+
+*   `1 <= queries.length <= 500`
+*   `queries[i].length == 3`
+*   0 <= queries[i][0] <= queries[i][1] <= 1015
+*   1 <= queries[i][2] <= 105
+
+## Solution
+
+```kotlin
+class Solution {
+    fun findProductsOfElements(queries: Array): IntArray {
+        val ans = IntArray(queries.size)
+        for (i in queries.indices) {
+            val q = queries[i]
+            val er = sumE(q[1] + 1)
+            val el = sumE(q[0])
+            ans[i] = pow(2, er - el, q[2])
+        }
+        return ans
+    }
+
+    private fun sumE(k: Long): Long {
+        var k = k
+        var res: Long = 0
+        var n: Long = 0
+        var cnt1: Long = 0
+        var sumI: Long = 0
+        for (i in 63L - java.lang.Long.numberOfLeadingZeros(k + 1) downTo 1) {
+            val c = (cnt1 shl i.toInt()) + (i shl (i - 1).toInt())
+            if (c <= k) {
+                k -= c
+                res += (sumI shl i.toInt()) + ((i * (i - 1) / 2) shl (i - 1).toInt())
+                sumI += i
+                cnt1++
+                n = n or (1L shl i.toInt())
+            }
+        }
+        if (cnt1 <= k) {
+            k -= cnt1
+            res += sumI
+            n++
+        }
+        while (k-- > 0) {
+            res += java.lang.Long.numberOfTrailingZeros(n).toLong()
+            n = n and n - 1
+        }
+        return res
+    }
+
+    private fun pow(x: Long, n: Long, mod: Long): Int {
+        var x = x
+        var n = n
+        var res = 1 % mod
+        while (n > 0) {
+            if (n % 2 == 1L) {
+                res = (res * x) % mod
+            }
+            x = (x * x) % mod
+            n /= 2
+        }
+        return res.toInt()
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3146_permutation_difference_between_two_strings/readme.md b/src/main/kotlin/g3101_3200/s3146_permutation_difference_between_two_strings/readme.md
new file mode 100644
index 00000000..e92622ea
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3146_permutation_difference_between_two_strings/readme.md
@@ -0,0 +1,64 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3146\. Permutation Difference between Two Strings
+
+Easy
+
+You are given two strings `s` and `t` such that every character occurs at most once in `s` and `t` is a permutation of `s`.
+
+The **permutation difference** between `s` and `t` is defined as the **sum** of the absolute difference between the index of the occurrence of each character in `s` and the index of the occurrence of the same character in `t`.
+
+Return the **permutation difference** between `s` and `t`.
+
+**Example 1:**
+
+**Input:** s = "abc", t = "bac"
+
+**Output:** 2
+
+**Explanation:**
+
+For `s = "abc"` and `t = "bac"`, the permutation difference of `s` and `t` is equal to the sum of:
+
+*   The absolute difference between the index of the occurrence of `"a"` in `s` and the index of the occurrence of `"a"` in `t`.
+*   The absolute difference between the index of the occurrence of `"b"` in `s` and the index of the occurrence of `"b"` in `t`.
+*   The absolute difference between the index of the occurrence of `"c"` in `s` and the index of the occurrence of `"c"` in `t`.
+
+That is, the permutation difference between `s` and `t` is equal to `|0 - 1| + |2 - 2| + |1 - 0| = 2`.
+
+**Example 2:**
+
+**Input:** s = "abcde", t = "edbac"
+
+**Output:** 12
+
+**Explanation:** The permutation difference between `s` and `t` is equal to `|0 - 3| + |1 - 2| + |2 - 4| + |3 - 1| + |4 - 0| = 12`.
+
+**Constraints:**
+
+*   `1 <= s.length <= 26`
+*   Each character occurs at most once in `s`.
+*   `t` is a permutation of `s`.
+*   `s` consists only of lowercase English letters.
+
+## Solution
+
+```kotlin
+import kotlin.math.abs
+
+class Solution {
+    fun findPermutationDifference(s: String, t: String): Int {
+        val res = IntArray(26)
+        res.fill(-1)
+        var sum = 0
+        for (i in s.indices) {
+            res[s[i].code - 'a'.code] = i
+        }
+        for (i in t.indices) {
+            sum += abs((res[t[i].code - 'a'.code] - i))
+        }
+        return sum
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3147_taking_maximum_energy_from_the_mystic_dungeon/readme.md b/src/main/kotlin/g3101_3200/s3147_taking_maximum_energy_from_the_mystic_dungeon/readme.md
new file mode 100644
index 00000000..8adb99f7
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3147_taking_maximum_energy_from_the_mystic_dungeon/readme.md
@@ -0,0 +1,59 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3147\. Taking Maximum Energy From the Mystic Dungeon
+
+Medium
+
+In a mystic dungeon, `n` magicians are standing in a line. Each magician has an attribute that gives you energy. Some magicians can give you negative energy, which means taking energy from you.
+
+You have been cursed in such a way that after absorbing energy from magician `i`, you will be instantly transported to magician `(i + k)`. This process will be repeated until you reach the magician where `(i + k)` does not exist.
+
+In other words, you will choose a starting point and then teleport with `k` jumps until you reach the end of the magicians' sequence, **absorbing all the energy** during the journey.
+
+You are given an array `energy` and an integer `k`. Return the **maximum** possible energy you can gain.
+
+**Example 1:**
+
+**Input:** energy = [5,2,-10,-5,1], k = 3
+
+**Output:** 3
+
+**Explanation:** We can gain a total energy of 3 by starting from magician 1 absorbing 2 + 1 = 3.
+
+**Example 2:**
+
+**Input:** energy = [-2,-3,-1], k = 2
+
+**Output:** -1
+
+**Explanation:** We can gain a total energy of -1 by starting from magician 2.
+
+**Constraints:**
+
+*   1 <= energy.length <= 105
+*   `-1000 <= energy[i] <= 1000`
+*   `1 <= k <= energy.length - 1`
+
+## Solution
+
+```kotlin
+import kotlin.math.max
+
+class Solution {
+    fun maximumEnergy(energy: IntArray, k: Int): Int {
+        var max = Int.MIN_VALUE
+        val n = energy.size
+        for (i in n - 1 downTo n - k) {
+            var en = 0
+            var j = i
+            while (j >= 0) {
+                en += energy[j]
+                max = max(en, max)
+                j -= k
+            }
+        }
+        return max
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3148_maximum_difference_score_in_a_grid/readme.md b/src/main/kotlin/g3101_3200/s3148_maximum_difference_score_in_a_grid/readme.md
new file mode 100644
index 00000000..16d2372a
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3148_maximum_difference_score_in_a_grid/readme.md
@@ -0,0 +1,82 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3148\. Maximum Difference Score in a Grid
+
+Medium
+
+You are given an `m x n` matrix `grid` consisting of **positive** integers. You can move from a cell in the matrix to **any** other cell that is either to the bottom or to the right (not necessarily adjacent). The score of a move from a cell with the value `c1` to a cell with the value `c2` is `c2 - c1`.
+
+You can start at **any** cell, and you have to make **at least** one move.
+
+Return the **maximum** total score you can achieve.
+
+**Example 1:**
+
+
+
+**Input:** grid = \[\[9,5,7,3],[8,9,6,1],[6,7,14,3],[2,5,3,1]]
+
+**Output:** 9
+
+**Explanation:** We start at the cell `(0, 1)`, and we perform the following moves:   
+
+- Move from the cell `(0, 1)` to `(2, 1)` with a score of `7 - 5 = 2`.   
+
+- Move from the cell `(2, 1)` to `(2, 2)` with a score of `14 - 7 = 7`.   
+
+The total score is `2 + 7 = 9`.
+
+**Example 2:**
+
+
+
+**Input:** grid = \[\[4,3,2],[3,2,1]]
+
+**Output:** \-1
+
+**Explanation:** We start at the cell `(0, 0)`, and we perform one move: `(0, 0)` to `(0, 1)`. The score is `3 - 4 = -1`.
+
+**Constraints:**
+
+*   `m == grid.length`
+*   `n == grid[i].length`
+*   `2 <= m, n <= 1000`
+*   4 <= m * n <= 105
+*   1 <= grid[i][j] <= 105
+
+## Solution
+
+```kotlin
+import kotlin.math.max
+
+class Solution {
+    fun maxScore(grid: List>): Int {
+        val m = grid.size - 1
+        var row = grid[m]
+        var n = row.size
+        val maxRB = IntArray(n--)
+        maxRB[n] = row[n]
+        var mx = maxRB[n]
+        var result = Int.MIN_VALUE
+        for (i in n - 1 downTo 0) {
+            val x = row[i]
+            result = max(result, (mx - x))
+            mx = max(mx, x)
+            maxRB[i] = mx
+        }
+        for (i in m - 1 downTo 0) {
+            row = grid[i]
+            mx = 0
+            for (j in n downTo 0) {
+                mx = max(mx, maxRB[j])
+                val x = row[j]
+                result = max(result, (mx - x))
+                mx = max(mx, x)
+                maxRB[j] = mx
+            }
+        }
+        return result
+    }
+}
+```
\ No newline at end of file
diff --git a/src/main/kotlin/g3101_3200/s3149_find_the_minimum_cost_array_permutation/readme.md b/src/main/kotlin/g3101_3200/s3149_find_the_minimum_cost_array_permutation/readme.md
new file mode 100644
index 00000000..d1912121
--- /dev/null
+++ b/src/main/kotlin/g3101_3200/s3149_find_the_minimum_cost_array_permutation/readme.md
@@ -0,0 +1,110 @@
+[](https://github.com/javadev/LeetCode-in-Kotlin)
+[](https://github.com/javadev/LeetCode-in-Kotlin/fork)
+
+## 3149\. Find the Minimum Cost Array Permutation
+
+Hard
+
+You are given an array `nums` which is a permutation of `[0, 1, 2, ..., n - 1]`. The **score** of any permutation of `[0, 1, 2, ..., n - 1]` named `perm` is defined as:
+
+`score(perm) = |perm[0] - nums[perm[1]]| + |perm[1] - nums[perm[2]]| + ... + |perm[n - 1] - nums[perm[0]]|`
+
+Return the permutation `perm` which has the **minimum** possible score. If _multiple_ permutations exist with this score, return the one that is lexicographically smallest among them.
+
+**Example 1:**
+
+**Input:** nums = [1,0,2]
+
+**Output:** [0,1,2]
+
+**Explanation:**
+
+****
+
+The lexicographically smallest permutation with minimum cost is `[0,1,2]`. The cost of this permutation is `|0 - 0| + |1 - 2| + |2 - 1| = 2`.
+
+**Example 2:**
+
+**Input:** nums = [0,2,1]
+
+**Output:** [0,2,1]
+
+**Explanation:**
+
+****
+
+The lexicographically smallest permutation with minimum cost is `[0,2,1]`. The cost of this permutation is `|0 - 1| + |2 - 2| + |1 - 0| = 2`.
+
+**Constraints:**
+
+*   `2 <= n == nums.length <= 14`
+*   `nums` is a permutation of `[0, 1, 2, ..., n - 1]`.
+
+## Solution
+
+```kotlin
+import kotlin.math.abs
+import kotlin.math.min
+
+class Solution {
+    private fun findMinScore(mask: Int, prevNum: Int, nums: IntArray, dp: Array): Int {
+        val n = nums.size
+        if (Integer.bitCount(mask) == n) {
+            dp[mask][prevNum] = abs((prevNum - nums[0]))
+            return dp[mask][prevNum]
+        }
+        if (dp[mask][prevNum] != -1) {
+            return dp[mask][prevNum]
+        }
+        var minScore = Int.MAX_VALUE
+        for (currNum in 0 until n) {
+            if ((mask shr currNum and 1 xor 1) == 1) {
+                val currScore = (
+                    abs((prevNum - nums[currNum])) + findMinScore(
+                        mask or (1 shl currNum),
+                        currNum,
+                        nums,
+                        dp
+                    )
+                    )
+                minScore = min(minScore, currScore)
+            }
+        }
+        return minScore.also { dp[mask][prevNum] = it }
+    }
+
+    private fun constructMinScorePermutation(n: Int, nums: IntArray, dp: Array): IntArray {
+        val permutation = IntArray(n)
+        var i = 0
+        permutation[i++] = 0
+        var prevNum = 0
+        var mask = 1
+        while (i < n) {
+            for (currNum in 0 until n) {
+                if ((mask shr currNum and 1 xor 1) == 1) {
+                    val currScore =
+                        (abs((prevNum - nums[currNum])) + dp[mask or (1 shl currNum)][currNum])
+                    val minScore = dp[mask][prevNum]
+                    if (currScore == minScore) {
+                        permutation[i++] = currNum
+                        prevNum = currNum
+                        break
+                    }
+                }
+            }
+            mask = mask or (1 shl prevNum)
+        }
+        return permutation
+    }
+
+    fun findPermutation(nums: IntArray): IntArray {
+        val n = nums.size
+        val dp = Array(1 shl n) { IntArray(n) }
+        for (row in dp) {
+            row.fill(-1)
+        }
+        findMinScore(1, 0, nums, dp)
+        return constructMinScorePermutation(n, nums, dp)
+    }
+}
+```
\ No newline at end of file