Pereiti prie turinio

Rekomenduojami pranešimai

turiu dvi matricas, jose yra numeriai kubeliu. Jie negali kabeti ore turi buti vienas ant kito arba ant zemes. Pirma matrica atvaziduoja kaip jie sudeti, o antra(final) kaip juos reikia sudet. As noriu stumdymus vykdyti pazingsniuj. Bet susiduriau su problema kad man is karto 2 zigsnius atlieka. Turetu tik viena karta pastumti pirma kubeli. Cia kodas:

 

#include <stdio.h>
#include <iostream>
#include <string>
#include <windows.h>
using namespace std;

int matrix[3][3]= //turima
{
0,0,0,
0,1,0,
0,2,3
};

int final[3][3]= //norima gauti
{
0,0,0,
0,0,0,
2,3,1
};

int j, i;

int matricos_paisymas()
{
cout <<"\n";
for(int i = 0; i < 3; i++)
	{
		cout << "\n";
		for(int j = 0; j < 3; j++)
			{
				if (matrix[i][j]==1) 
				{
					matrix[i][j]=1;
					SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 14);
					cout << matrix[i][j] << " ";
					SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 7);
				}
				else
				{
					if (matrix[i][j]==2) 
					{
						matrix[i][j]=2;
						SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 12);
						cout << matrix[i][j] << " ";
						SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 7);
					}
					else
					{
						if (matrix[i][j]==3) 
						{
							matrix[i][j]=3;
							SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 2);
							cout << matrix[i][j] << " ";
							SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE), 7);
						}
						else
						{
							cout << matrix[i][j] << " ";
						}
					}
				}
			}
	}
return 0;
}
///////////////////////////////////////////////// VIENAS
int vienas()
{
for(int i = 0; i < 3; i++)
{
for(int j = 0; j < 3; j++)
{
	if (matrix[i][j]==1) // 1
	{
		if (i==2 && matrix[i][j]==final[i][j]) // jei apatinis elementas sutampa su norimos gauti matricos, tai nieko nedaro
		{
		}
		else // jei turimos matricos ir norimos gauti matricos vieneto pozicija apatineje eiluteje nesutampa, tai ji judina
		{
			if (matrix[2][j]==final[2][j] && matrix[i][j]==final[i][j]) // jei apatinis ir vidurinis elementai sutampa su norimos gauti matricos, tai nieko nedaro
			{
			}
			else
			{
				if (matrix[i-1][j] == 0) // tikrina ar virs 1 nera kito skaiciaus
				{
					matrix[i][j]=0;	// vietoj 1 yraso 0
					j=j-1; // paeinam vienu stulpeliu i kaire
					if (j == -1) // jei pirmas stulpelis tai pakeicia i paskutini
						{
							j=2;
						}
					for(int i=2; i>=0; i--)
					{
						if (matrix[i][j] == 0) //jei 0 tai 1
						{
							matrix[i][j]=1;
							matricos_paisymas();
							break; //sustoja iskart po pirmo irasymo
						}
					}
				}
			}
		}
	}
}
}
return 0;
}
///////////////////////////////////////////////// PAGRINDINE PROGRAMA
int main ()
{
vienas();

 system("pause");
 return 0;
}

 

isveda toki atsakyma:

 


0 0 0
0 0 0
1 2 3

0 0 0
0 0 1
0 2 3 Press any key to continue . . .

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...