Een methode maken om dubbele transacties te vinden
Logbestanden van financiële transacties moeten worden gevalideerd om te garanderen dat elke transactie-ID uniek is. Jij gaat een methode implementeren die efficiënt controleert of er dubbele transactie-ID’s voorkomen.
Deze oefening maakt deel uit van de cursus
Code optimaliseren in Java
Oefeninstructies
- Initialiseer de variabele
seenals een legeSet. - Voeg transacties toe aan
seenals je ze nog niet bent tegengekomen. - Retourneer de juiste booleanwaarde als de lus eindigt zonder een duplicaat te vinden.
Praktische interactieve oefening
Probeer deze oefening eens door deze voorbeeldcode in te vullen.
public class Main {
public static void main(String[] args) {
TransactionProcessor processor = new TransactionProcessor();
String[] transactions = {
"TXN001", "TXN002", "TXN003", "TXN001",
"TXN004", "TXN005", "TXN003", "TXN006"
};
boolean hasDuplicates = processor.hasDuplicateTransactions(transactions);
if (hasDuplicates) {
System.out.println("Duplicate transactions detected!");
} else {
System.out.println("All transactions are unique.");
}
}
}
class TransactionProcessor {
public boolean hasDuplicateTransactions(String[] transactionIds) {
// Initialize an empty HashSet
____ seen = new ____<>();
for (String transactionId : transactionIds) {
if (seen.contains(transactionId)) {
return true;
} else {
// First time seeing this transaction, add it to the set
seen.____(____)
}
}
// Return true/false if no duplicates found
return ____;
}
}