Hledání slov v matici – C / C++ – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Hledání slov v matici – C / C++ – Fórum – Programujte.comHledání slov v matici – C / C++ – Fórum – Programujte.com

 

Bery
~ Anonymní uživatel
7 příspěvků
22. 5. 2015   #1
-
0
-

Ahoj, dělám program na řešení osmisměrky a funkce mi není schopná najít hledané slovo a už vůbec není schopná převést velké písmeno na malé. Ať zkouším tolower nebo -'A' + 'a' stále vyhazuje nesmyslné znaky, nebyl by mi někdo schopen poradit nebo najít chybu ? Předem moc děkuji 

for(i=0;i<Pocet;i++){
poc_p = strlen(Slova[i].slovo);

for(j=0;j<Rad;j++){  //vodorovný směr ---->
for(k=0;k<Slp;k++){
p = 0;
if(((mat[j][k]==Slova[i].slovo[0]) || ((mat[j][k] - 'a' + 'A') 
==Slova[i].slovo[0])) && Slp - k >= poc_p){
	p = 1;
	for(l=1;l<poc_p - 1 ;l++){ 
		if(mat[j][k+l] == Slova[i].slovo[l] || (mat[j][k+l] - 'a' + 'A') == Slova[i].slovo[l])
		p = p + 1;
			}
	if( p == poc_p)
	for(l=0;l<poc_p;l++)
	mat[j][k+l] = mat[j][k+l] - 'A' + 'a' ;
Nahlásit jako SPAM
IP: 178.216.151.–
Bery
~ Anonymní uživatel
7 příspěvků
22. 5. 2015   #2
-
0
-

tak jinak, vyřešil jsem hledání následovně ale stále mi při výpisu malých písmen vyhodí error, konkrétně 

(unsigned)(c+1) <=256 , netuší někdo čím by to mohlo být ? 

{
	for(i=0;i<Pocet;i++){
		poc_p = strlen(Slova[i].slovo);

		for(j=0;j<Rad;j++){				
			for(k=0;k<Slp;k++){
//vodorovný směr ---->
				p = 0;					 //představuje nalezená písmena
				if(((mat[j][k]==Slova[i].slovo[0]) || ((mat[j][k] - 'A' + 'a') == Slova[i].slovo[0])) && Slp - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){ 
						if(mat[j][k+l] == Slova[i].slovo[l] || (mat[j][k+l] - 'A' + 'a') == Slova[i].slovo[l])
						p = p + 1;
					}
					if( p = poc_p){
						for(l=0;l<poc_p;l++)
							mat[j][k+l] = mat[j][k+l] - 'A' + 'a' ;}
					if( p = poc_p)
						goto nalezeno;}
//vodorovný směr <----
				if(((mat[j][k] == Slova [i].slovo[0]) || ((mat[j][k] + 'A' - 'a') == Slova[i].slovo[0])) && Slp - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){
						if(mat[j][k-l] == Slova[i].slovo[l] || (mat[j][k+l] - 'a' + 'A') == Slova[i].slovo[l])
						p = p + 1;
					}
					if ( p == poc_p)
						for(l=0;l<poc_p;l++)
							mat[j][k-l] = mat[j][k-l] - 'A' + 'a' ;
					if ( p == poc_p)
						goto nalezeno;}

//směr dolů  		
					p = 0;
				if(((mat[j][k]==Slova[i].slovo[0]) || ((mat[j][k] - 'A' + 'a') == Slova[i].slovo[0])) && Rad - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){ 
						if(mat[j+l][k] == Slova[i].slovo[l] || (mat[j+l][k] - 'A' + 'a') == Slova[i].slovo[l])
						p = p + 1;
					}
					if( p = poc_p){
						for(l=0;l<poc_p;l++)
							mat[j+l][k] = mat[j+l][k] - 'A' + 'a' ;}
					if( p = poc_p)
						goto nalezeno;}

//směr nahoru	
					p = 0;
				if(((mat[j][k] == Slova [i].slovo[0]) || ((mat[j][k] + 'A' - 'a') == Slova[i].slovo[0])) && Rad - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){
						if(mat[j-l][k] == Slova[i].slovo[l] || (mat[j-l][k] - 'a' + 'A') == Slova[i].slovo[l])
						p = p + 1;
					}
					if ( p == poc_p)
						for(l=0;l<poc_p;l++)
							mat[j-l][k] = mat[j-l][k] - 'A' + 'a' ;
					if ( p == poc_p)
						goto nalezeno;}

//šímký směr zleva dolů doprava
				p = 0;					 
				if(((mat[j][k]==Slova[i].slovo[0]) || ((mat[j][k] - 'A' + 'a') == Slova[i].slovo[0])) && Rad - k >= poc_p ){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){ 
						if(mat[j+l][k+l] == Slova[i].slovo[l] || (mat[j+l][k+l] - 'A' + 'a') == Slova[i].slovo[l])
						p = p + 1;
					}
					if( p = poc_p){
						for(l=0;l<poc_p;l++)
							mat[j+l][k+l] = mat[j+l][k+l] - 'A' + 'a' ;}
					if( p = poc_p)
						goto nalezeno;}

//šikmý směr zprava dolů doleva
				p=0;
				if(((mat[j][k] == Slova [i].slovo[0]) || ((mat[j][k] + 'A' - 'a') == Slova[i].slovo[0])) && Slp - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){
						if(mat[j+l][k-l] == Slova[i].slovo[l] || (mat[j+l][k+l] - 'a' + 'A') == Slova[i].slovo[l])
						p = p + 1;
					}
					if ( p == poc_p)
						for(l=0;l<poc_p;l++)
							mat[j+l][k-l] = mat[j+l][k-l] - 'A' + 'a' ;
					if ( p == poc_p)
						goto nalezeno;}

//šikmý směr zleva nahoru doprava				
				p=0;
				if(((mat[j][k] == Slova [i].slovo[0]) || ((mat[j][k] + 'A' - 'a') == Slova[i].slovo[0])) && Rad - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){
						if(mat[j-l][k+l] == Slova[i].slovo[l] || (mat[j-l][k+l] - 'a' + 'A') == Slova[i].slovo[l])
						p = p + 1;
					}
					if ( p == poc_p)
						for(l=0;l<poc_p;l++)
							mat[j-l][k+l] = mat[j-l][k+1] - 'A' + 'a' ;
					if ( p == poc_p)
						goto nalezeno;}

//šikmý směr zprava nahoru doleva					
				p=0;
				if(((mat[j][k] == Slova [i].slovo[0]) || ((mat[j][k] + 'A' - 'a') == Slova[i].slovo[0])) && Rad - k >= poc_p){
					p = 1;
					for(l=1;l<poc_p - 1 ;l++){
						if(mat[j-l][k] == Slova[i].slovo[l] || (mat[j-l][k] - 'a' + 'A') == Slova[i].slovo[l])
						p = p + 1;
					}
					if ( p == poc_p)
						for(l=0;l<poc_p;l++)
							mat[j-l][k] = mat[j-l][k] - 'A' + 'a' ;
					if ( p == poc_p)
						goto nalezeno;}
				else {Slova[i].slovo == Nenalezeno[n].slovo;
						n++;}
}}

nalezeno:;
	}}
Nahlásit jako SPAM
IP: 178.216.151.–
PiranhaGreg0
Stálý člen
22. 5. 2015   #3
-
0
-

V tomhle se nedá vyznat... rozděl si kód do funkcí a hned to půjde líp ;-) 

bool isInRow(char * row, int rowWidth, const char * word) {
	/* todo */
}

bool isInColumn(char ** matrix, int column, int height, const char * word) {
	/* todo */
}

bool isInRows(char ** matrix, int width, int height, const char * word) {
	for (int y = 0; y < height; y++)
		if (isInRow(matrix[y], width, word))
			return true;

	return false;
}

bool isInColumns(char ** matrix, int width, int height, const char * word) {
	for (int x = 0; x < width; x++)
		if (isInColumn(matrix, x, height, word))
			return true;

	return false;
}

bool isInMatrix(char ** matrix, int width, int height, const char * word) {
	if (isInRows(matrix, width, height, word))
		return true;

	if (isInColumns(matrix, width, height, word))
		return true;

	/* todo */

	return false;
}
Nahlásit jako SPAM
IP: 2a00:1028:9942:b69e:e821:...–
Bery
~ Anonymní uživatel
7 příspěvků
22. 5. 2015   #4
-
0
-

#3 PiranhaGreg
Dobrá, jeden směr vypadá například takhle ale ani tak to ty slova nemůže najít

for(j=0;j<Rad;j++){				
for(k=0;k<Slp;k++){
//vodorovný směr ---->
p = 0;			//představuje nalezená písmena
  if(((mat[j][k]==Slova[i].slovo[0]) || ((mat[j][k] - 'A' + 'a') == Slova[i].slovo[0])) && Slp - k >= poc_p){
    p = 1;
for(l=1;l<poc_p - 1 ;l++){ 
if(mat[j][k+l] == Slova[i].slovo[l] || (mat[j][k+l] - 'A' + 'a') ==  Slova[i].slovo[l])
    p = p + 1;}
if( p = poc_p){
for(l=0;l<poc_p;l++)
    mat[j][k+l] = mat[j][k+l] - 'A' + 'a' ;}
if( p = poc_p)
    goto nalezeno;}

Nahlásit jako SPAM
IP: 178.216.151.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 35 hostů

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý