Originariamente inviato da AndreaNobili
Ciao,
mi trovo a dover fare una cosa un po' particolare (anche se non credo sia difficile...un po' a basso livello semmai)
Per favore è abbastanza urgente...
Provo a spiegarvela iniziando con un esempietto pratico pratico, considerate la stringa
PEPE
Ogni carattere è un char. Ho un puntatore chiamato yytext che può puntarmi ai vari char all'interno di questa stringa (cioè yytext può puntare alla prima P, alla prima E, alla seconda P ed alla seconda E dentro tale stringa)
Poi ho un altro puntatore chiamato offset che anch'esso può puntare ai vari char della stringa.
C'è un modo di sapere quanto è la differenza in byte tra i 2 puntatori per poter stabilire se sono adiacenti?
Da quello che sò un char occupa 1 byte (correggetemi se sbaglio). In pratica usando questo metodo a basso livello posso stabilire se 2 caratteri all'interno della stringa sono adiacenti?
In pratica a livello di codice ho questa semplicissima if:
codice:
if(*yytext != consonante){ /* Se la consonante attualmente riconosciuta e puntata da yytext è diversa dalla consonante precedente il cui valore è contenuto nella variabile consonante */
printf("%c", *yytext); /* Stampa sullo schermo la consonante riconosciuta. */
a cui però dovrei aggiungere un'ulteriore condizione con un AND logico, che il carattere puntato da yytext ed il carattere puntato da offset abbiano una sola posizione di distanza (siano caratteri adiacenti)..in pratica credo qualcosa tipo:
(yytext - offset) == 1 byte (almeno credo...o qualcosa del genere...)
Qualcuno sà aiutarmi? Per favore è veramente molto urgente...
Grazie mille
Andrea