View Full Version : [C]Controllare che una stringa ne contenga un'altra
Ciao, non riesco a risolvere questo esercizio, in pratica devo continuare a chiedere una stringa s1 e una stringa s2 (ma lo fa un programma esterno che deve essere solo richiamato) e controllare che s2 sia contenuta in s1 fino a che non arrivo al terminatore (\0 per intenderci) o la stringa contenga la parola fine.
Una mano?
Grazie
yggdrasil
07-11-2009, 11:21
cerchi lungo s1 se esiste il primo carattere di s2. se sì controlli che tutti i caratteri di s2 siano, ordinatamente dopo il carattere trovato in s1.
se sì ecco che è contenuta. se no, ritenti dal secondo carattere di s1 da capo. fino a quando non incontri su s1 il terminatore o non hai una lunghezza dalla fine minore della lunghezza di s2.
Puoi usare strstr della string.h ?
edit: Ah e' un esercizio. Allora lo devi fare a mano, magari come suggerito da yggdrasil.
cerchi lungo s1 se esiste il primo carattere di s2. se sì controlli che tutti i caratteri di s2 siano, ordinatamente dopo il carattere trovato in s1.
se sì ecco che è contenuta. se no, ritenti dal secondo carattere di s1 da capo. fino a quando non incontri su s1 il terminatore o non hai una lunghezza dalla fine minore della lunghezza di s2.
Grazie!
Una cosa del genere:
for(la lungghezza di s1)
{
if(carattere i-esimo di s1 == primo carattere s2)
for(partendo dal carattere i-esimo si s1 fino alla fine di s2)
if(s1 j-esimo == s2 j-esimo)
printf("ok la contiene")
else
printf("nada")
}
??
Ma come faccio a dirgli smettila se la stringa contiene la parola fine?
Qualcuno dice che ha messo un while(s2!='fine') ma all'inizio, ma funge?
Puoi usare strstr della string.h ?
edit: Ah e' un esercizio. Allora lo devi fare a mano, magari come suggerito da yggdrasil.
Sì è un esercizio ma lo devo fare in laboratorio, quindi sì posso usare string.h, qunidi se hai suggerimenti sono bene accetti
wingman87
07-11-2009, 13:15
Io farei un ciclo while: finché entrambe le stringhe non sono finite (controlli che i caratteri che stai controllando non siano '\0') confronto i caratteri, se sono diversi restituisco 0, altrimenti proseguo. Uscito dal ciclo controllo che i caratteri a cui sono giunto siano uguali (entrambi '\0'), se sì restituisco 1, altrimenti 0.
Se puoi usare la string.h puoi vedere qui come si usa la funzione strstr: LINK (http://www.cplusplus.com/reference/clibrary/cstring/strstr/)
Io farei un ciclo while: finché entrambe le stringhe non sono finite (controlli che i caratteri che stai controllando non siano '\0') confronto i caratteri, se sono diversi restituisco 0, altrimenti proseguo. Uscito dal ciclo controllo che i caratteri a cui sono giunto siano uguali (entrambi '\0'), se sì restituisco 1, altrimenti 0.
Se puoi usare la string.h puoi vedere qui come si usa la funzione strstr: LINK (http://www.cplusplus.com/reference/clibrary/cstring/strstr/)
in pratica strstr cerca se s2 è contenuta in s1 e poi restituisce un valore?
Ma non ho capito, li fa vedere che può sostituire un parola con un altra, quindi cosa restituisce, 1 se la trova e 0 se no?
Muoviti usando una "finestra" di ampiezza uguale alla parola che stai cercando e controlla nello stesso ciclo se la prima e l'ultima lettera coincidono con i rispettivi nella parola cercata.
Se sono uguali allora procedi col controllare la seconda e la penultima lettera e così via.
Ad esempio:
"car" in "cercare"
ampiezza 3
cer: c==c vero, r=r vero, e=e falso
erc: e==c falso
rca: r==c falso
car: c==c vero, r=r vero, a=a vero -> parola trovata
wingman87
08-11-2009, 01:48
Io farei un ciclo while: finché entrambe le stringhe non sono finite (controlli che i caratteri che stai controllando non siano '\0') confronto i caratteri, se sono diversi restituisco 0, altrimenti proseguo. Uscito dal ciclo controllo che i caratteri a cui sono giunto siano uguali (entrambi '\0'), se sì restituisco 1, altrimenti 0.
Ma che cavolo ho scritto? Mi sono riletto adesso e stento a crederci :doh:
La procedura che ho descritto serve a controllare se due stringhe sono uguali...
Quella che ha descritto WarDuck mi sembra corretta, anche se non ho capito perché salta "erc"
Ma che cavolo ho scritto? Mi sono riletto adesso e stento a crederci :doh:
La procedura che ho descritto serve a controllare se due stringhe sono uguali...
Quella che ha descritto WarDuck mi sembra corretta, anche se non ho capito perché salta "erc"
Hai ragione in realtà non si può fare così, non puoi saltarla, ora correggo.
Ciao, ho provato a fare così, ma non funziona
#include <string.h>
#include <stdio.h>
void main ()
{
char s1[20] , s2[20];
int n_s1 , n_s2 , i , j=0 ;
printf("Scrivi S1\n"); // Catturo s1
scanf("%s\n",s1);
printf("Scrivi S2\n"); //Catturo s1
scanf("%s\n",s2);
n_s1=strlen(s1); //Conto i caratteri di s1
n_s2=strlen(s2); //Conto i caratteri di s2
for(i=0;i<n_s1;i++) //Per ogni elemento di s1...
{
if(s1[i]==s2[0]) //...controlla se per caso sia uguale al primo elemento di s2
{
while((s1[i]==s2[j]) && (j<n_s2)) //Se sì, controlla anche gli altri elementi
{
j++;
i++;
}
printf("OK, e' compresa\n");
}
else
printf("non e' compresa\n");
}
getchar();
getchar();
}
In pratica s1 devo scriverla due volte altrimenti non me la prende, premo la prima volta invio e non succede niente, poi scrivo s2 e il programma termina
@WarDuck:
Non capisco cosa mi stai suggerndo, concettualmente sì, ok, ma non saprei come implementarlo
wingman87
08-11-2009, 18:36
In pratica s1 devo scriverla due volte altrimenti non me la prende, premo la prima volta invio e non succede niente, poi scrivo s2 e il programma termina
Togli \n dagli scanf.
Per l'algoritmo per la ricerca sei sulla buona strada ma è ancora incompleto.
Togli \n dagli scanf.
Per l'algoritmo per la ricerca sei sulla buona strada ma è ancora incompleto.
Ok, un suggerimento? Almeno dirmi qual'è il problema logico?
wingman87
09-11-2009, 13:56
Facciamo un esempio, prova a cercare "sar" in "sassari" con l'algoritmo che hai scritto.
Facciamo un esempio, prova a cercare "sar" in "sassari" con l'algoritmo che hai scritto.
SIIII!!! Viene! Ho fatto qualche prova e mi sembra che funzioni.
Posto il codice
#include <string.h>
#include <stdio.h>
void main ()
{
char s1[20] , s2[20];
int n_s1 , n_s2 , i , j=0,compreso=0 ;
printf("Scrivi S1\n"); // Catturo s1
scanf("%s",s1);
printf("Scrivi S2\n"); //Catturo s1
scanf("%s",s2);
n_s1=strlen(s1); //Conto i caratteri di s1
n_s2=strlen(s2); //Conto i caratteri di s2
for(i=0;i<n_s1;i++) //Per ogni elemento di s1...
{
if(s1[i]==s2[0]) //...controlla se per caso sia uguale al primo elemento di s2
{
while((s1[i]==s2[j]) && (j<n_s2)) //Se sì, controlla anche gli altri elementi
{
j++;
i++;
}
if(j==n_s2) //Se ha raggiunto la fine di S2 senza problemi...
compreso=1; //...allora è contenuta
}
}
if(compreso==1)
printf("OK, e' compresa\n");
else
printf("non e' compresa\n");
getchar();
getchar();
}
wingman87
09-11-2009, 22:29
In verità se cerchi "sar" in "sassari" dice che non è compresa...
In verità se cerchi "sar" in "sassari" dice che non è compresa...
Sei sicuro che sar è contenuta in sassari?:D Altre parole funziona...
wingman87
10-11-2009, 15:05
Sei sicuro che sar è contenuta in sassari?:D Altre parole funziona...
Cosa intendi? sar è in sassari
Cosa intendi? sar è in sassari
Sì, ok, ti stavo prendendo in giro;) Sicuramente il problema è quando si trova la prima lettera da cercare doppia, però continuo a non capire dove sia l'errore
wingman87
10-11-2009, 20:52
Sì, ok, ti stavo prendendo in giro;) Sicuramente il problema è quando si trova la prima lettera da cercare doppia, però continuo a non capire dove sia l'errore
Ah, ok, scusa ma oggi sono stordito.
Il problema è che se la prima lettera coincide parte la ricerca delle altre lettere, ma se questa fallisce la ricerca della seconda parola nella prima non riparte dalla prima lettera della seconda parola e dalla lettera successiva a quella che coincideva nella prima. Es:
s1="sassari" s2="sar"
i=0, j=0 -> s1[0]==s2[0] -> j++, i++
i=1, j=1 -> s1[1]==s2[1] -> j++, i++
i=2, j=2 -> s1[2]!=s2[2] -> i++
i=3, j=2 -> s1[3]==s2[0] ma s1[3]!=s2[2] -> i++
...
vBulletin® v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.