Spiel Programmieren

valentina2013

Bekanntes Mitglied
Hallo,

ich möchte Conweys Spiel des Lebens (Game of life) programmieren. Dabe ist das Spielfeld mit einem zweidimensionalen Boolean-Array der Größe M*N dargestellt. Die Zustände Lebendig =true, tot=false. Jede Zehle hat 8 Nachbarn. Dafür dass es auch wirklich gilt berechne ich die Zustände nur auf den Indizies 0<i<M-1 sowie 0<j<N-1. Infolgedessen sind Zellen auf dem äußeren Rand zu allen Zeiten tot.
Erster Regel des Spels lautet: Eine tote Zelle mit genau drei lebenden Nachbarn wird in der folgegeneration neu geboren.
Nun muss ich dieser Regel als eine Funktion schreiben. Von 8 Nachbarn je dreier Kombinationen ergit sich insgesamt als 56 Kombinationen. Ich musste also 56 if anfrage machen um dieser Regel in einem algorithm umzuschreiben.

Java:
public class Life {

    public static boolean[][] conwayStep(boolean [][] world) {
		boolean[] [] newWorld = new boolean[world.length] [world[0].length];

		int m=world.length;
		int n=world[0].length;
		//Erster Regel:Eine tote Zelle mit genau drei lebenden  Nachbarn wird in Folgegeneration neu geboren
		for(int i=1;i<m-1;i++){
			for(int j=1;j<n-1; j++){
				if(world[i][j]==false){
					if(((world[i-1][j-1]==true)&&(world[i-1][j]==true))&&(world[i-1][i+1]==true)){
						else{
						if((world[i-1][j-1]==true)&&(world[i-1][j]==true)&&(world[i-1][i+1]==true))
					}
....usw
Kennt ihr einen einfacheren weg?


Danke:bahnhof:
 
Zuletzt bearbeitet:

valentina2013

Bekanntes Mitglied
was mache ich falsch
Java:
public class TestLife {

	public static boolean[][] conwayStep(boolean[][] world) {
		boolean[][] newWorld = new boolean[world.length][world[0].length];
		int m = world.length;
		int n = world[0].length;

		int neighbor;
		int counter = 0;
		int a, b;
		for (int i = 1; i < m - 1; i++) {
			for (int j = 1; j < n - 1; j++) {
				for (a = (i - 1); a < (i + 2); a++) {
					for (b = (j - 1); b < (j + 2); b++) {
						
							if (world[a][b])
								counter += 1;
						

						

						// einen zuviel mitgezaehlt?
						if (world[i][j])
							counter -= 1;

						neighbor = counter;

						if (world[i][j]) {
							// Erseter Regel:Lebende Zellen mit weniger als zwei
							// lebenden Nachbarn sterben in der Folegeneration
							// an E
							// Zweiter Regel:Lebende Zellen mit mehr als drei
							// lebenden
							// Nachbarn sterben in der Folgegeneration an
							// Überbevolkerung

							if ((neighbor < 2) || (neighbor > 3))
								newWorld[i][j] = false;
							// Dritter Regel:Eine Lebende Zelle mit zweil oder
							// drei
							// lebenden Nachbarn bleibt in der Folgegeneration
							// am Leben
							if ((neighbor == 2) || (neighbor == 3))
								newWorld[i][j] = true;
							// Vierter Regel:Eine tote Zelle mit genau drei
							// lebenden
							// Nachbarn wird in Folgegeneration neu geboren
						} else {
							if (neighbor == 3)
								newWorld[i][j] = true;
						}
					}
				}
			}
		}
		return newWorld;
	}

	public static void draw(boolean[][] world) {

		for (int i = 1; i < world.length - 1; i++)
			for (int j = 1; j < world[0].length - 1; j++)
				System.out.print((world[i][j] ? "o" : ".")
						+ (j == world[0].length - 2 ? "\n" : ""));
		System.out.println();
	}

	public static void main(String args[]) {
		boolean[][] world = {
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, true, false, false, false, false, false, false,
						false },
				{ false, false, false, true, false, false, false, false, false,
						false },
				{ false, true, true, true, false, false, false, false, false,
						false },
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, false, false, false, false, false, false,
						false, false },
				{ false, false, false, false, false, false, false, false,
						false, false } };

		draw(world);

		for (int i = 0; i < 24; i++) {
			world = conwayStep(world);
			draw(world);
		}
	}
}
 

Ruzmanz

Top Contributor
In einem Zug gibt es 8 Plätze. Wie genau stellst du nun fest, wie viele Leute in dem Zug sitzen? Natürlich kannst du jede Kombination aufstellen, die es gibt ... oder du machst etwas, dass man in der ersten Klasse lernt ;) Bischen denken schadet niemanden.
 

valentina2013

Bekanntes Mitglied
sei nicht frech,ja man zählt "wieviele plätze besetzt sind"-siehe oben die code, mache aber trotzdem was falsch ;(
 
Zuletzt bearbeitet:

ChristianK

Aktives Mitglied
Du verschachtelst vier for-Schleifen. Das ist eine Komplexität von O(n^4). Das solltest du sein lassen und einen Weg suchen, das mit weniger Aufwand zu machen. Wenn du schon nur 100 Durchläufe bei jeder for hast, bist du insgesamt bei 100 Millionen Durchläufen, das würde man dann ineffizientes Programmieren nennen.
 

valentina2013

Bekanntes Mitglied
hi, danke habe ich auch gemerkt, habe auch verbessert
Java:
public static boolean[][] conwayStep(boolean[][] world) {
		boolean[][] newWorld = new boolean[world.length][world[0].length];
		int m = world.length;
		int n = world[0].length;

		int neighbor;
		int counter = 0;
		for (int i = 2; i < m - 1; i++) {
			for (int j = 2; j < n - 1; j++) {

				if (world[i - 1][j - 1])
					counter += 1;
				if (world[i - 1][j])
					counter += 1;
				if (world[i - 1][j + 1])
					counter += 1;
				if (world[i][j - 1])
					counter += 1;
				if (world[i][j + 1])
					counter += 1;
				if (world[i + 1][j - 1])
					counter += 1;
				if (world[i + 1][j])
					counter += 1;
				if (world[i + 1][j + 1])
					counter += 1;

				neighbor = counter;

				if (world[i][j]) {
					
					if ((neighbor < 2) || (neighbor > 3))
						newWorld[i][j] = false;
					if ((neighbor == 2) || (neighbor == 3))
						newWorld[i][j] = true;

				} else {
					if (neighbor == 3)
						newWorld[i][j] = true;
				}
			}
		}
		return newWorld;
	}
stimmt aber immer noch nicht ganz, warum??????????:L
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
N Hey Leute und zwar versuche ich gerade ein 2D Spiel zu Programmieren aber die Figur will sich nicht nach links oder rechts bewegen :( Java Basics - Anfänger-Themen 12
G Ufo Spiel programmieren Java Basics - Anfänger-Themen 13
J Spiel programmieren Java Basics - Anfänger-Themen 16
S Spiel-Programmieren. Wenn ein Objekt den anderen berührt. Java Basics - Anfänger-Themen 6
S Spiel programmieren mit Java Java Basics - Anfänger-Themen 11
M Spiel programmieren Java Basics - Anfänger-Themen 16
kokojamboo92 Spiel programmieren Java Basics - Anfänger-Themen 1
I Spiel programmieren. Java Basics - Anfänger-Themen 16
K Kleines Spiel auf Java programmieren Java Basics - Anfänger-Themen 2
L rekursives spiel programmieren Java Basics - Anfänger-Themen 4
K Welches Spiel programmieren? Anfänger Java Basics - Anfänger-Themen 28
C Ein Handy Spiel programmieren mit Netbeans Java Basics - Anfänger-Themen 1
S Spiel Hangman programmieren - Ausgabe funktioniert nicht!!! Java Basics - Anfänger-Themen 13
PrograJan Poker Spiel ruückfrage Java Basics - Anfänger-Themen 8
I Threads Spiel gol Java Basics - Anfänger-Themen 6
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
J ArrayList vergleichen im spiel Mastermind Java Basics - Anfänger-Themen 2
enesss tictactoe spiel Java Basics - Anfänger-Themen 5
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
Jxhnny.lpz TicTacToe Spiel vs Computer. (Probleme) Java Basics - Anfänger-Themen 7
httprt Probleme bei dem erstellen von leveln in meinem Spiel Java Basics - Anfänger-Themen 2
berserkerdq2 Habe ein Spiel entwickelt, dass immer in der 4 Runde einen cast-Fehler erhält Java Basics - Anfänger-Themen 3
berserkerdq2 Spiel hängt sich immer in der 4 Runde auf, obwohl ich jede Runde das gleiche mache Java Basics - Anfänger-Themen 1
Ekooekoo Hilfe spiel Java Basics - Anfänger-Themen 5
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
Kennewick Basketball Spiel Ergebnisse Java Basics - Anfänger-Themen 11
X Erste Schritte Hilfe bei einem kleinen Spiel. Java Basics - Anfänger-Themen 19
D Snake-Spiel ähnliche Aufgabe Hilfe Java Basics - Anfänger-Themen 3
R Hangman-Spiel-zufälliges Wort ermitteln Java Basics - Anfänger-Themen 4
JEP1 Java Dialog Fenster schließen Spiel Java Basics - Anfänger-Themen 0
I Simples Risiko-Spiel Java Basics - Anfänger-Themen 5
Hallolu Pong-Spiel: Schläger schneller werden lassen Java Basics - Anfänger-Themen 9
M Java Spiel wie Wer wird Millionär Java Basics - Anfänger-Themen 1
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
C Java Spiel Java Basics - Anfänger-Themen 3
B Memory Spiel Java Basics - Anfänger-Themen 29
J Memory-Spiel Aktivierung der Methode mit Timer Java Basics - Anfänger-Themen 44
Kamy Ein einfaches "Vier Gewinnt" Spiel für Anfängerin Java Basics - Anfänger-Themen 51
A Breakout-Spiel , Ball mit Platten abprallen lassen Java Basics - Anfänger-Themen 1
Olis Erste Schritte Simples Memory Spiel möglich? Java Basics - Anfänger-Themen 1
J Spiel mit Button klick starten Java Basics - Anfänger-Themen 9
C Rekursives Backtracking beim Spiel Peg Java Basics - Anfänger-Themen 22
Spencer Reid Feedback zu kleinem Spiel Java Basics - Anfänger-Themen 4
R Kleines Java Spiel funktioniert nicht. Java Basics - Anfänger-Themen 2
I Spiel Java Basics - Anfänger-Themen 34
H ein einfaches Tic Tac Toe Spiel Java Basics - Anfänger-Themen 1
B Hilfe bei Escape - Spiel Java Basics - Anfänger-Themen 6
S Java-Spiel Java Basics - Anfänger-Themen 2
M Nim-Spiel geht in den negativen Bereich Java Basics - Anfänger-Themen 1
K Klassen Registrierungsseite für ein Spiel Java Basics - Anfänger-Themen 6
J Programmierung Quiz Spiel Java Basics - Anfänger-Themen 3
J Programmierung Quiz Spiel Java Basics - Anfänger-Themen 2
M Brauche Tipps für ein Spiel Java Basics - Anfänger-Themen 4
S Probleme mit GamGrid Spiel-Erstellung => Actor reagiert nicht auf Tastatur Java Basics - Anfänger-Themen 2
Mxxxt Mosaik Spiel - Steuerpanel wird nicht angezeigt Java Basics - Anfänger-Themen 5
M Erste Schritte Zufallszahl Spiel Problem Java Basics - Anfänger-Themen 7
Z Erste Schritte Kleines 2D. Spiel Objekt Bewegung funktioniert nicht Java Basics - Anfänger-Themen 2
H Spiel Kniffel: Gesamtes Array untersuchen. Java Basics - Anfänger-Themen 15
Tacofan Hangman als fertiges Spiel Java Basics - Anfänger-Themen 7
M Array und Objektorientierung? - TicTacToe Spiel Java Basics - Anfänger-Themen 43
C Klassen Sudoku-Spiel Werte werden nicht gesetzt Java Basics - Anfänger-Themen 4
W Tic Tac Toe Spiel ohne Arrays Java Basics - Anfänger-Themen 7
S Im objektorientiertem "Spiel" kämpfen Java Basics - Anfänger-Themen 3
I Klassen Umsetzungsfrage zu Spiel "Zuul" Java Basics - Anfänger-Themen 3
F Mastermind Spiel Java Basics - Anfänger-Themen 9
H Liste ausgeben (Spiel Hey Fisch (software-challenge) ändern Anzahl Fische) Java Basics - Anfänger-Themen 1
F Game-Engine für textbasierendes Spiel: Architektur? Java Basics - Anfänger-Themen 9
K Erste Schritte Frage Antwort Spiel - Fragen zur Planung Java Basics - Anfänger-Themen 2
J Java Spiel Zufallsauswahl für Zugbeginn Java Basics - Anfänger-Themen 3
J Frage Antwort Spiel - Wie Zeitcountdown realisieren? Java Basics - Anfänger-Themen 2
L Erste Schritte Spiel: Glückliches Sieben Java Basics - Anfänger-Themen 3
T Hangman spiel Java Basics - Anfänger-Themen 5
J 2 Pc's - Spiel gegeneinander ?! Java Basics - Anfänger-Themen 3
P 2D-Spiel und Bildschirmgröße Java Basics - Anfänger-Themen 2
O Methoden Fehlermeldung(Illegal start of expression) bei 4-Gewinnt-Spiel Java Basics - Anfänger-Themen 5
T Blöcke für ein Jump and Run Spiel Java Basics - Anfänger-Themen 8
S 2D-Spiel mit Threads... Java Basics - Anfänger-Themen 3
S 2D-Spiel im Vollbild an größe anpassen? Java Basics - Anfänger-Themen 3
M hangman spiel Java Basics - Anfänger-Themen 1
K JTextField in ein Spiel einfügen Java Basics - Anfänger-Themen 2
S Mosaik Spiel Java Basics - Anfänger-Themen 19
pinar memory spiel Java Basics - Anfänger-Themen 10
T OOP Mein erstes Java-Spiel - Schiffe versenken! Java Basics - Anfänger-Themen 2
K Erste Schritte Wie mache ich weiter? (Spiel-Menü) Java Basics - Anfänger-Themen 9
C Java Applet in html. Pong - old school Spiel Java Basics - Anfänger-Themen 10
J Variablen Invalid Character - Error -> Spiel mit Variablenergebnissen Java Basics - Anfänger-Themen 8
K Schere Stein Papier Spiel Java Basics - Anfänger-Themen 3
A Feedback zum Spiel Java Basics - Anfänger-Themen 5
F Hilfe bei meinem Spiel Java Basics - Anfänger-Themen 3
C Lotto Spiel Java Basics - Anfänger-Themen 23
Jagson Dotcom Spiel - Dots Random setzen Java Basics - Anfänger-Themen 8
Dogge Farben-Spiel Java Basics - Anfänger-Themen 20
K Diverse Bugs in einem Snake Spiel Java Basics - Anfänger-Themen 4
2 Lotto-Spiel Java Basics - Anfänger-Themen 9
X Datentypen Probleme mit Char bei meinem 1. Spiel Java Basics - Anfänger-Themen 20
D Erste Schritte Einstieg in die Java Spiel Programmierung Java Basics - Anfänger-Themen 7
H kleines Spiel [Processing] Java Basics - Anfänger-Themen 7
P NullPointerException in Memory-Spiel Java Basics - Anfänger-Themen 5
R Server/Client für Spiel Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben