CodingBat is an online coding practice platform for java. Their question help greatly in logical thinking which a most important for the programmer.
So let see the coding.
The squirrels in Palo Alto spend most of the day playing. In particular, they play if the temperature is between 60 and 90 (inclusive). Unless it is summer, then the upper limit is 100 instead of 90. Given an int temperature and a boolean isSummer, return true if the squirrels play and false otherwise.
public boolean squirrelPlay(int temp, boolean isSummer) {
if (temp > 60 && temp < 90 && isSummer == false)
return true;
else if (temp > 60 && temp < 100 && isSummer == true)
return true;
else
return false;
}
You are driving a little too fast, and a police officer stops you. Write code to compute the result, encoded as an int value: 0=no ticket, 1=small ticket, 2=big ticket. If speed is 60 or less, the result is 0. If speed is between 61 and 80 inclusive, the result is 1. If speed is 81 or more, the result is 2. Unless it is your birthday -- on that day, your speed can be 5 higher in all cases.
public int caughtSpeeding(int speed, boolean isBirthday) {
if ((speed < 60 && isBirthday == false) || (speed < 65 && isBirthday == true))
return 0;
else if ((speed > 61 && speed < 80 && isBirthday == false) ||
(speed > 66 && speed < 85 && isBirthday == true))
return 1;
else
return 2;
}
Given 2 ints, a and b, return their sum. However, sums in the range 10..19 inclusive, are forbidden, so in that case just return 20.
public int sortaSum(int a, int b) {
if (a + b >= 10 && a + b <= 19) return 20;
else return a + b;
}
Given a day of the week encoded as 0=Sun, 1=Mon, 2=Tue, ...6=Sat, and a boolean indicating if we are on vacation, return a string of the form "7:00" indicating when the alarm clock should ring. Weekdays, the alarm should be "7:00" and on the weekend it should be "10:00". Unless we are on vacation -- then on weekdays it should be "10:00" and weekends it should be "off".
public String alarmClock(int day, boolean vacation) {
if ((day >= 1 && day <= 5) && vacation == false) return "7:00";
else if ((day == 0 || day == 6) && vacation == false) return "10:00";
else {
if (vacation == true && day >= 1 && day <= 5) return "10:00";
else return "off";
}
}
The number 6 is a truly great number. Given two int values, a and b, return true if either one is 6. Or if their sum or difference is 6. Note: the function Math.abs(num) computes the absolute value of a number.
public boolean love6(int a, int b) {
if (a == 6 || b == 6) return true;
else if ((a + b) == 6) return true;
else if ((a - b) == 6 || (b - a) == 6) return true;
else return false;
}
Given a number n, return true if n is in the range 1..10, inclusive. Unless outsideMode is true, in which case return true if the number is less or equal to 1, or greater or equal to 10.
public boolean in1To10(int n, boolean outsideMode) {
if (n >= 1 && n <= 10 && outsideMode == false) return true;
else if (outsideMode == true &&
(n <= 1 || n >= 10)) return true;
else return false;
}
We'll say a number is special if it is a multiple of 11 or if it is one more than a multiple of 11. Return true if the given non-negative number is special. Use the % "mod" operator
public boolean specialEleven(int n) {
if (n % 11 == 0 || n % 11 == 1) return true;
else return false;
}
Return true if the given non-negative number is 1 or 2 more than a multiple of 20.
public boolean more20(int n) {
if (n % 20 == 1 || n % 20 == 2) return true;
else return false;
}
Return true if the given non-negative number is a multiple of 3 or 5, but not both. Use the % "mod" operator
public boolean old35(int n) {
if ((n % 3 == 0) && (n % 5 == 0)) {
return false;
}
if (n % 3 == 0) {
return true;
}
if (n % 5 == 0) {
return true;
}
return false;
}
Return true if the given non-negative number is 1 or 2 less than a multiple of 20. So for example 38 and 39 return true, but 40 returns false.
public boolean less20(int n) {
if ((n % 20) == 18 || (n % 20) == 19) {
return true;
} else return false;
}
Given a non-negative number "num", return true if num is within 2 of a multiple of 10. Note: (a % b) is the remainder of dividing a by b, so (7 % 5) is 2.
public boolean nearTen(int num) {
if ((num % 10 <= 2) || (num % 10 >= 8)) return true;
else return false;
}
Given 2 ints, a and b, return their sum. However, "teen" values in the range 13..19 inclusive, are extra lucky. So if either value is a teen, just return 19.
public int teenSum(int a, int b) {
if (a >= 13 && a <= 19 || b <= 19 && b >= 13) return 19;
else if (a == 13 || a == 19 || b == 19 || b == 13) return 19;
else return a + b;
}
Your cell phone rings. Return true if you should answer it. Normally you answer, except in the morning you only answer if it is your mom calling. In all cases, if you are asleep, you do not answer.
public boolean answerCell(boolean isMorning, boolean isMom, boolean isAsleep) {
if (isAsleep == true) return false;
if ((isMorning == true) && (isMom == true)) {
return true;
}
if ((isMorning == true) && (isMom == false)) {
return false;
}
return true;
}
We are having a party with amounts of tea and candy. Return the int outcome of the party encoded as 0=bad, 1=good, or 2=great. A party is good (1) if both tea and candy are at least 5. However, if either tea or candy is at least double the amount of the other one, the party is great (2). However, in all cases, if either tea or candy is less than 5, the party is always bad (0).
public int teaParty(int tea, int candy) {
if (tea >= 5 && candy >= 5) {
if (tea >= 2 * candy || candy >= 2 * tea) {
return 2;
} else {
return 1;
}
} else return 0;
}
Given a string str, if the string starts with "f" return "Fizz". If the string ends with "b" return "Buzz". If both the "f" and "b" conditions are true, return "FizzBuzz". In all other cases, return the string unchanged
public String fizzString(String str) {
if ((str.startsWith("f")) &&
(str.endsWith("b"))) return "FizzBuzz";
if (str.startsWith("f")) return "Fizz";
if (str.endsWith("b")) return "Buzz";
return str;
}
Given an int n, return the string form of the number followed by "!". So the int 6 yields "6!". Except if the number is divisible by 3 use "Fizz" instead of the number, and if the number is divisible by 5 use "Buzz", and if divisible by both 3 and 5, use "FizzBuzz". Note: the % "mod" operator computes the remainder after division, so 23 % 10 yields 3. What will the remainder be when one number divides evenly into another?
public String fizzString2(int n) {
if ((n % 3 == 0) &&
(n % 5 == 0)) return "FizzBuzz!";
if (n % 3 == 0) return "Fizz!";
if (n % 5 == 0) return "Buzz!";
return n + "!";
}
Given three ints, a b c, return true if it is possible to add two of the ints to get the third.
public boolean twoAsOne(int a, int b, int c) {
if (a + b == c || b + c == a || c + a == b) return true;
else return false;
}
Given three ints, a b c, return true if b is greater than a, and c is greater than b. However, with the exception that if "bOk" is true, b does not need to be greater than a.
public boolean inOrder(int a, int b, int c, boolean bOk) {
if (b >a& &c> b && bOk == false) return true;
else if (bOk == true && c >b) return true; else return false;
}
Given three ints, a b c, return true if they are in strict increasing order, such as 2 5 11, or 5 6 7, but not 6 5 7 or 5 5 7. However, with the exception that if "equalOk" is true, equality is allowed, such as 5 5 7 or 5 5 5.
public boolean inOrderEqual(int a, int b, int c, boolean equalOk) {
if (((equalOk == true) &&
(a <= b && b <= c)) || ((equalOk == false) &&
(a <b& &b< c))) {
return true;
} else {
return false;
}
}
Given three ints, a b c, return true if two or more of them have the same rightmost digit. The ints are non-negative. Note: the % "mod" operator computes the remainder, e.g. 17 % 10 is 7.
public boolean lastDigit(int a, int b, int c) {
if (a % 10 == b % 10 || b % 10 == c % 10 || c % 10 == a % 10) return true;
else return false;
}
Return the sum of two 6-sided dice rolls, each in the range 1..6. However, if noDoubles is true, if the two dice show the same value, increment one die to the next value, wrapping around to 1 if its value was 6.
public int withoutDoubles(int die1, int die2, boolean noDoubles) {
if (noDoubles == true) {
if ((die1 == die2) &&
(die1 != 6 && die2 != 6)) return die1 + die2 + 1;
else if (die1 == 6 && die2 == 6) return die1 + 1;
else return die1 + die2;
} else return die1 + die2;
}
Given two int values, return whichever value is larger. However if the two values have the same remainder when divided by 5, then the return the smaller value. However, in all cases, if the two values are the same, return 0. Note: the % "mod" operator computes the remainder, e.g. 7 % 5 is 2.
public int maxMod5(int a, int b) {
if (a == b) return 0;
else {
if (a % 5 == b % 5) {
if (a <b) return a; else return b; } else { if(a> b) return a;
else return b;
}
}
}
You have a red lottery ticket showing ints a, b, and c, each of which is 0, 1, or 2. If they are all the value 2, the result is 10. Otherwise if they are all the same, the result is 5. Otherwise so long as both b and c are different from a, the result is 1. Otherwise the result is 0.
public int redTicket(int a, int b, int c) {
if (a == 2 && b == 2 && c == 2) return 10;
else if (a == b && b == c && c == a) return 5;
else if (a != b && a != c) return 1;
else return 0;
}
You have a green lottery ticket, with ints a, b, and c on it. If the numbers are all different from each other, the result is 0. If all of the numbers are the same, the result is 20. If two of the numbers are the same, the result is 10.
public int greenTicket(int a, int b, int c) {
if (a == b && b == c) return 20;
else if (a == b || b == c || c == a) return 10;
else return 0;
}
You have a blue lottery ticket, with ints a, b, and c on it. This makes three pairs, which we'll call ab, bc, and ac. Consider the sum of the numbers in each pair. If any pair sums to exactly 10, the result is 10. Otherwise if the ab sum is exactly 10 more than either bc or ac sums, the result is 5. Otherwise the result is 0.
public int blueTicket(int a, int b, int c) {
if (a + b == 10 || b + c == 10 || c + a == 10) return 10;
else if (a + b == b + c + 10 || a + b == c + a + 10) return 5;
else return 0;
}
Given two ints, each in the range 10..99, return true if there is a digit that appears in both numbers, such as the 2 in 12 and 23. (Note: division, e.g. n/10, gives the left digit while the % "mod" n%10 gives the right digit.)
public boolean shareDigit(int a, int b) {
if (a % 10 == b / 10 || a / 10 == b % 10 || a % 10 == b % 10 || a / 10 == b / 10) return true;
else return false;
}
Given 2 non-negative ints, a and b, return their sum, so long as the sum has the same number of digits as a. If the sum has more digits than a, just return a without b. (Note: one way to compute the number of digits of a non-negative int n is to convert it to a string with String.valueOf(n) and then check the length of the string.)
public int sumLimit(int a, int b) {
String a1 = "", b1 = "", sum = "";
a1 = a1.valueOf(a);
b1 = b1.valueOf(b);
sum = sum.valueOf(a + b);
if (sum.length() == a1.length()) return a + b;
if (sum.length() >a1.length()) return a; return a+b;
}
CodingBat String-2 Answers
All the above questions are in CodingBat logic1
If you find a better solution for any of the above problems, please comment below.