Algorithmen für Anfänger

stevoo

Aktives Mitglied
Erstmal hallo! Ich war schon einmal in diesem Forum, wegen der java installation. Nun der zweite Schritt Um programmieren zu können muss man Algorithmen verstehen. Unten seht ihr eine Frage aus einem Buch, welche ic beantwortet habe. Ist meine Antwort richtig?

Wir betrachten den folgenden Algorithmus, dem als Eingabe ein Array a aus n natürlichen
Zahlen übergeben wird und der als Ausgabe zwei Zahlen x und y liefert.
Input: Array a der Länge n
x := a[0]
y := a[0]
for i = 1 to n − 1 do
if x > a then
x := a
end if
if y < a then
y := a
end if
end for
Output: x, y
a) Was berechnet der obige Algorithmus? Antwort: Er untersucht das Feld bis n-1. Für x sucht er den kleinsten Wert für y den größten.
 
Zuletzt bearbeitet:

stevoo

Aktives Mitglied
b) Wie viele Vergleiche führt der obige Algorithmus durch? Hierbei sollen nur Vergleiche mit Elementen aus a berücksichtigt werden.
Antwort: Er führt (1,2,.....,n-1) Vergeliche für x und für y durch

Ist das richtig?
 
Zuletzt bearbeitet:

stevoo

Aktives Mitglied
c) Geben Sie einen Algorithmus in Pseudocode an, der dasselbe Problem wie der obige Algorithmus
löst und dafür höchstens 3/2n Vergleiche von Elementen aus a benötigt. Beschreiben
Sie zusätzlich die Grundidee Ihres Algorithmus in wenigen Sätzen.

Bei dieser Frage tue ich mich schon schwer, weil ich es eben selber schreiben muss. Ihr wisst bestimmt sofort die Antwort, aber bitte antwortet nicht, bevor ich nicht geantwortet hab.
 
G

Gast2

Gast
Es werden schonmal 2 Antworten gefordert, also fehlt bei dir schonmal was. Aber auch der erste Teil der Antwort ist nicht richtig.
 

stevoo

Aktives Mitglied
Es werden schonmal 2 Antworten gefordert, also fehlt bei dir schonmal was. Aber auch der erste Teil der Antwort ist nicht richtig.

Wie viele Vergleiche führt der obige Algorithmus durch? Hierbei sollen nur Vergleiche mit
Elementen aus a berücksichtigt werden.

Dann vielleicht für x-->n-1
für y-->(n-1)-1 (Weil die eine Position wo sich x befindet ja schon vergeben ist)

PS: Lassen wir fürs erste den 2ten Teil der Frage außer Acht
 
Zuletzt bearbeitet:

stevoo

Aktives Mitglied
Vergissts die Frage c, soweit bin ich noch nicht.

Aber hier eine Frage zum Programmablaufplan

Wie oft wird "Hallo" ausgegeben


Start
(Pfeil nach unten)
x<--1
(Pfeil nach unten)
x<100 (Pfeil auf die Seite mit falls "NEIN") Ende
(Pfeil nach unten mit falls "JA")
Print "Hallo"
(Der Pfeil geht links zurück an die Stelle nach "x<--1" also vor x<100)

Ich meine "Hallo" wird nur einmal ausgegeben, weil es keinen zusätzlichen Befehl gibt, dass x die Positionen von 1 bis Hundert immer einzeln verschiebt. oder?
 

langhaar!

Bekanntes Mitglied
X ist immer kleiner 100, da es nirgendwo erhöht wird.
Somit wird der Text unendlich oft ausgegeben (vielleicht hast du eine Zeile vergessen?)

Deine Anmerkung 'dass x die Positionen von 1 bis Hundert immer einzeln verschiebt.' verstehe ich nicht.
Wenn x eine Zahl sein soll, gibt es weder Positionen noch irgendetwas, was verschoben werden kann.
 

stevoo

Aktives Mitglied
X ist immer kleiner 100, da es nirgendwo erhöht wird.
Somit wird der Text unendlich oft ausgegeben (vielleicht hast du eine Zeile vergessen?)

Deine Anmerkung 'dass x die Positionen von 1 bis Hundert immer einzeln verschiebt.' verstehe ich nicht.
Wenn x eine Zahl sein soll, gibt es weder Positionen noch irgendetwas, was verschoben werden kann.

Ich dachte hier ist x nur die Position und keine Zahl. Mit Unendlich hast du schon Recht. Wenn x immer an der Position 1 bleibt wird es ein Kreislauf. Ich hätte gedacht, dass 100 in diesem Fall =(z.B.)n ist. Also die Anzahl der Felder und nicht eine Zahl im Feld.

Ich stelle mir das so vor: x wird an Position 1 gesetzt. Dann: Falls x ist kleiner die mögliche Anzahl der Positionen(hier n=100 x=1) dann Print hallo. Da es dann keine Befehle zum verschieben von Positionen gibt, wird es ein unendlicher Kreislauf. ODER VERWECHSLE ICH hier x mit i vom ersten Beispiel(ganz oben)?
 

stevoo

Aktives Mitglied
Wie schaut der Pseudocode für diesen Algorithmus(siehe Link) aus. Ich habe keine Idee, weil er so viele Bedinungen hat.

Link: Img002 - Speedy Share - upload your files here

Ungefähr so?:

j=n

While j>1 do
max=1
i=2

If i<==j

If K(i)>K(max) //Wie knöpfe ich eine zweite Bedinung an?
max=i
i=i+1

Else
i=i+1
EndIF

Else
Hilf=K(j)
K(j)=K(max)
K(max)=Hilf
j=j-1
ENDIF
?
?

Ps: DAS IST KEINE HAUSAUFGABE, DAS WILL ICH ENFACH LERNEN.
 
M

Marcinek

Gast
Hallo,

daraus Pseudocode zu machen ist mehr als Trivial.

Du musst das doch nur ablesen -.-

Java:
function x (int n, K) {

  int j = n;
  int max;

  while ( j > 1 ) {
    max = 1;
    i = 2;
    while (i <= j) {
        if ( K[i] > K[max] ) {
          max = i;
          i = i +1;
        } // if
       } // while
      int Hilf = K[j];
      K[j] = K[max];
      K[max] = Hillf;
      j = j-1;
    } // außen while
  }

Was der Algo macht steht auf deinem Bild.

Gruß,
Martin
 

stevoo

Aktives Mitglied
Hallo,

daraus Pseudocode zu machen ist mehr als Trivial.

Du musst das doch nur ablesen -.-

Java:
function x (int n, K) {

  int j = n;
  int max;

  while ( j > 1 ) {
    max = 1;
    i = 2;
    while (i <= j) {
        if ( K[i] > K[max] ) {
          max = i;
          i = i +1;
        } // if
       } // while
      int Hilf = K[j];
      K[j] = K[max];
      K[max] = Hillf;
      j = j-1;
    } // außen while
  }

Was der Algo macht steht auf deinem Bild.

Gruß,
Martin

Wenn K(i)<K(max) ist müsste er doch max=1 auslassen, oder? Bei dir wird es aber nicht erwähnt.
 
Zuletzt bearbeitet:

stevoo

Aktives Mitglied
Passt das so?:
j=n

While j>1 do
max=1
i=2

While i<==j

If K(i)>K(max)
max=i
i=i+1

Else
i=i+1
EndIF
Endwhile

Hilf=K(j)
K(j)=K(max)
K(max)=Hilf
j=j-1
Endwhile
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Algorithmen Java Basics - Anfänger-Themen 1
Viktor A. Kaiser Rekursive Algorithmen Java Basics - Anfänger-Themen 9
K Algorithmen und Datenstrukturen Programmier Aufgabe Java Basics - Anfänger-Themen 10
D Algorithmen lernen Java Basics - Anfänger-Themen 45
H Übungsaufgabe algorithmen Java Basics - Anfänger-Themen 2
F Graphen-Algorithmen Java Basics - Anfänger-Themen 1
M Algorithmen und Datenstrukturen Java Basics - Anfänger-Themen 3
M Elementaren Algorithmen Java Basics - Anfänger-Themen 2
J Suche Tipps zum erstellen von Algorithmen Java Basics - Anfänger-Themen 5
E Algorithmen und Programmierung - Datum und Zeit ausgeben? Java Basics - Anfänger-Themen 8
C Terminierung von imperativen Algorithmen Java Basics - Anfänger-Themen 13
B OOP Algorithmen und dann ? Java Basics - Anfänger-Themen 4
J Strategy: geht es immer um die Algorithmen? Java Basics - Anfänger-Themen 4
Spin Probleme mit Algorithmen Java Basics - Anfänger-Themen 8
W Algorithmen und Eigenschaften Java Basics - Anfänger-Themen 29
J Algorithmen verbessern Java Basics - Anfänger-Themen 11
B Zeitmessung von Algorithmen Java Basics - Anfänger-Themen 8
G Komplexe Algorithmen implementieren Java Basics - Anfänger-Themen 4
J Hilfe! Algorithmen --> ich schaff es nicht Java Basics - Anfänger-Themen 4
T Laufzeitanalyse von Algorithmen - Problem und Frage - Java Basics - Anfänger-Themen 1
B Datenstrukturen & Algorithmen => Iteratoren Java Basics - Anfänger-Themen 7
R Algorithmen entwickeln und in Java umsetzen Java Basics - Anfänger-Themen 3
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben