Hilfestellung bei einer Aufgabe

PatrickM

Neues Mitglied
Hey Leute,

Ich bin relativ neu im Geschäft der Programmierung.

Wir haben in der Schule ein wenig im 3. Semester meiner Oberstufe auf dem Gymnasium mit Softwareentwicklung spezifisch mit Java hantiert. Da ich nach meinem Abitur eine Ausbildung als Anwendungsentwickler starten möchte, habe ich selbstverständlich einige Bewerbungen abgeschickt und auch zurückerhalten. Da meine letzte Stunde mit Java schon etwas länger her ist und ich bedingt nicht mehr alles im Kopf habe, habe ich jedoch schon eine Aufgabe eines Unternehmens erhalten, die ich zu lösen habe. Bei dieser handelt es sich um Folgende:

Es ist ein Programm zu schreiben, das zu einer eingegebenen Zahl die nächstgrößere Primzahl berechnet und ausgibt. Beispiel: Eingabe 14, Ausgabe 17.

Natürlich habe ich schon versucht, mir einzelne Schritte aufzuschreiben, bin aber letztendlich noch auf keine Gesamtlösung gekommen. Diese findet Ihr im Anhang.

Ich hoffe, dass Ihr mir helfen könnt und wäre euch somit sehr verbunden. :)

MfG Patrick
 

Anhänge

  • Neues Textdokument (2).txt
    1,5 KB · Aufrufe: 10

Tarrew

Top Contributor
Hey, weil das ja ziemlich wichtig zu sein scheint für deine mögliche Ausbildung gebe ich dir mal eine beispielhafte Lösung:
Java:
import java.util.Scanner;

public class Testprogramm {
    public static void main(String[] args) {
        //Zahl einlesen
        Scanner s = new Scanner(System.in);
        int number = s.nextInt();
        s.close();
     
        //Inkrementiere 'number' so oft, bis eine Primzahl gefunden wurde.
        do {
            number++;
        } while (!isPrime(number));
     
        //Gebe gefundene Primzahl aus
        System.out.println(number);
    }

    /**
     * Prüft ob übergebe Zahl eine Primzahl ist
     * @param number Zu überprüfende Zahl
     * @return true für den Fall das number eine Primzahl ist, ansonsten false
     */
    public static boolean isPrime(int number) {
        if (number < 2) {
            return false;
        }
        for (int i = 2; i <= Math.sqrt(number); i++) {
            if (number % i == 0) {
                return false;
            }
        }
        return true;
    }
}

Der Algorithmus gibt immer die nächste höhere Primzahl aus! Wenn du also 17 eingibst was selbst eine Primzahl ist wird tdz. die höhere berechnet. Ich denke der Code ist relativ verständlich. Bei so welchen Sachen ist es hilfreich eine Methode zu haben die überprüft ob eine konkrete Zahl eine Primzahl ist. Die Methode kann man dann in einer Schleife aufrufen um die nächst höhere Primzahl zu finden.

Viel Glück noch bei deiner Bewerbung!
 

PatrickM

Neues Mitglied
Hey, vielen Dank für die schnelle Antwort! Werde mir das alles in Ruhe anschauen und verstehen. :D
Hätte nie gedacht, dass das so schnell geht, danke! :)
 
K

kneitzel

Gast
Also ich würde Dir an dieser Stelle empfehlen, dich intensiver mit der Thematik zu beschäftigen. Eine Lösung ist damit gefunden und die ist auch erst einmal ok. Aber was für Optimierungen gibt es hier evtl. noch?
Das könnte wichtig sein, falls Du erwartest, dass da ein Gespräch zu stattfinden könnte.

Optimierungen können vielschichtig sein:
- Strukturierungen (isPrime in eigene Math Klasse zur besseren Wiederverwendung z.B. oder eben Clean Code allgemein.)
- Verbesserung des Algorithmus. Ist da evtl. etwas optimierbar?
- Was für Möglichkeiten bezüglich Primzahlen gibt es evtl. noch? (Bei ähnlichen Anforderungen sind evtl. etwas andere Algorithmen denkbar).

Für ein Gespräch könnte es sinnvoll sein, z.B. eine Recherche zum Thema Primzahlen gemacht zu haben, um da dann in Gesprächen mehr erzählen zu können.

Aber das meiste ist natürlich nur wichtig, wenn es diesbezüglich ein Gespräch geben kann. Gerade die Recherche zur Lösungsfindung wäre mir sehr wichtig. Ob du nun Java gut kannst oder nicht, ist egal. Wenn Du Dich 40h / Woche mit Java beschäftigst, dann hast Du da schnell mögliche Lücken geschlossen. Aber selbständiges Arbeiten, Recherche zur Lösungsfindung, .... das sind Dinge, die sehr wichtig wäre in meinen Augen bei Personalgesprächen.

Speziell bei dem Algorithmus: Ich würde die 2 prüfen und dann eine Schleife ab 3 mit i=i+2 zur Erhöhung. Dann habe ich schon die Hälfte der Checks weniger. Und das lässt sich evtl. noch weiter optimieren. Wenn diese Checks extrem oft vorkommen, dann ist evtl. eine Art Cache sinnvoll. Oder die Speicherung aller Primzahlen um dann bei Checks nur noch Primzahlen prüfen zu müssen. Für einmalige Checks Unsinn, aber für ein System, dass viele Anfragen bekommt evtl. wichtig. Aber ich habe jetzt auch keine Recherche gemacht - evtl. hat da der eine oder andere Mathematiker noch mehr parat.

Das nur so als kleine Info von meiner Seite in der Hoffnung, dass es Dir etwas hilft. Viel Erfolg bei den Bewerbungen und den Gesprächen. (Und wenne s klappt: Viel Spass im Beruf!)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Interpreter-Fehler Hilfestellung bei einer NullPointerException Java Basics - Anfänger-Themen 1
B Collections Streams - Hilfestellung bei komplexer Struktur Java Basics - Anfänger-Themen 9
J Hilfestellung zu Hochschulaufgaben Java Basics - Anfänger-Themen 19
J Suche Hilfestellung Java Basics - Anfänger-Themen 10
A Hilfestellung zur Implementierung des Gaußsches Eliminationsverfahren Java Basics - Anfänger-Themen 4
R Hilfestellung bei Iteratorimplementierung Java Basics - Anfänger-Themen 4
A Hilfestellung zum Thema Persistenz Java Basics - Anfänger-Themen 12
N BinärBaum Hilfestellung Java Basics - Anfänger-Themen 8
G hilfestellung bei Array Java Basics - Anfänger-Themen 5
M Hilfestellung zur schularbeit Java Basics - Anfänger-Themen 17
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1
M Interface als Parameter einer Klasse Java Basics - Anfänger-Themen 8
I Liste von Infos von einer eigenen Annotation in Liste speichern Java Basics - Anfänger-Themen 0
M Wie kann ich den Index i von einer LinkedList überprüfen? Java Basics - Anfänger-Themen 36
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
M Wie verknüpfe ich eine Bedingung mit einer Methode ohne if-Verzweigung & Bedingungsoperator? Java Basics - Anfänger-Themen 2
P Doppelte werte in einer Liste zählen Java Basics - Anfänger-Themen 11
javapingu Jeglichen Inhalt einer Textdatei nach Zeile n löschen Java Basics - Anfänger-Themen 8
D mehrere Berechnungen in einer Methode Java Basics - Anfänger-Themen 9
P Iterieren mit einer Foreach in Lambdaschreibweise und Counter. Java Basics - Anfänger-Themen 1
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
X Was ist der Unterschied zwischen materialisierten und nichtmaterialisierten Attributen einer Klasse? Java Basics - Anfänger-Themen 1
U Wie ein Attribut von einer Klassenmethode in der Klasse speichern= Java Basics - Anfänger-Themen 2
M Wie richte ich eine Diagonale an Robotern in einer World ein? Java Basics - Anfänger-Themen 15
YAZZ BlueJ Bewegung einer Figur im Kreis Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben