You are given a node that is the beginning of a linked list. This list always contains a tail and a loop.
Your objective is to determine the length of the loop.
For example in the following picture the tail's size is 3 and the loop size is 11.
// Use the `getNext()` method to get the following node.
node.getNext()
Note: do NOT mutate the nodes!
Thanks to shadchnev, I broke all of the methods from the Hash class.
Don't miss dmitry's article in the discussion after you pass the Kata !!
import java.util.ArrayList;
import java.util.List;
public class LoopInspector {
public int loopSize(Node node) {
List<node> list = new ArrayList<>();
int index =0;
while(true){
index = list.indexOf(node);
if(index == -1)
list.add(node);
else
break;
node = node.getNext();
}
return list.size()-index;
}
}
Write a function that takes in a string of one or more words, and returns the same string, but with all five or more letter words reversed (Just like the name of this Kata). Strings passed in will consist of only letters and spaces. Spaces will be included only when more than one word is present.
Your friend won't stop texting his girlfriend. It's all he does. All day. Seriously. The texts are so mushy too! The whole situation just makes you feel ill. Being the wonderful friend that you are, you hatch an evil plot. While he's sleeping, you take his phone and change the autocorrect options so that every time he types "you" or "u" it gets changed to "your sister."
Write a function called autocorrect that takes a string and replaces all instances of "you" or "u" (not case sensitive) with "your sister" (always lower case).
Return the resulting string.
Here's the slightly tricky part: These are text messages, so there are different forms of "you" and "u".
For the purposes of this kata, here's what you need to support:
"youuuuu" with any number of u characters tacked onto the end
"u" at the beginning, middle, or end of a string, but NOT part of a word
"you" but NOT as part of another word like youtube or bayou
public class Kata {
public static String autocorrect(String input) {
return input.replaceAll("(?i)\\b(u|you+)\\b", "your sister");
}
}
Complete the method so that it formats the words into a single comma separated value. The last word should be separated by the word 'and' instead of a comma. The method takes in an array of strings and returns a single formatted string. Empty string values should be ignored. Empty arrays or null/nil values being passed into the method should result in an empty string being returned.
Kata.formatWords(new String[] {"ninja", "samurai", "ronin"}) => "ninja, samurai and ronin"
Kata.formatWords(new String[] {"ninja", "", "ronin"}) => "ninja and ronin"
Kata.formatWords(new String[] {}) => ""
import java.util.Arrays;
import java.util.stream.Collectors;
public class Kata {
public static String replaceLast(String str, String regex, String replacement) {
int regexIndexOf = str.lastIndexOf(regex);
if(regexIndexOf == -1){
return str;
}else{
return str.substring(0, regexIndexOf) + replacement + str.substring(regexIndexOf + regex.length());
}
}
public static String formatWords(String[] words) {
// Do the things...
if(words == null) return "";
return replaceLast(Arrays.stream(words).filter(word -> !word.equals("")).collect(Collectors.joining(", ")),", "," and ");
}
}
In baseball, the batting average is a simple and most common way to measure a hitter's performace. Batting average is calculated by taking all the players hits and dividing it by their number of at_bats, and it is usually displayed as a 3 digit decimal (i.e. 0.300).
Given a yankees table with the following schema,
-player_id STRING
-player_name STRING
-primary_position STRING
-games INTEGER
-at_bats INTEGER
-hits INTEGER
return a table with player_name, games, and batting_average.
We want batting_average to be rounded to the nearest thousandth, since that is how baseball fans are used to seeing it. Format it as text and make sure it has 3 digits to the right of the decimal (pad with zeroes if neccesary).
Next, order our resulting table by batting_average, with the highest average in the first row.
Finally, since batting_average is a rate statistic, a small number of at_bats can change the average dramatically. To correct for this, exclude any player who doesn't have at least 100 at bats.
Expected Output Table
-player_name STRING
-games INTEGER
-batting_average STRING
select player_name,
games,
round(hits::numeric / at_bats, 3)::text as batting_average
from yankees
where at_bats > 100
order by batting_average desc
Your task in order to complete this Kata is to write a function which formats a duration, given as a number of seconds, in a human-friendly way.
The function must accept a non-negative integer. If it is zero, it just returns "now". Otherwise, the duration is expressed as a combination of years, days, hours, minutes and seconds.
It is much easier to understand with an example:
TimeFormatter.formatDuration(62) //returns "1 minute and 2 seconds"
TimeFormatter.formatDuration(3662) //returns "1 hour, 1 minute and 2 seconds"
For the purpose of this Kata, a year is 365 days and a day is 24 hours.
Note that spaces are important.
Detailed rules
The resulting expression is made of components like 4 seconds, 1 year, etc. In general, a positive integer and one of the valid units of time, separated by a space. The unit of time is used in plural if the integer is greater than 1.
The components are separated by a comma and a space (", "). Except the last component, which is separated by " and ", just like it would be written in English.
A more significant units of time will occur before than a least significant one. Therefore, 1 second and 1 year is not correct, but 1 year and 1 second is.
Different components have different unit of times. So there is not repeated units like in 5 seconds and 1 second.
A component will not appear at all if its value happens to be zero. Hence, 1 minute and 0 seconds is not valid, but it should be just 1 minute.
A unit of time must be used "as much as possible". It means that the function should not return 61 seconds, but 1 minute and 1 second instead. Formally, the duration specified by of a component must not be greater than any valid more significant unit of time.
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.List;
public class TimeFormatter {
public static String formatDuration(int seconds) {
// your code goes here
int d = seconds / 86400;
seconds %= 86400;
int h = seconds / 3600;
seconds %= 3600;
int m = seconds / 60;
seconds %= 60;
List<String> list = new ArrayList<>();
if(d != 0)
if(d > 1)
list.add(d+" days");
else
list.add(d+" days");
if(h != 0)
if(h > 1)
list.add(h+" hours");
else
list.add(h+" hour");
if(m != 0)
if(m > 1)
list.add(m+" minutes");
else
list.add(m+" minute");
if(seconds!= 0)
if(seconds > 1)
list.add(seconds+" seconds");
else
list.add(seconds+" second");
String format;
if(list.size() ==4){
format = "{0}, {1}, {2} and {3}";
}else if(list.size()==3) {
format = "{0}, {1} and {2}";
}else if(list.size() ==2) {
format = "{0} and {1}";
}else {
format = "{0}";
}
return MessageFormat.format(format, list.toArray());
}
}
Complete the function/method so that it takes CamelCase string and returns the string in snake_case notation. Lowercase characters can be numbers. If method gets number, it should return string.
Examples:
// returns test_controller
toUnderscore('TestController');
// returns movies_and_books
toUnderscore('MoviesAndBooks');
// returns app7_test
toUnderscore('App7Test');
// returns "1"
toUnderscore(1);
function toUnderscore(string) {
return string.toString().replace(/\.?([A-Z])/g, function (x,y){return "_" + y.toLowerCase()}).replace(/^_/, "");
}
Two tortoises named A and B must run a race. A starts with an average speed of 720 feet per hour. Young B knows she runs faster than A, and furthermore has not finished her cabbage.
When she starts, at last, she can see that A has a 70 feet lead but B's speed is 850 feet per hour. How long will it take B to catch A?
More generally: given two speeds v1 (A's speed, integer > 0) and v2 (B's speed, integer > 0) and a lead g (integer > 0) how long will it take B to catch A?
The result will be an array [hour, min, sec] which is the time needed in hours, minutes and seconds (round down to the nearest second) or a string in some languages.
If v1 >= v2 then return nil, nothing, null, None or {-1, -1, -1} for C++, C, Go, Nim, [] for Kotlin or "-1 -1 -1".
Examples:
(form of the result depends on the language)
race(720, 850, 70) => [0, 32, 18] or "0 32 18"
race(80, 91, 37) => [3, 21, 49] or "3 21 49"
public class Tortoise {
public static int[] race(int v1, int v2, int g) {
if(v2 -v2 < 0)
return null;
double d = Double.valueOf(g)/(v2-v1);
int hours = (int) d;
int minutes = (int) (d * 60) % 60;
int seconds = (int) (d * (60*60)) % 60;
return new int [] {hours,minutes,seconds};
}
}
Given an array of one's and zero's convert the equivalent binary value to an integer.
Eg: [0, 0, 0, 1] is treated as 0001 which is the binary representation of 1.
Examples:
Testing: [0, 0, 0, 1] ==> 1
Testing: [0, 0, 1, 0] ==> 2
Testing: [0, 1, 0, 1] ==> 5
Testing: [1, 0, 0, 1] ==> 9
Testing: [0, 0, 1, 0] ==> 2
Testing: [0, 1, 1, 0] ==> 6
Testing: [1, 1, 1, 1] ==> 15
Testing: [1, 0, 1, 1] ==> 11
However, the arrays can have varying lengths, not just limited to 4.
import java.util.List;
import java.util.stream.Collectors;
public class BinaryArrayToNumber {
public static int ConvertBinaryArrayToInt(List<Integer> binary) {
// Your Code
return Integer.parseInt(String.join("",binary.stream().map(String::valueOf).collect(Collectors.joining())), 2);
}
}
For each symbol in the string if it's the first character occurence, replace it with a '1', else replace it with the amount of times you've already seen it...
But will your code be performant enough?
Examples:
input = "Hello, World!"
result = "1112111121311"
input = "aaaaaaaaaaaa"
result = "123456789101112"
Note: there will be no int domain overflow (character occurences will be less than 2 billion).
import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
public class JomoPipi {
public static String numericals(String s) {
Map<String, AtomicInteger> map = new HashMap<>();
StringBuilder result = new StringBuilder();
for (String element :s.split("")) {
int temp;
if(map.containsKey(element)){
temp=map.get(element).incrementAndGet();
}else{
temp = 1;
map.put(element, new AtomicInteger(1));
}
result.append(temp);
}
return result.toString();
}
}