Hoztam nektek egy sor gyakorlófeladatot (“live coding”) junior vagy medior szintű állásinterjúkra: a feladatok között több is előfordult már az állásinterjúimon. Jelen feladatok mellé csatolok egy lehetséges megoldást Java nyelven. Nem állítom, hogy az enyém a legoptimálisabb megoldás, de működik.
- Írj programot, amely 2 egész számot vár paraméterként. A programnak a két szám közötti összes egész számot egy listában kell visszaadnia a kezdő és befejező számokat kihagyva. Ha a kezdőszám nagyobb, mint a befejező szám, a lista tartalmazza a számokat csökkenő sorrendben. Ha a kezdőszám kisebb, mint a befejező szám, a lista tartalmazza a számokat növekvő sorrendben.
import java.util.List;import java.util.ArrayList;class HelloWorld {public static void main(String[] args) {System.out.println(“Hello, World!”);}public List<Integer> solution(int a, int b) {List<Integer> solutionList = new ArrayList<>();if (a > b) {for (int i = a-1; i > b; i–) {solutionList.add(i);}} else {for (int i = a+1; i < b; i++) {solutionList.add(i);}}return solutionList;}}
class HelloWorld {public static void main(String[] args) {System.out.println(isPerfectNumber(11));}public static boolean isPerfectNumber (int number){int maradek = 0;for (int i = 1; i < number -1; i++){if (number % i == 0){maradek+=i;}}return maradek==number;}}
import java.util.ArrayList;import java.util.List;public class HelloWorld {public static void main(String[] args) {List<Integer> testList = List.of(1, 1, 2, 2, 3, 3, 4, 5, 5, 5, 6);System.out.println(uniqueArray(testList));}public static List<Integer> uniqueArray(List<Integer> numbers) {if (numbers == null || numbers.isEmpty()) {return new ArrayList<>();}List<Integer> result = new ArrayList<>();result.add(numbers.get(0));for (int i = 1; i < numbers.size(); i++) {if (!numbers.get(i).equals(numbers.get(i – 1))) {result.add(numbers.get(i));}}return result;}}
public static List<Integer> solution(List<Integer> numbers) {Set<Integer> uniqueSet = new LinkedHashSet<>(numbers);return uniqueSet.stream().collect(Collectors.toList());}
public static int summarizer (int a, int b){int solution = 0;if(a>b){for (int i= b; i>=a;i++){solution+=i;}}else{for (int i= a; i<=b;i++){solution+=i;}}return solution;}
public class WordReverser {
public static void main(String[] args) {
String sentence = “This is a test sentence”;
System.out.println(“Original Sentence: ” + sentence);
System.out.println(“Reversed Sentence: ” + reverseWordsOrder(sentence));
}/**
* Reverses the order of words in a sentence, but leaves the characters of each word intact.
* @param sentence The original sentence.
* @return The sentence with the words reversed.
*/
public static String reverseWordsOrder(String sentence) {
String[] words = sentence.split(” “);
StringBuilder reversedSentence = new StringBuilder();for (int i = words.length – 1; i >= 0; i–) {
reversedSentence.append(words[i]);
if (i != 0) {
reversedSentence.append(” “);
}
}return reversedSentence.toString();
}
}
7. Prím Számok Keresése.Írj egy metódust, amely visszaadja az első n prím számot egy listában.
import java.util.ArrayList;
import java.util.List;public class PrimeSearcher {
public static void main(String[] args) {
int n = 10; // Például az első 10 prím szám kereséséhez
List<Integer> primes = findFirstNPrimes(n);
System.out.println(“Az első ” + n + ” prím szám: ” + primes);
}/**
* Visszaadja az első n prím számot egy listában.
*
* @param n A keresendő prím számok száma
* @return Egy lista az első n prím számmal
*/
public static List<Integer> findFirstNPrimes(int n) {
List<Integer> primes = new ArrayList<>();
int num = 2; // kezdés a legkisebb prím számmal
while (primes.size() < n) {
if (isPrime(num)) {
primes.add(num);
}
num++;
}
return primes;
}/**
* Megvizsgálja, hogy egy szám prím-e vagy sem.
*
* @param num A vizsgálandó szám
* @return true, ha a szám prím, egyébként false
*/
private static boolean isPrime(int num) {
if (num <= 1) return false;
for (int i = 2; i <= Math.sqrt(num); i++) {
if (num % i == 0) {
return false;
}
}
return true;
}
}
public class HelloWorld {public static void main(String[] args) {System.out.println(isItPalindrome(“Indul a pap aludni”));}public static boolean isItPalindrome(String word) {String cleanedWord = word.replaceAll(“\\s+”, “”).toLowerCase(); // szóközök eltávolítása és kisbetűssé alakításStringBuilder stringBuilder = new StringBuilder(cleanedWord);String reversed = stringBuilder.reverse().toString();return cleanedWord.equals(reversed);}}
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class SumPairs {
public static void main(String[] args) {
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);
int targetSum = 15;
int[] pair = findPairWithSum(numbers, targetSum);if (pair != null) {
System.out.println(“Two numbers with a sum of ” + targetSum + ” are: ” + pair[0] + ” and ” + pair[1]);
} else {
System.out.println(“No two numbers found with a sum of ” + targetSum);
}
}/**
* Searches for a pair of numbers in the given list that adds up to the given target sum.
*
* @param numbers The list of numbers
* @param targetSum The target sum
* @return An array of size 2 containing the pair of numbers or null if no pair found.
*/
public static int[] findPairWithSum(List<Integer> numbers, int targetSum) {
Map<Integer, Integer> complementMap = new HashMap<>();for (int number : numbers) {
int complement = targetSum – number;
if (complementMap.containsKey(complement)) {
return new int[]{complement, number};
}
complementMap.put(number, complement);
}return null;
}
}
import java.util.Arrays;
import java.util.List;public class MinMaxFinder {
public static void main(String[] args) {
List<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5);
int[] result = findMinMax(numbers);
System.out.println(“The smallest number is: ” + result[0]);
System.out.println(“The largest number is: ” + result[1]);
}/**
* Determines the smallest and the largest number in a list.
*
* @param numbers The list of numbers
* @return An array where the first element is the smallest number and the second element is the largest number.
*/
public static int[] findMinMax(List<Integer> numbers) {
if (numbers == null || numbers.isEmpty()) {
throw new IllegalArgumentException(“List cannot be null or empty”);
}int min = Integer.MAX_VALUE;
int max = Integer.MIN_VALUE;for (int number : numbers) {
if (number < min) {
min = number;
}
if (number > max) {
max = number;
}
}return new int[]{min, max};
}
}
import java.util.*;public class HelloWorld {public static void main(String[] args) {System.out.println(areAnagrammas(“indula”, “aludni”));}public static boolean areAnagrammas(String first, String second) {List<Character> firstWordCharacters = new ArrayList<>();List<Character> secondWordCharacters = new ArrayList<>();for (int i = 0; i < first.length(); i++) {if (first.charAt(i) != ‘ ‘) {firstWordCharacters.add(first.charAt(i));}}for (int j = 0; j < second.length(); j++) {if (second.charAt(j) != ‘ ‘) {secondWordCharacters.add(second.charAt(j));}}Collections.sort(firstWordCharacters);Collections.sort(secondWordCharacters);return firstWordCharacters.equals(secondWordCharacters);}}
import java.util.List;public class FindMissingNumber {public static int summarizerToN(List<Integer> numbers) {int reference = 0;int sum = 0;for (int j = 1; j <= numbers.size() + 1; j++) {reference += j;}for (int i = 0; i < numbers.size(); i++) {sum += numbers.get(i);}return reference – sum;}}
import java.util.*;
public class MostFrequentElement {
public static void main(String[] args) {
List<Integer> numbers = Arrays.asList(1, 2, 3, 2, 5, 3, 3, 5, 5, 4);
List<Integer> mostFrequent = findMostFrequentElements(numbers);
System.out.println(“The most frequently occurring elements are: ” + mostFrequent);
}/**
* Determines the most frequently occurring elements in a list.
*
* @param list The list of elements
* @return A list containing the most frequently occurring elements in the order of their first occurrence.
*/
public static List<Integer> findMostFrequentElements(List<Integer> list) {
Map<Integer, Integer> frequencyMap = new HashMap<>();
int maxFrequency = 0;// Calculate the frequency of each element
for (int number : list) {
frequencyMap.put(number, frequencyMap.getOrDefault(number, 0) + 1);
maxFrequency = Math.max(maxFrequency, frequencyMap.get(number));
}// Find elements with the max frequency
Set<Integer> resultSet = new LinkedHashSet<>();
for (int number : list) {
if (frequencyMap.get(number) == maxFrequency) {
resultSet.add(number);
}
}return new ArrayList<>(resultSet);
}
}
import java.util.*;public class HelloWorld {public static void main(String[] args) {List<Integer> testList = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);System.out.println(numberOfOdds(testList));}public static int numberOfOdds(List<Integer> numberList) {int numberOfOdds = 0;for (int i = 0; i < numberList.size(); i++){if (numberList.get(i) % 2 == 1){numberOfOdds++;}}return numberOfOdds;}}
public class HelloWorld {public static void main(String[] args) {System.out.println(gcd(56, 98)); // Eredmény: 14System.out.println(gcd(98, 56)); // Eredmény: 14}public static int gcd(int a, int b) {while (b != 0) {int temp = b;b = a % b;a = temp;}return Math.abs(a); // Abszolút érték, hogy a negatív számok esetén is pozitív eredményt kapjunk}}
import java.util.ArrayList;import java.util.List;public class HelloWorld {public static void main(String[] args) {System.out.println(fibonacci(10)); // [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]}public static List<Integer> fibonacci(int n) {List<Integer> list = new ArrayList<>();if (n <= 0) {return list;}list.add(0);if (n == 1) {return list;}list.add(1);for (int i = 2; i < n; i++) {int nextNumber = list.get(i – 1) + list.get(i – 2);list.add(nextNumber);}return list;}}
What do you think?
Show comments / Leave a comment