Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-07-2012, 20:45   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
[C] carattere di una stringa

ciao,
per determinare un certo tipo carattere in una matrice di stringhe uso la seguente chiamata:

if( filename[i][strlen(filename[i])-4] ) == 'x') fai qualcosa

è un errore?

Ultima modifica di misterx : 26-07-2012 alle 06:40.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 09:33   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
lo so che la domanda era banale ma una svista mi faceva ottenere un risultato sbagliato che ora ho risolto

Già che ci sono vi chiedo qual'è il modo più furbo per verificare se in una stringa esiste nella sua parte finale una sottostringa

esempio

stringa="xyz.aabbabcdefg.aabb";
sottostringa=".aabb";

devo verificare se la parte finale di stringa termina con sottostringa.
Chiaramente nel mio esempio creato apposta, si nota che sottostringa potrebbe essere presente anche in una posizione qualsiasi di stringa, ma a me interessa verrificare che esista solo alla fine.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 10:31   #3
GByTe87
Senior Member
 
L'Avatar di GByTe87
 
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
Idea di massima: parti dalla fine delle stringhe e torna verso l'inizio. Al primo carattere diverso, la prima stringa non contiene la seconda.

Implementazione a GRANDISSIME linee.

Codice:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>

int strrevcmp(char * s1, char * s2) {
    for (int i = strlen(s1) - 1, j = strlen(s2) - 1; j && i; --j, --i)
        if (s1[i] != s2[j])  return 0;
    return 1;
}


int main (int argc, char ** argv) {
    char * s1 = argv[1];
    char * s2 = argv[2];

    if (strrevcmp(s1, s2))
        printf("S1 contiene S2 in coda\n");
    else
        printf("S1 NON contiene S2 in coda\n");
}
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO
GByTe87 è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 13:22   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da GByTe87 Guarda i messaggi
Idea di massima: parti dalla fine delle stringhe e torna verso l'inizio. Al primo carattere diverso, la prima stringa non contiene la seconda.

Implementazione a GRANDISSIME linee.

Codice:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>

int strrevcmp(char * s1, char * s2) {
    for (int i = strlen(s1) - 1, j = strlen(s2) - 1; j && i; --j, --i)
        if (s1[i] != s2[j])  return 0;
    return 1;
}


int main (int argc, char ** argv) {
    char * s1 = argv[1];
    char * s2 = argv[2];

    if (strrevcmp(s1, s2))
        printf("S1 contiene S2 in coda\n");
    else
        printf("S1 NON contiene S2 in coda\n");
}
ottima idea, grazie
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 15:21   #5
british
Member
 
L'Avatar di british
 
Iscritto dal: Sep 2008
Città: Milano
Messaggi: 126
Quote:
Originariamente inviato da misterx Guarda i messaggi
Già che ci sono vi chiedo qual'è il modo più furbo per verificare se in una stringa esiste nella sua parte finale una sottostringa
Usando la libreria standard:

Codice:
#include <string.h>

int suffix_cmp(const char * s, const char * suffix)
{
	const size_t s_len = strlen(s);
	const size_t suffix_len = strlen(suffix);

	if( s_len == 0 || suffix_len == 0 ) {
		return 0;
	}

	if( suffix_len <=  s_len ) {
		return ! strcmp(s + s_len - suffix_len, suffix);
	} else {
		return 0;
	}

}
ciao!
british è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 15:37   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da british Guarda i messaggi
Usando la libreria standard:

Codice:
#include <string.h>

int suffix_cmp(const char * s, const char * suffix)
{
	const size_t s_len = strlen(s);
	const size_t suffix_len = strlen(suffix);

	if( s_len == 0 || suffix_len == 0 ) {
		return 0;
	}

	if( suffix_len <=  s_len ) {
		return ! strcmp(s + s_len - suffix_len, suffix);
	} else {
		return 0;
	}

}
ciao!

bella idea, grazie 1000
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 30-07-2012, 21:09   #7
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12961
Usa strstr .

http://linux.die.net/man/3/strstr

Fa una ricerca ottimizzata (usa l'algoritmo di Boyer-Moore) per trovare la sottostringa, e ti restituisce il puntatore all'inizio di essa.

A quel punto basta confrontare se l'ha trovato alla fine ovvero:

Se puntatore_fine_stringa - puntatore_tornato_da_strstr == lunghezza_stringa_da_cercare, allora vuol dire che l'hai trovato in fondo .

Nota: se non erro strstr si ferma alla prima sottostringa che matcha, devi lavorare un pochino per trovare alla fine.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 01-08-2012, 21:31   #8
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Usa strstr .

http://linux.die.net/man/3/strstr

Fa una ricerca ottimizzata (usa l'algoritmo di Boyer-Moore) per trovare la sottostringa, e ti restituisce il puntatore all'inizio di essa.

A quel punto basta confrontare se l'ha trovato alla fine ovvero:

Se puntatore_fine_stringa - puntatore_tornato_da_strstr == lunghezza_stringa_da_cercare, allora vuol dire che l'hai trovato in fondo .

Nota: se non erro strstr si ferma alla prima sottostringa che matcha, devi lavorare un pochino per trovare alla fine.


quella sopra è una bella idea ed anche piuttosto performante, di primo acchito, fa una differenza di indirizzi e posiziona il puntatore nella posizione quasi di fine stringa sottraendo la lunghezza del campione da verificare
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 02-08-2012, 00:28   #9
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12961
Quote:
Originariamente inviato da misterx Guarda i messaggi
quella sopra è una bella idea ed anche piuttosto performante, di primo acchito, fa una differenza di indirizzi e posiziona il puntatore nella posizione quasi di fine stringa sottraendo la lunghezza del campione da verificare
Si infatti, stavo rivedendo, avevo risposto velocemente e non avevo capito bene cosa volessi fare.

Comunque volendo essere puntigliosi, in caso negativo (trovo un carattere che sicuramente non appartiene alla stringa) strstr fallisce prima di strcmp (che in realtà non fallisce mai, fa sempre la differenza di bytes) .

Nota: puoi posizionarti alla fine della stringa e fare comunque una ricerca con strstr.

Ma sono dettagli.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Spotify introduce 'Taste Profile': il co...
Sole e pioggia insieme: il nuovo pannell...
AWS e Cerebras uniscono le forze: nuova ...
Windows 11: accesso al drive C: bloccato...
BYD pronta a comprare un marchio storico...
Windows 11 si prepara ai monitor oltre i...
Apple avrebbe fissato un target di vendi...
Ultimi giorni per sfruttare le Offerte d...
I migliori smartphone in offerta ora su ...
Le migliori TV delle Offerte di Primaver...
Uno dei robot più avanzati del 2025 crol...
Robot aspirapolvere con stazione automat...
Il nuovo top di gamma compatto di OPPO n...
Nilox aggiorna la sua gamma di fat e-bik...
Meta valuta tagli fino al 20% della forz...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 21:31.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v