Problem mit for Schleife

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
hallo

ich habe ein problem mit einer for schleife.
diese for schleife ist in einer methode, welche mir immer die position des nächsten wahren wertes zurückgibt.
es darf aber nie zwei Mal die gleiche position im array zurückgegeben werden, desshalb zähle ich die variable pos hoch und beginne beim nächsten versuch ab der position pos zu suchen.
ist das ende des arrays erreicht, sollte die suche wieder von vorne beginnen, sprich wieder vom anfang des arrays an beginnen.
ist kein wert im ganzen array true, sollte -1 zurückgegeben werden.

irgendwie stoppt aber die for schleife.
ich habe das folgendermassen versucht, bin mir aber nicht sicher ob das so korrekt ist:

Code:
int pos = 0;
boolean[] arr = new boolean[100];

private int getPos(){
for (int i = pos; i < arr.length; i++) {
      
  if (pos >= arr.length-1) {
      // reset the reading position
      pos = 0;

  }
      
  pos++;
      
  // check if the array element is true
  if (arr[i]) {
     return i;
  }

  }
  return -1;
}

wenn z.B. im booleanarray die felder arr[40], arr[41],arr[42], arr[43],arr[44], arr[45],arr[46], arr[47] true sind, sollte die methode immer 40,41,42,43,44,45,46,47,40,41,42,43,44,45,46,47,40,41,42,43,44,45,46,47 etc zurückgeben!

weiss jemand, wo das problem liegt?
grüsse
 

motschow

Aktives Mitglied
wenn ein arraywert true ist dann stoppt die methode (-> return i) Rufst du die Methoe selber auch in einer schleife auf?
 
G

Guest

Gast
nein,ich rufe die methode nicht in einer schleife auf!
grüsse
 

norman

Top Contributor
Code:
public class TestingClass {
	// variable pos gelöscht, weil sie garnicht gebraucht wurde
	boolean[] arr = new boolean[100];

	private int getPos(){
		for (int i = 0; i < arr.length; i++) {
		      
			  if (i >= arr.length-1) {
			      i = 0;		
			  }
			      
			  if (this.arr[i]) {
				  // übergebe i an eine andere methode die irgendwas machen
				  // soll, zb ausgabe:
				  printPosOfNextTrueElement(i);
			  }
		
		}
		return -1;
	}
	
	private void printPosOfNextTrueElement(int i) {
		System.out.println("arr[" + i + "]");
	}
}
 

mikachu

Top Contributor
Code:
public class TestingClass {
// ...
/*  wozu soll dieser block dienen ?!?
           if (i >= arr.length-1) {
               i = 0;      
           }
*/
// ...
   }
}
 

norman

Top Contributor
mika hat gesagt.:
Code:
public class TestingClass {
// ...
/*  wozu soll dieser block dienen ?!?
           if (i >= arr.length-1) {
               i = 0;      
           }
*/
// ...
   }
}
liest du oben, checkst du :wink:


..damit er nach dem durchlaufen des arrays wieder am anfang beginnt
 

mikachu

Top Contributor
...da wird aber in diesem falle NIE der index 99 erreicht...

ergo, das feld hat immer einen wert zuviel :!:
 

mikachu

Top Contributor
und damit ist auch noch nicht realisiert, dass, wenn es keinen freien platz mehr gibt, die schleife aufhört :wink:
 

mikachu

Top Contributor
Code:
public class TestingClass {
   // variable pos gelöscht, weil sie garnicht gebraucht wurde
   boolean[] arr = new boolean[100];

   private int getPos(){
      boolean hasFreeElements = false;     // are there more elements which are 'true' ?
      for (int i = 0; i < arr.length; i++) {
           
           if (i > arr.length-1) {
               i = 0;      
               hasFreeElements = false;  // reset the flag to 'false'
           }
              
           if (this.arr[i]) {
              // übergebe i an eine andere methode die irgendwas machen
              // soll, zb ausgabe:
              printPosOfNextTrueElement(i);
              hasFreeElements = true;
           }

           if( i == arr.length - 1 && ! hasFreeElements ) // if 'i' is the index of the last element AND there are no more 'true' elements
               break;  // leave the loop
      
      }
      return -1;
   }
   
   private void printPosOfNextTrueElement(int i) {
      System.out.println("arr[" + i + "]");
   }
}


:!: NOT TESTED :!:
 
G

Guest

Gast
Das Problem war das du pos in der Schleife hochgezählt hast. Das hat aber keinen
Einfluss auf die Methode, du zählst immer nur von pos bis arr.length.

Einfacher wird es wenn du immer von 0 bis 100 zählst und die
aktuelle Position einfach dazuadierst. Damit i zwischen 0 und 100
bleibt einfach einmal Modulo 100 rechnen.

Code:
int pos = 0;
boolean[] arr = new boolean[100];

private int getPos(){

for (int i = 0; i < arr.length; i++)
  if (arr[(i+pos)%arr.length])
     return i;

  pos = ++pos%arr.length;
}
 
G

Guest

Gast
Korrektur:

Code:
int pos = 0;
boolean[] arr = new boolean[100];

private int getPos(){

for (int i = 0; i < arr.length; i++)
  if (arr[(i+pos)%arr.length])
     return (i+pos)%arr.length;

  pos = ++pos%arr.length;
}
 
G

Guest

Gast
Lol das passiert wenn man nicht testet. Sorry für den Verwirrung stiftenden Code *g
Der hier ist aber getestet:

Code:
int pos = 0;
boolean[] arr = new boolean[10];
	
		
public int getPos() {
  for (int i=0; i<arr.length; i++)
    if (arr[(pos=++pos%arr.length)])
      return pos;
							
  return -1;
}
 

mikachu

Top Contributor
ich bin immer noch der meinung, dass der beim erstem auftreten eines 'true'-elements die methode beendet :roll:
...was nicht beabsichtigt ist :meld:

wenn z.B. im booleanarray die felder arr[40], arr[41],arr[42], arr[43],arr[44], arr[45],arr[46], arr[47] true sind, sollte die methode immer 40,41,42,43,44,45,46,47,40,41,42,43,44,45,46,47,40,41,42,43,44,45,46,47 etc zurückgeben!
 

mikachu

Top Contributor
...ist mir ja grad noch ne ideee gekommen :meld: :D

Code:
public class TestingClass {
   // variable pos gelöscht, weil sie garnicht gebraucht wurde
   boolean[] arr = new boolean[100];

   private int getPos(){
      boolean hasFreeElements = false;     // are there more elements which are 'true' ?
      int i = 0;
      while( true ){
           if (i > arr.length-1) {
               i = 0;     
               hasFreeElements = false;  // reset the flag to 'false'
           }
             
           if (this.arr[i]) {
              // übergebe i an eine andere methode die irgendwas machen
              // soll, zb ausgabe:
              printPosOfNextTrueElement(i);
              hasFreeElements = true;
           }

           if( i++ == arr.length - 1 && ! hasFreeElements ) // if 'i' is the index of the last element AND there are no more 'true' elements
               break;  // leave the loop
      }
      return -1;
   }
   
   private void printPosOfNextTrueElement(int i) {
      System.out.println("arr[" + i + "]");
   }
}
 
G

Gast

Gast
Die Methode soll doch immer den nächsten Wert im Array liefern der
True ist. Das tut die Methode. Jedenfalls denke ich das Gast das so
gemeint hat. Man muss sich nur mal anschauen wie er versucht hat
die Methode zu schreiben.

Und er schreibt es auch:
in einer methode, welche mir immer die position des nächsten wahren wertes zurückgibt.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
RalleYTN Problem bei Schleife die durch einen 2D raum iterieren soll Allgemeine Java-Themen 1
W Problem mit Index in einer for-Schleife Allgemeine Java-Themen 8
S for-Schleife, while-Schleife Problem Allgemeine Java-Themen 6
ModellbahnerTT Problem: Schleife über Textdatei Allgemeine Java-Themen 5
V Problem in While-Schleife Allgemeine Java-Themen 3
J FOR-Schleife-Problem Allgemeine Java-Themen 10
M Problem mit while/do Schleife Allgemeine Java-Themen 12
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0

Ähnliche Java Themen

Neue Themen


Oben