Frage zu Random

Status
Nicht offen für weitere Antworten.
Kurze Beschreibung zum Code:
4 Algorithmen zur Maximalen Summenbestimmung innerhalb eines Arrays von bestimmter Länge. Mein Problem ist das mit Randomzahlen gefüllte Array.

Code:
import java.io.*;
import java.util.*;

public class MaxSum {

// 	static int[] a = {31, -41, 59, 26, -53, 58, 97, -93, -23, 84};
//	static int[] a = new int[10000];

	static int[] a;
	static Random r = new Random();
	
	public static int fillArray(int[] a) {
		int i = 0;
		for(i=0; i<10000; i++) {
			a[i] = r.nextInt(200)-100;
		}
		return a[i];
	}
	
	static int left = 0;
	static int right = 0;
 
	static Writer fw = null;
 
	/*
	 * MaxSum1
	 */
	public static int maxSum1(int[] a) {
		int maximum = 0;
		for (int left = 0; left<a.length; left++) {
			for (int right = left; right<a.length; right++) {
				int sum = 0;
				for (int k = left; k<right; k++) {
					sum += a[k];
					if (sum>maximum) maximum = sum;
				}
			}
		}
		return maximum;
	}
 
	/*
	 * MaxSum2
	 */
	public static int maxSum2a(int[] a) {
		int maximum = 0;
		for (int left = 0; left<a.length; left++) {
			int sum = 0;
			for (int right = left; right<a.length; right++) {
				sum += a[right];
				if (sum>maximum) maximum = sum;
			}
		}
		return maximum;
	}
 
	/*
	 * MaxSum3
	 */
	public static int maxSum3(int[]a) {
		maxSum3_(left, right);
		return maxSum3_(0,right-1);
	}
 
	
	public static int maxSum3_(int left, int right) {
		if (left>right) return 0;
		if (left==right) return a[right];
		int middle = (left+right)/2;
		//links
		int lmidmax = 0;
		int suml = 0;
		for (int pos = middle; pos>=left; pos--) {
			suml += a[pos];
			lmidmax = Math.max(lmidmax,suml);
		}
		//rechts
		int rmidmax = 0;
		int sumr = 0;
		for (int pos = middle; pos<right; pos++) {
			sumr += a[pos];
			rmidmax = Math.max(rmidmax, sumr);
		}
		//linker Teil
		int leftmax = maxSum3_(left,middle);
		//rechter Teil
		int rightmax = maxSum3_(middle,right);
		return Math.max(lmidmax+rmidmax,Math.max(leftmax,rightmax));
	}
 
	
	/*
	 * MaxSum4
	 */
	public static int maxSum4(int a[]) {
		int maximum = 0;
		int maxright = 0;
  
		for (int pos = 0; pos<right; pos++) {
			maxright = Math.max(maxright+=a[pos],0);
			maximum = Math.max(maximum,maxright);
		}
  		return maximum;
	}
 
	public static void main (String[]args) {
		
		fillArray(a);
		right = a.length;
		
		System.out.println(maxSum1(a) + "\n");
		System.out.println(maxSum2a(a) + "\n");
//		System.out.println(maxSum3(a) + "\n");
		System.out.println(maxSum4(a));
		
		
  
 	}
}

Warum erhalte ich eine NullPointerException? Anders.
Wieso akzeptiert der Compiler das leere Array nicht, das ja in der fillArray() mit Randomzahlen gefüllt wird und demnach vorher leer ist bzw. ungefüllt ist?

Liegt es daran, weil ich dem Array keine Größe gebe?
 

Schandro

Top Contributor
Java:
static int[] a;
Das hier ist kein int-Array. Das ist nur eine Referenz die theoretisch auf irgendein int-Array im Arbeitspeocher zeigen kann.

Du musst "a" auf was zeigen lassen => es initialisieren
 
Wenn ich es also mit "null" initialisiere, dann sollte es deiner Meinung nach gehen?
Das habe ich bereits probiert. "null" funktioniert nicht.

Hast du eine Idee?!
 

sol1x

Mitglied
wenn du es mit null initialisierst erhällst du logischerweise eine NullPointerException oder nicht?! ;)
 

sol1x

Mitglied
ja das bringt dir aber auch noch nicht viel - du musst eben den Array dann noch füllen - bzw. musst nicht - wäre aber sinnvoll ;)
 

Schandro

Top Contributor
du hast in der fillArray Methode in der Bedingung der for-Schleife auch ne feste Zahl stehen (10000)...
änder das auf die Länge des Arrays
a.length

wenn es an was anderem liegt: poste den code.
 
Code:
static int[] a = new int[10000];
	static Random r = new Random();
	
	public static int fillArray(int[] a) {
		int i = 0;
		for(i=0; i<a.length; i++) {
			a[i] = r.nextInt(200)-100;
		}
		return a[i];
	}

Also soll das jetzt so aussehen?

Nochmal der gesamte Code

Code:
import java.io.*;
import java.util.*;

public class MaxSum {

// 	static int[] a = {31, -41, 59, 26, -53, 58, 97, -93, -23, 84};
	static int[] a = new int[10000];
	static Random r = new Random();
	
	public static int fillArray(int[] a) {
		int i = 0;
		for(i=0; i<a.length; i++) {
			a[i] = r.nextInt(200)-100;
		}
		return a[i];
	}
	
	static int left = 0;
	static int right = 0;
 
	/*
	 * MaxSum1
	 */
	public static int maxSum1(int[] a) {
		int maximum = 0;
		for (int left = 0; left<a.length; left++) {
			for (int right = left; right<a.length; right++) {
				int sum = 0;
				for (int k = left; k<right; k++) {
					sum += a[k];
					if (sum>maximum) maximum = sum;
				}
			}
		}
		return maximum;
	}
 
	/*
	 * MaxSum2
	 */
	public static int maxSum2a(int[] a) {
		int maximum = 0;
		for (int left = 0; left<a.length; left++) {
			int sum = 0;
			for (int right = left; right<a.length; right++) {
				sum += a[right];
				if (sum>maximum) maximum = sum;
			}
		}
		return maximum;
	}
 
	/*
	 * MaxSum3
	 */
	public static int maxSum3(int[]a) {
		maxSum3_(left, right);
		return maxSum3_(0,right-1);
	}
 
	
	public static int maxSum3_(int left, int right) {
		if (left>right) return 0;
		if (left==right) return a[right];
		int middle = (left+right)/2;
		//links
		int lmidmax = 0;
		int suml = 0;
		for (int pos = middle; pos>=left; pos--) {
			suml += a[pos];
			lmidmax = Math.max(lmidmax,suml);
		}
		//rechts
		int rmidmax = 0;
		int sumr = 0;
		for (int pos = middle; pos<right; pos++) {
			sumr += a[pos];
			rmidmax = Math.max(rmidmax, sumr);
		}
		//linker Teil
		int leftmax = maxSum3_(left,middle);
		//rechter Teil
		int rightmax = maxSum3_(middle,right);
		return Math.max(lmidmax+rmidmax,Math.max(leftmax,rightmax));
	}
 
	
	/*
	 * MaxSum4
	 */
	public static int maxSum4(int a[]) {
		int maximum = 0;
		int maxright = 0;
  
		for (int pos = 0; pos<right; pos++) {
			maxright = Math.max(maxright+=a[pos],0);
			maximum = Math.max(maximum,maxright);
		}
  		return maximum;
	}
 
	public static void main (String[]args) {
		
		fillArray(a);
		right = a.length;
		
		System.out.println(maxSum1(a) + "\n");
		System.out.println(maxSum2a(a) + "\n");
//		System.out.println(maxSum3(a) + "\n");
		System.out.println(maxSum4(a));
		
		
  
 	}
}
 
Zuletzt bearbeitet:
Wenn ich fillArray() "void" deklariere, dann passoert:

Code:
Cannot make a static reference to the non-static method fillArray(int[]) from the type MaxSum

Dabei ist fillArray als static deklariert und auch das Array??
 
Zuletzt bearbeitet:

Schandro

Top Contributor
Nein, dass passiert wenn du das "static" wegmachst...
du brauchst nur "int" auf void ändern und die letzte Zeile der Methode mit dem return-Statement entfernen.
 
Warum brauch man denn der Methode fillArray keinen primitiven Datentyp zuzuweisen? Ist das generell so, wenn ich einen Methode void setze? Kann mich laut meinem Stand an kein Muster erinnern, was das angeht!
 

Lexi

Bekanntes Mitglied
Wenn deine fillArray Methode ein Array zurückgeben soll, dann kannst du das auch einfach hinschreiben:
Java:
public int[] fillArray(int[] array){ ...
 

Schandro

Top Contributor
Eine Methode hat entweder einen Rückgabewert (das muss kein primitiver Datentyp sein!) oder sie ist void.
 
Code:
long zstVorher1;
		long zstNachher1;
		long zstVorher2;
		long zstNachher2;
		long zstVorher3;
		long zstNachher3;
		long zstVorher4;
		long zstNachher4;

		fillArray(a);
		left = 0;
		right = a.length;
		
				zstVorher1 = System.currentTimeMillis();
		System.out.println(zstVorher1);
		maxSum1(a);
		zstNachher1 = System.currentTimeMillis();
		System.out.println(zstNachher1);
		System.out.println("Zeit benötigt MaxSum1: " + ((zstNachher1 - zstVorher1)) + " ms");
		
		zstVorher2 = System.currentTimeMillis();
		System.out.println(zstVorher2);
		maxSum2a(a);
		zstNachher2 = System.currentTimeMillis();
		System.out.println(zstNachher2);
		System.out.println("Zeit benötigt MaxSum2: " + ((zstNachher2 - zstVorher2)) + " ms");		

		zstVorher4 = System.currentTimeMillis();
		System.out.println(zstVorher4);
		maxSum4(a);
		zstNachher4 = System.currentTimeMillis();
		System.out.println(zstNachher4);
		System.out.println("Zeit benötigt MaxSum4: " + ((zstNachher4 - zstVorher4)) + " ms");

Das ist die Ausgabe:
Code:
1242558195859
1047
1242558196328
Zeit benötigt MaxSum1: 469 ms
1242558196328
1047
1242558196343
Zeit benötigt MaxSum2: 15 ms
1242558196343
1047
1242558196343
Zeit benötigt MaxSum4: 0 ms

Jedem Programmier ziehts wahrscheinlich die Schuhe aus, aber ich weiß einfach keine andere Lösung!

Ich will die Zeiten messen, die die einzelnen Algorithmen brauchen und versuch das mit System.currentTimeMillis();, aber leider setzt er auch bei separaten Variablen für die Zeitstempel immer die gleiche Zeit. Sprich nach dem ersten Berechnen kommt bei den letzten beiden Berechnungen immer null raus bzw. nur ein kleiner Wert. Gibt es eine andere Lösung zum Messen der Zeit? Oder verbraucht der letzte Algorithmus keine Zeit? ;) Die Frage ist eher nicht ernst gemeint.

Grüße
 
Zuletzt bearbeitet:

Schandro

Top Contributor
Java:
Oder verbraucht der letzte Algorithmus keine Zeit?
Nein, aber er ist viel schneller als die anderen Algorithmen, deswegen musst du die Größe des Arrays erhöhen um eine Zeit != 0 zu sehen. Wenn du das machst,musst du aber vorher das Aufrufen der anderen beiden Algorithmen auskommentieren, da diese bei einem so großen Array extrem lange brauchen.

Normalerweise macht man solche Tests übrigens immer nacheinanden und nicht gleichzeitig, da eine bereits laufende JVM verschiedene Sachen während der Laufzeit optimiert.
 

sol1x

Mitglied
Du kannst auch System.nanoTime() verwenden ;)
jedoch ist da das ergebnis leider nicht immer korrekt ... aber du kannst dir ja mal die api zu nanoTime durchlesen ;)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Math.random() - kurze frage. Java Basics - Anfänger-Themen 20
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben