Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 18 additions & 4 deletions src/main/java/rocks/zipcode/quiz4/arrays/ArrayUtils.java
Original file line number Diff line number Diff line change
@@ -1,22 +1,36 @@
package rocks.zipcode.quiz4.arrays;

import java.util.ArrayList;
import java.util.Arrays;

/**
* @author leon on 01/01/2019.
*/
public class ArrayUtils {
public static String getMiddleElement(String[] values) {
return null;
Integer midIndex = values.length / 2;
return values[midIndex];
}

public static String[] removeMiddleElement(String[] values) {
return null;
ArrayList<String> valuesList= new ArrayList<>(Arrays.asList(values));
valuesList.remove((values.length)/2);
String [] result = new String[valuesList.size()];
result = valuesList.toArray(result);
return result;
}

public static String getLastElement(String[] values) {
return null;
Integer lastIndex = values.length -1;
return values[lastIndex];
}

public static String[] removeLastElement(String[] values) {
return null;
ArrayList<String> valuesList = new ArrayList<>(Arrays.asList(values));
//Integer lastIndex = values.length -1;
valuesList.remove(values.length - 1);
String [] result = new String[valuesList.size()];
result = valuesList.toArray(result);
return result;
}
}
26 changes: 24 additions & 2 deletions src/main/java/rocks/zipcode/quiz4/collections/WordCounter.java
Original file line number Diff line number Diff line change
@@ -1,12 +1,34 @@
package rocks.zipcode.quiz4.collections;

import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.stream.Collector;
import java.util.stream.Collectors;

public class WordCounter {

Map<String, Long> wordCounts = new HashMap<>();
Map<String, Integer> newMap = new HashMap<>();

public WordCounter(String... strings) {
wordCounts =
Arrays.stream(strings).collect(Collectors.groupingBy(w -> w, Collectors.counting()));
newMap = wordCounts.entrySet()
.stream()
.collect(Collectors.toMap(entry -> entry.getKey(), entry -> entry.getValue().intValue()));
}

public Map<String, Integer> getWordCountMap() {
return null;
//Write method for using a loop also.
// HashMap<String,int> frequencymap = new HashMap<String,int>();
// foreach(String a in animals) {
// if(frequencymap.containsKey(a)) {
// frequencymap.put(a, frequencymap.get(a)+1);
// }
// else{ frequencymap.put(a, 1); }
// }

public Map<String, Integer> getWordCountMap(String... strings) {
return newMap;
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package rocks.zipcode.quiz4.collections.culonary;

public class Curry {
public class Curry implements Spice{
}
36 changes: 32 additions & 4 deletions src/main/java/rocks/zipcode/quiz4/collections/culonary/Food.java
Original file line number Diff line number Diff line change
@@ -1,20 +1,48 @@
package rocks.zipcode.quiz4.collections.culonary;

import java.util.List;
import java.util.Map;
import java.util.*;
import java.util.function.Function;
import java.util.stream.Collectors;

/**
* @author leon on 27/12/2018.
*/
public class Food {
List<Spice> mySpices = new ArrayList<>();
Set<Spice> spicesSet;


public List<Spice> getAllSpices() {
return null;
return mySpices;
}

public <SpiceType extends Class<? extends Spice>> Map<SpiceType, Integer> getSpiceCount() {
return null;
//Map<SpiceType, Long> spiceMap = mySpices.stream().collect(Collectors.toMap((Spice)Collectors.groupingBy(Function.identity()), Collectors.counting()));

Map<SpiceType, Integer> spiceMap = new HashMap<>();
for (Spice spice: mySpices) {
SpiceType spiceType = (SpiceType) spice.getClass();
if(spiceMap.containsKey(spiceType)){
spiceMap.put(spiceType, spiceMap.get(spiceType) + 1);
}
else {
spiceMap.put(spiceType, 1);
}
}
return spiceMap;
}

// HashMap<String,int> frequencymap = new HashMap<String,int>();
// foreach(String a in animals) {
// if(frequencymap.containsKey(a)) {
// frequencymap.put(a, frequencymap.get(a)+1);
// }
// else{ frequencymap.put(a, 1); }
// }


public void applySpice(Spice spice) {
mySpices.add(spice);
//spicesSet = new HashSet(mySpices);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
/**
* @author leon on 27/12/2018.
*/
public class Ginger {
public class Ginger implements Spice{
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@
/**
* @author leon on 27/12/2018.
*/
public class Pepper {
public class Pepper implements Spice{
}
23 changes: 16 additions & 7 deletions src/main/java/rocks/zipcode/quiz4/fundamentals/Calculator.java
Original file line number Diff line number Diff line change
Expand Up @@ -4,32 +4,41 @@
* @author leon on 21/12/2018.
*/
public class Calculator {

public static Double squareRoot(Double value) {
return null;
return Math.sqrt(value);
}

public static Double square(Double value) {
return null;
return value*value;
}

public static Double[] squareRoots(Double... value) {
return null;
Double [] valueRoots = new Double[value.length];
for (int i = 0; i < valueRoots.length; i++) {
valueRoots[i] = Math.sqrt(value[i]);
}
return valueRoots;
}

public static Double[] squares(Double... values) {
return null;
Double [] valueRoots = new Double[values.length];
for (int i = 0; i < valueRoots.length; i++) {
valueRoots[i] = values[i] * values[i];
}
return valueRoots;
}

public static Double add(Double value1, Double value2) {
return null;
return value1 + value2;
}

public static Double subtract(Double value1, Double value2) {
return null;
return value1 - value2;
}


public static Double divide(Double divisor, Double dividend) {
return null;
return divisor / dividend;
}
}
87 changes: 79 additions & 8 deletions src/main/java/rocks/zipcode/quiz4/fundamentals/StringUtils.java
Original file line number Diff line number Diff line change
@@ -1,34 +1,105 @@
package rocks.zipcode.quiz4.fundamentals;

import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import java.util.stream.Collectors;
import java.util.stream.Stream;

/**
* @author leon on 21/12/2018.
*/
public class StringUtils {
public static Character getMiddleCharacter(String string) {
return null;
char [] strArray = string.toCharArray();
return strArray[(string.length())/2];
}

public static String capitalizeMiddleCharacter(String str) {
return null;
String [] strArray = str.split("");
Integer midIndex = str.length()/2;
strArray[midIndex] = strArray[midIndex].toUpperCase();
return String.join("", strArray);
//Or using a stream: String joined = Arrays.stream(strArray).collect(Collectors.joining());
}

public static String lowerCaseMiddleCharacter(String str) {
return null;
String [] strArray = str.split("");
Integer midIndex = str.length()/2;
strArray[midIndex] = strArray[midIndex].toLowerCase();
String joined = Arrays.stream(strArray).collect(Collectors.joining());
return joined;
}

public static Boolean isIsogram(String str) {
return null;
Map<Character, Long> charMap = new HashMap<>();
char [] strArray = str.toCharArray();
Character [] nonPrimitiveArray = new Character[strArray.length];
for (int i = 0; i < nonPrimitiveArray.length; i++) {
nonPrimitiveArray[i] = (Character) strArray[i];
}
charMap = Arrays.stream(nonPrimitiveArray).collect(Collectors.groupingBy(c -> c, Collectors.counting()));
for (Long count : charMap.values()) {
if (count >= 2) {
return false;
}
}
return true;
}

public static Boolean hasDuplicateConsecutiveCharacters(String str) {
return null;
}


String[] strArray = str.split("");

if (strArray[str.length() -1].equals(str.length() - 2)){
return true;
}
for (int i = 0; i < str.length() - 2; i++) {
if (strArray[i].equals(strArray[i + 1])) {
return true;
}
}
return false;
}


public static String removeConsecutiveDuplicateCharacters(String str) {
return null;
if(hasDuplicateConsecutiveCharacters(str)==true){

String[] strArray = str.split("");
StringBuilder sb = new StringBuilder();
for (int i = 0; i < str.length() - 2; i++) {
if (strArray[i].equals(strArray[i + 1])) {
i=i+1;
} else if (!strArray[i].equals(strArray[i + 1])) {
sb.append(strArray[i]);
}
}
if (!strArray[str.length() - 1].equals(str.length() - 2)) {
sb.append(strArray[str.length() - 1]);
}
return sb.toString();
}
else { return str;}
}


public static String invertCasing(String str) {
return null;
StringBuilder sb = new StringBuilder(str);
char c;

for (int i = 0; i < str.length(); i++) {
c = str.charAt(i);
if (Character.isLowerCase(c))
{
sb.replace(i, i + 1, String.valueOf(Character.toUpperCase(c)));
}
else
{
sb.replace(i, i + 1, String.valueOf(Character.toLowerCase(c)));
}
}
return sb.toString();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,20 @@
/**
* @author leon on 30/12/2018.
*/
public class Account extends BankAccount {
public class Account {
Long id;

public Account () {}

public Account(Long id) {
this.id = id;
}

public Long getId() {
return null;
return id;
}

public void setId(Long id) {
this.id = id;
}
}
Original file line number Diff line number Diff line change
@@ -1,17 +1,25 @@
package rocks.zipcode.quiz4.objectorientation.account;

import java.util.ArrayList;

/**
* @author leon on 27/12/2018.
*/
public class Bank {
public BankAccount removeBankAccountByIndex(Integer indexNumber) {
return null;
ArrayList<BankAccount> accountArrayList = new ArrayList<>(0);

public BankAccount removeBankAccountByIndex(Integer indexNumber) { //returns BankAccount
BankAccount accountToRemove = accountArrayList.get(indexNumber);
this.accountArrayList.remove(accountToRemove);
return accountToRemove;
}

public void addBankAccount(BankAccount bankAccount) {
accountArrayList.add(bankAccount);
}

public Boolean containsBankAccount(BankAccount bankAccount) {
throw new UnsupportedOperationException("Method not yet implemented");
//throw new UnsupportedOperationException("Method not yet implemented");
return this.accountArrayList.contains(bankAccount);
}
}
Loading