ESERCIZIO 3-3
Scrivete una funzione expand(s1,s2) che espande le notazioni abbreviate nella stringa s1 in notazioni estese ( per esempio traduce a-z in abc....xyz) e pone in s2 la stringa risultante. s1 può essere costituita da caratteri maiuscoli, minuscoli e cifre; gestite abbreviazioni quali a-b-c a-z0-9 e -a-z. Assicuratevi che un - iniziale o finale venga interpretato letteralmente.
L' ultima frase per me significa che un - iniziale o finale resta un - .
void expand(char s1[], char s2[]){
int c,inizio,stato,j,k;
inizio=stato=j=0;
for(inizio=stato=j=c=0;s1[c]!='\0';c++)
switch (stato){
case 0 :
if((s1[c]>='0' && s1[c]<='9') || (s1[c]>='A' && s1[c]<='Z') || (s1[c]>='a' && s1[c]<='z')){
inizio=s2[j++]=s1[c];
stato=1;
}
else
s2[j++]=s1[c];
break;
case 1 :
if((s1[c]>='0' && s1[c]<='9') || (s1[c]>='A' && s1[c]<='Z') || (s1[c]>='a' && s1[c]<='z')){
inizio=s2[j++]=s1[c];}
else if (s1[c]=='-')
stato=2;
else{
s2[j++]=s1[c];
stato=0;
}
break;
case 2 :
if(((s1[c]>='0' && s1[c]<='9') || (s1[c]>='A' && s1[c]<='Z') || (s1[c]>='a' && s1[c]<='z')) && (inizio<s1[c])){
for (k=inizio+1;k!=s1[c];k=(k+1)%128)
if ((k>='0' && k<='9') || (k>='A' && k<='Z') || (k>='a' && k<='z'))
s2[j++]=k;
inizio=s2[j++]=s1[c];
stato=1;
}
else if (inizio==s1[c])
stato=1;
else{
stato=0;
s2[j++]='-';
s2[j++]=s1[c];
}
break;
}
if (stato==2)
s2[j++]='-';
s2[j]='\0';
}
__________________
Ingegnere: colui che ha molta familiarità con i modelli e molto poca con le modelle.
|