Unsortierter Array mit einmaligen Zahlen

nikisback

Mitglied
Guten Tag zusammen,

ich habe folgendes Problem:

Ich muss eine Methode erstellen
Code:
public static int[] genZahlenEinm(int size)
, welche einen Array erstellt, der alle Zahlen von 0 bis size-1 enthält und zwar unsortiert (wäre es sortiert, hätte ich ja kein Problem damit).

Eine andere Methode soll einen int Array zurückgeben, mit size-vielen Zufallszahlen, von 0 bis size-1.
Diese Methode habe ich so geschrieben:


Code:
	public static int[] generateNumbers(int size)
	{
		int x = 0;
		int[] a = new int[size];
		
		while (x <= size) 
		{
			a[x] = (int) ((size-2) * Math.random() + 1);
			
			x++;
		}
		
		return a;
		
	}

Meine Idee wäre quasi alle doppelt vorkommenden Zahlen zu ersetzen (in der Methode genZahlenEinm), durch jeweils die niedrigste, noch nicht vorgekommene Zahl. Hätte dafür aber keine intelligente Idee.

Oder gibt es dafür bereits eine simple Funktion? Wir werden teilweise ziemlich ins kalte Wasser geschmissen und ich stecke gerade fest.

EDIT: ein Fehler behoben
 
Zuletzt bearbeitet:

pro2

Bekanntes Mitglied
Öhm, könntest du nicht erst mal das Array ganz normal füllen und dann einfach zufällig ein paar Zahlen vertauschen? Hier bietet Java Bordmittel, aber ich denke, das könnte man auch selbst schreiben. Halte ich jedenfalls für wesentlich praktischer, als erst zu versuchen, zufällig zu füllen, bis dann mal alle drin sind.

Das hier könnte dir helfen:
Shuffle an Array in Java | Ryan Rampersad

Die 2. gezeigte Methode benutzt die Bordmittel, aber ich weiß nicht, ob ihr das dürft. Die 1. stellt eigentlich genau dein Problem dar.
 
Zuletzt bearbeitet:

nikisback

Mitglied
Vielen Dank für deine Antwort.
Bis jetzt dürfen wir eigentlich alles probieren, was uns Java zur Verfügung stellt.
Ich werde mal die zweite Variante testen.
Was mich halt etwas stört ist, dass bei der Methode genZahlenEinm(int size) auch auf die Funktion Math.random() verwiesen wurde.

Ich glaube also es ist schon danach gefragt den Array direkt zufällig zu füllen.

Es ist nämlich später noch die Rede davon, den Array mit Hilfe von Arrays.sort() zu sortieren.
 
Zuletzt bearbeitet:

AmunRa

Gesperrter Benutzer
Hier eine IDee zur ueberlegung.

fuelle dein array mit allen Zahlen aufsteigend.

und nimm eine Schleife wie oft du den Schrit machst ist dir ueberlassen

Lass dir mit Java Random einen Zufalls wert "start" zwischen 0 und der Länge deines Arrays geben.
und einen andern mit End zwischen 0 und Länge des Arrays.

vertausche nun die Zahlen die an den indexpositionen Start und End sind wenn du das oft gemacht hast sind alle zahlen im Array zufällig enthalten
 

Logaff

Bekanntes Mitglied
die frage ist was bedeutet sortiert? Es gibt kein offensichtliches Muster zwischen Nachfolgern einer Zahl oder aufsteigend und absteigend angeordnet ist verboten?


Das einfachste Wär wenn du quasi ein Array erstellst wo alle möglichen Zahlen sortiert drinne sind. Anschließend überlegst du dir eine Methode wie du Zahlen einsammelst. Du könntest ja eine Zahlenfolge dir ausssuchen die abwechselnd von hinten und von vorne nimmt, bzw diese in 2 Funktionen aufteilen

Geg: Array A[0,....,size-1]
Ges: Unsortiertes Array aus A

1) Möglichkeit abwechselnd von Vorn und Hinten wählen
-----------------------------------------------------
vorn: V[0,1,2,...(size-1)/2] (Rundung usw muss beachtet werden damit man auch das Element in der Mitte gewählt werden kann)
hinten: H[(size-1)/2+1,(size-1)/2+2,....size-1]

Bildung einer unsortierten Reihenfolge durch abwechselndes Wählen des Indexes:
V[0],H[0],V[1],V[2]......

Schon hast du aus Beispie:
[1,2,3,4,5,6] => [1,6,2,5,3,4]

2) Weitere Möglichkeiten durch "Sondieren"
--------------------------------------------
Möglich ist es sich eine Sondierfunktion aussusuchen welche sogewählt sein muss das jeder Index erreicht werden kann (Methode aus dem Auflösen von Hashkollitionen)

Bsp: n = size-1
(Generatorfunktion) mod n (damit bleibst du immer in Array möglichen Indizes)

Generatorfunktion muss nun gewählt werden das alle Möglichen Indizes mod n erzeugt werden, diese schreibst du denn in das unsortierte Array

siehe: Lineares Sondieren

----
edit: Nachdem was ich oben gelesen hab ....würd ich auch Random nehmen^^
 

pro2

Bekanntes Mitglied
Hier mal ein Ansatz.

Java:
public class Array
{
    public static int[] getFilledArray(int size)
    {
        int a[] = new int[size];
        for (int i = 0; i < size; i++)
        {
            a[i] = i;
        }
        return a;
    }

    public static void shuffleArray(int a[])
    {
        Random rand = new Random();
        for (int i = 0; i < a.length * 2; i++)
        {
            int posi1 = rand.nextInt(a.length);
            int posi2 = rand.nextInt(a.length);
            int temp = a[posi1];
            a[posi1] = a[posi2];
            a[posi2] = temp;
        }
    }

    public static void main(String[] args)
    {
        int array[] = getFilledArray(10);
        shuffleArray(array);
        System.out.println(Arrays.toString(array));
    }

}

Wenn du was nicht verstehst: Fragen.
 

AndiE

Top Contributor
Was soll die
Java:
public static int genZahlenEinm(int size)

genau machen? Was für ein int-Wert soll zurückgegeben werden?
 

nikisback

Mitglied
Oh stimmt, habe den Fehler oben verbessert.

Sollte heißen:
Code:
public static int[] genZahlenEinm(int size)

Die Methode soll halt alle Zahlen von 0 bis size-1 in zufälliger Reihenfolge in den Array schreiben.
 

AndiE

Top Contributor
Und wozu soll die eine zweite Methode aufrufen, die die gleiche Parameter und Rückgabewert hat? Sind das zwei verschiedene Size? So wie beim Lotto( einmal 6 und einmal 49)?
 

nikisback

Mitglied
Die Methode selbst ruft dann gar nichts mehr auf.

Der Rückgabearray geht aber an verschiedene Methoden zur binären und sequentiellen Suche.
Eine andere Methode wiederum wertet die Anzahl der Durchläufe aus.

Das hier war nur das Problem, wegen dem ich nicht weiter gekommen bin
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
L Gridmuster in einem Array Java Basics - Anfänger-Themen 2
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
G zweidimensionales int Array sortieren Java Basics - Anfänger-Themen 57
W Array ausgeben Java Basics - Anfänger-Themen 29

Ähnliche Java Themen

Neue Themen


Oben