Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni
Dal richiamo di Enrico Letta alla necessità di completare il mercato unico entro il 2028 alla visione di Nokia sul ruolo dell’IA e delle reti intelligenti, il Nokia Innovation Day 2025 ha intrecciato geopolitica e tecnologia, mostrando a Vimercate come la ricerca italiana contribuisca alle sfide globali delle telecomunicazioni
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-07-2012, 19:45   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
[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 05:40.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 26-07-2012, 08:33   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
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, 09: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, 12:22   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
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, 14: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, 14:37   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
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, 20:09   #7
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12843
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, 20:31   #8
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
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 01-08-2012, 23:28   #9
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12843
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


Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Il prototipo del razzo spaziale riutiliz...
Blue Origin mostra uno spettacolare vide...
Roscosmos: la capsula Bion-M2 è r...
ASUS sperimenta GPU senza connettori di ...
La Cina conquisterà lo spazio ent...
Samsung ha un nuovo entry level: debutta...
Caos nei cieli europei: attacco informat...
Volkswagen ferma la produzione di ID.Buz...
Super sconti del weekend Amazon: 5 novit...
Dreame non si ferma più: tra le n...
Samsung Galaxy Buds3 FE a meno di 95€ su...
Praticamente regalate: 135€ per le Squie...
Si rinnovano i coupon nascosti di settem...
Amazon sconta i componenti: occasioni d'...
Vibe coding: esplode la domanda di esper...
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:22.


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