Wie 2 Arrays zusammenfügen und sortieren?

capturion

Mitglied
Hallo,

bin gerade dabei für die Uni ein Programm zu schreiben.
Das Programm soll
-2 Arrays erstellen
- Länge des arrays und höchste zahl sollen über die Konsole eingegeben werden
- Beide arrays sollen mit zufälligen zahlen gefüllt werden
- Beide Arrays sollen richtig sortiert ausgegeben werden
- Anschließend beide arrays in ein 3. rein und das wiederum sortieren und ausgeben !Problem!

Hab alles bis auf den letzten Punkt und verzweifle seit 3h langsam wirklich.
Vielleicht weiß jemand wie es geht.
Das 3. Array soll direkt sortiert werden und nicht ersten erstellt und dann sortiert werden:


Java:
import java.util.Random;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;


public class App {
    
    public static void main (String[] args) throws IOException 
    {        
 BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
         
         System.out.println("Länge Array eingeben");
           
            
            String capacity1 = reader.readLine();
            int capacity = Integer.parseInt(capacity1);
         
            System.out.println("maxvalue eingeben");
            String maxValue1 = reader.readLine();
            int maxValue = Integer.parseInt(maxValue1);
            
          
            int [] a1 =    createRandomIntegerArray(capacity, maxValue);
            System.out.println();                                            
            System.out.println("Unsortiertes erstes Array:");
            printArray(a1);
            
            
      
            int [] b1 =    createRandomIntegerArray(capacity, maxValue);
            System.out.println();
            System.out.println("Unsortiertes zweites Array:");
            printArray(b1);
            
            System.out.println();
            System.out.println("Sortiertes erstes Array:");
            bubbleSort (a1);
            printArray(a1);
            
            System.out.println();
            System.out.println("Sortiertes zweites Array:");
            bubbleSort (b1);
            printArray(b1);
            
            Zusammenfügen(a1, b1);
            
          Zusammenfügen(c);             //hier soll die Methode ausgeführt werden
    }
    
    
    
    
    
    public static int[] createRandomIntegerArray(int capacity, int maxValue)
    {
        Random rnd = new Random();
        int[] result = new int[capacity];
        for (int i = 0; i < result.length; i++)
        {
            result[i] = rnd.nextInt(maxValue) + 1;
        }
        return result;
    }
    
    
    
    public static void printArray(int[] Values)
    {
        for (int i = 0 ; i < Values.length ; i++)
        {
            System.out.print(Values[i]);
            System.out.print(" ");
            }
            }
    
    
    
    
    public static void bubbleSort (int[] Values)
            {
            {
            for (int i = Values.length; i>0; i--)
            {
            for (int c = 1; c < i; c++)
            {
            if (Values[c-1] > Values[c])
            {
            int buf = Values[c-1];
            Values[c-1] = Values [c];
            Values[c] = buf;
            }
            }
            }
            }
            }
    
    
    
    
    private static void Zusammenfügen(int[] a1, int[] b1) 
    {
        int Länge = a1.length + b1.length;
        int [] c = new int[Länge];
        
        boolean bool=true;
        
        while(bool)
        {
            int i=0;
            int j=0;
            int k=0;
            if(a1[i]<b1[j])    
            {
                c[k]=a1[i];
                i++;
                k++;
                if(i==a1.length)
                {
                    return;
                }
                else
                {
                    c[k]=b1[j];
                    j++;
                    k++;
                    if(j==b1.length);    
                }
            }
         //hier weiß ich nicht mehr weiter
        }
    }
}
 

fhoffmann

Top Contributor
Deine Methode zusammenfuegen sollte das zusammengefügte Array zurückgeben, also:
Java:
public static int[] zusammenfuegen(int[] a, int[] b) {
 

MoxxiManagarm

Top Contributor
1. Bitte halte dich an Java Namenskonventitionen, d.h. Methoden und Felder immer im lowerCamelCase. Möglichst auch Umlaute vermeiden. Ändere daher bitte "Zusammenfügen", "Länge", "Values" etc.
2. Warum a1 wenn es kein a2 gibt?
3. Eine while Schleife finde ich nicht besonders schlau. Du weiß genau wie oft du einen Wert setzen willst, nämlich |c|-mal. Also ist eine for-Schleife sinnvoller.
Java:
int laenge = a.length + b + length;
int [] c = new int[laenge];
for (int k = 0; k < laenge; k++) { /* ... */ };
4.
while(bool) { int i=0; int j=0; int k=0;
In deiner Version sind i j und k in jedem Schleifendurchlauf immer wieder 0. Du musst diese vor der while-Schleife deklarieren.
5.
if(a1<b1[j]) { c[k]=a1; i++; k++; if(i==a1.length) { return; } else { c[k]=b1[j]; j++; k++; if(j==b1.length); } }
Ganz ehrlich, dieser Teil ist total Banane :D Überlege dir welche Fälle auftreten können.
Code:
a) i === a.length --> nimm b[j++]
b) j === b.length --> nimm a[i++]
c) a[i] <= b[j] --> nimm a[i++]
d) else (a[i] > b[j]) --> nimm b[j++]
 

capturion

Mitglied
1. Bitte halte dich an Java Namenskonventitionen, d.h. Methoden und Felder immer im lowerCamelCase. Möglichst auch Umlaute vermeiden. Ändere daher bitte "Zusammenfügen", "Länge", "Values" etc.
2. Warum a1 wenn es kein a2 gibt?
3. Eine while Schleife finde ich nicht besonders schlau. Du weiß genau wie oft du einen Wert setzen willst, nämlich |c|-mal. Also ist eine for-Schleife sinnvoller.
Java:
int laenge = a.length + b + length;
int [] c = new int[laenge];
for (int k = 0; k < laenge; k++) { /* ... */ };
4.

In deiner Version sind i j und k in jedem Schleifendurchlauf immer wieder 0. Du musst diese vor der while-Schleife deklarieren.
5.

Ganz ehrlich, dieser Teil ist total Banane :D Überlege dir welche Fälle auftreten können.
Code:
a) i === a.length --> nimm b[j++]
b) j === b.length --> nimm a[i++]
c) a[i] <= b[j] --> nimm a[i++]
d) else (a[i] > b[j]) --> nimm b[j++]
Habs jetzt mal geändert, kein fehler laut Eclipse, funktioniert aber nicht ganz.
Java:
import java.util.Random;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;


public class App {
    
    public static void main (String[] args) throws IOException 
    {        
 BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
         
         System.out.println("Länge Array eingeben");
           
            
            String capacity1 = reader.readLine();
            int capacity = Integer.parseInt(capacity1);
         
            System.out.println("maxvalue eingeben");
            String maxValue1 = reader.readLine();
            int maxValue = Integer.parseInt(maxValue1);
            
          
            int [] a =    createRandomIntegerArray(capacity, maxValue);
            System.out.println();                                            
            System.out.println("Unsortiertes erstes Array:");
            printArray(a);
            
            
      
            int [] b =    createRandomIntegerArray(capacity, maxValue);
            System.out.println();
            System.out.println("Unsortiertes zweites Array:");
            printArray(b);
            
            System.out.println();
            System.out.println("Sortiertes erstes Array:");
            bubbleSort (a);
            printArray(a);
            
            System.out.println();
            System.out.println("Sortiertes zweites Array:");
            bubbleSort (b);
            printArray(b);
            
            int [] d = zusammen(a, b);
            System.out.println("Das sortierte, zusammenfefügte Array ist:");
            printArray(d);
            
         
    }
    
    
    
    
    
    public static int[] createRandomIntegerArray(int capacity, int maxValue)
    {
        Random rnd = new Random();
        int[] result = new int[capacity];
        for (int i = 0; i < result.length; i++)
        {
            result[i] = rnd.nextInt(maxValue) + 1;
        }
        return result;
    }
    
    
    
    public static void printArray(int[] Values)
    {
        for (int i = 0 ; i < Values.length ; i++)
        {
            System.out.print(Values[i]);
            System.out.print(" ");
            }
            }
    
    
    
    
    public static void bubbleSort (int[] Values)
            {
            {
            for (int i = Values.length; i>0; i--)
            {
            for (int c = 1; c < i; c++)
            {
            if (Values[c-1] > Values[c])
            {
            int buf = Values[c-1];
            Values[c-1] = Values [c];
            Values[c] = buf;
            }
            }
            }
            }
            }
    
    
    
    
public static int[] zusammen(int[] a, int[] b) 
        {
        int laenge = a.length + b.length;
        int [] c = new int[laenge];
        int i=0; 
        int j=0;
        for (int k =0; k<=laenge; k++)
        {
            if(i==a.length)
            {
                c[k]=b[j];
                j++;
            }

            if(j==b.length)
            {
                c[k]=a[i];
                i++;
            }
            if(a[i]<=b[j])
            {
            c[k]=a[i];
            i++;
            }
            
            else(a[i]>b[j])
            {
                c[k]=b[j];
                j++;
            }
            
        }
        return c;
}
}
 

capturion

Mitglied
Was denn nicht?

Vergleiche doch nochmal diese Zeile mit meiner:
Habs geändert, bringt nichts

Exception in thread "main" java.lang.Error: Unresolved compilation problems:
The left-hand side of an assignment must be a variable
Syntax error, insert "AssignmentOperator Expression" to complete Assignment
Syntax error, insert ";" to complete Statement

at App.zusammen(App.java:128)
at App.main(App.java:46)


finde da aber absolut nicht was falsch sein soll...
 
K

kneitzel

Gast
Generell wäre wichtig, dann den Fehler auch zu nennen, wenn du einen bekommst. So ist eine Hilfestellung schwer möglich.

Was mir noch etwas auffällt: Du hast beim Merge lauter einzelne if. Da würde ich immer if ... else if ... else if ... else ... erwarten.
Du bist am Ende von a, daher kommt das nächste Element von b. Wenn das das letzte Element von b war, rennst du im nächsten if rein und willst ein Element von a kopieren ...

Und du vergleichst auch noch die Elemente ...

Daher ist eine Index out of bounds vorprogrammiert ....
 

capturion

Mitglied
Generell wäre wichtig, dann den Fehler auch zu nennen, wenn du einen bekommst. So ist eine Hilfestellung schwer möglich.

Was mir noch etwas auffällt: Du hast beim Merge lauter einzelne if. Da würde ich immer if ... else if ... else if ... else ... erwarten.
Du bist am Ende von a, daher kommt das nächste Element von b. Wenn das das letzte Element von b war, rennst du im nächsten if rein und willst ein Element von a kopieren ...

Und du vergleichst auch noch die Elemente ...

Daher ist eine Index out of bounds vorprogrammiert ....
Ja daran lags, hat nur fast nen ganzen Tag gedauert 3 kleine hinzuzufügen xD aber gehört denke ich mal dazu
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
O zwei Arrays nach Werten durchsuchen und zusammenfügen Java Basics - Anfänger-Themen 3
A Arrays zusammenfügen Java Basics - Anfänger-Themen 3
C Arrays zusammenfügen mit abwechselnden Werten Java Basics - Anfänger-Themen 3
C Beliebige Anzahl Arrays zusammenfügen Java Basics - Anfänger-Themen 5
D Arrays zusammenfügen und in einem Array ausgeben Java Basics - Anfänger-Themen 3
P Arrays abwechslend zusammenfügen Java Basics - Anfänger-Themen 31
A 2 arrays zusammenfügen Java Basics - Anfänger-Themen 5
T Einzelne Ziffer zusammenfügen (ohne Strings oder Arrays) Java Basics - Anfänger-Themen 2
G Feld bzw. Arrays erweitern oder zusammenfügen Java Basics - Anfänger-Themen 4
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21
J zwei String Arrays miteinander vergleichen Java Basics - Anfänger-Themen 18
A Java.util.Arrays Java Basics - Anfänger-Themen 15
T Methodenverknüpfung mit Arrays Java Basics - Anfänger-Themen 4
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
F Eine Zahl mit Arrays vergleichen Java Basics - Anfänger-Themen 7
A 2d Arrays aus txt.file einlesen Java Basics - Anfänger-Themen 16
B Arrays Java Basics - Anfänger-Themen 4
P Arrays "automatisch" erstellen lassen Java Basics - Anfänger-Themen 12
B Nur eine bestimmte Anzahl an Arrays ausgeben Java Basics - Anfänger-Themen 9

Ähnliche Java Themen

Neue Themen


Oben