Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-04-2011, 19:05   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] Funzione ricorsiva coppie alfabeto con uguale distanza

Ho un problema con un esercizio su una funzione ricorsiva:

Si scriva in C++ una funzione ricorsiva che riceva almeno un array di caratteri (assumendo che contenga solo lettere dell’alfabeto minuscole) e la sua dimensione (supponendo che sia sempre PARI) e restituisca TRUE se è verificata la seguente proprietà. Si considerino coppie di elementi di cui il primo è nella prima metà dell’array, e il secondo è l’elemento di posto corrispondente nella seconda metà. Per ogni coppia, la distanza tra i due elementi nell’alfabeto inglese deve essere uguale. La distanza tra due lettere è un numero positivo, ed è definita come il numero di lettere che intercorrono tra essi nell’ordine alfabetico.
Esempio: la funzione invocata su un array contenente la sequenza di caratteri ‘a’ ‘t’ ‘h’ ‘i’ ‘d’ ‘q’ ‘k’ ‘f’ dovrà restituire TRUE. Infatti la distanza tra il primo elemento della prima metà (‘a’) e il primo elemento della seconda metà (‘d’) è pari a 3 e così è per tutte le altre coppie di elementi corrispondenti (‘t’ --‘q’, ‘h’ -- ‘k’ e ‘i’-- ‘f’).
Specificare quale deve essere la prima invocazione per la funzione.


Io ho provato a fare cosi'... va bene?non mi compila...ma credo che l'algoritmo sia questo o no? magari c'è qualche errore
Codice:
bool distanzaAlfabetica(char a[], int dim){
     if(dim%2 != 0) //per far terminare subito la funzione in caso di stringa dispari
     return false;
     
     if(a[i]=='\0') //passo base
     return true;
     
     int distanza= a[0] - a[dim/2];
     if(a[i] - a[dim/2+i] != distanza) //passo ricorsivo
     return false;
     
     distanzaAlfabetica(a[], dim, i+1);
     
}//chiusura funzione
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 19:31   #2
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2125
Tu hai dichiarato

Codice:
bool distanzaAlfabetica(char a[], int dim){
e poi hai chiamato ricorsivamente

Codice:
distanzaAlfabetica(a[], dim, i+1);
cosa noti?

E poi ci sarebbe anche un'altra cosa, ma prima cerca di arrivarci da solo.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 19:43   #3
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
ops è vero..errore di distrazione! chiaramente il prototipo è:

Codice:
bool distanzaAlfabetica(char a[], int dim, int i);
L'altro errore qual'è??
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 19:56   #4
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2125
no, niente, avevo notato una cosa nel calcolo della distanza, ma mi sembra corretto ad una seconda occhiata.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 20:00   #5
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Allora è tutto corretto??
Comunque...volevo sapere... con le stringhe.. posso usare tutti gli operatori? -, +, *, /, % ecc...??? All'inizio mi sembrava strano fare una sottrazione tra stringhe....però mi sembrava l'unico modo per risolvere il problema...ma non sono sicuro che si possa fare..
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 20:08   #6
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2125
Quote:
Originariamente inviato da mistergks Guarda i messaggi
Allora è tutto corretto??
Comunque...volevo sapere... con le stringhe.. posso usare tutti gli operatori?
Beh, provalo

Quote:
Originariamente inviato da mistergks Guarda i messaggi
Comunque...volevo sapere... con le stringhe.. posso usare tutti gli operatori? -, +, *, /, % ecc...??? All'inizio mi sembrava strano fare una sottrazione tra stringhe....però mi sembrava l'unico modo per risolvere il problema...ma non sono sicuro che si possa fare..
Ah ecco! Non avevo ripensato che fosse un array di char. Datti una bella letta:

http://www.exforsys.com/tutorials/c-...ings-in-c.html
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 20:16   #7
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
cioè? non si possono usare gli array di char in questo contesto?!
Non ho mai capito la differenza tra array di char e string ..
quando si usa uno e quando l'altro? che benefici hanno?
In un esame universitario di fondamenti di c++ ...qual'è consigliato usare? char o string?
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 20:23   #8
Supdario
Member
 
Iscritto dal: Mar 2008
Messaggi: 267
La differenza sta nel fatto che i "char *" sono il modo di rappresentare le stringhe in C (quindi ad un livello più basso), invece il C++ ha il tipo "std::string" che è di livello più alto, permettendo di eseguire altre funzioni di alto livello (ridimensionamento, concatenazione, ecc..)

Se programmi in C++ chiaramente usi std::string, salvo certe eccezioni.
Supdario è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 20:24   #9
dierre
Senior Member
 
L'Avatar di dierre
 
Iscritto dal: Sep 2004
Città: Interamnia Urbs
Messaggi: 2125
A mio parere non va mai usato direttamente char* a meno che non stai usando del codice C.

con std::string hai qualcosa che è ottimizzato, standardizzato e diciamocelo, anche più facile. Eventualmente char* si usa sei hai da gestire delle parole che non devi manipolare e che siano piccole.

Si dice che char* sia più performante, ma non ne so abbastanza su questo.
__________________
Un wormhole (buco di tarlo, in italiano), detto anche Ponte di Einstein-Rosen, è una ipotetica caratteristica topologica dello spaziotempo che è essenzialmente una "scorciatoia" da un punto dell'universo a un altro, che permetterebbe di viaggiare tra di essi più velocemente di quanto impiegherebbe la luce a percorrere la distanza attraverso lo spazio normale.
Go to a Wormhole
dierre è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 23:59   #10
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
mi sapreste indicare un pò di materiale sulle string c++?? Mi servirebbero tutte le funzioni di manipolazione, come si dichiarano, come si inizializzano ecc...
sul mio libro non le trovo perchè ho un libro di fondamenti di informatica! e si usano i char.. ora ho il dubbio....per un esame di fondamenti... dove non si usano funzioni pronte....vanno usati i char o le string?
mistergks è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Giorgia Meloni 'una di noi': Palazzo Chi...
Airbus richiama oltre 6.000 A320: rischi...
Tra open hybrid cloud e sovranità...
Il nuovo SSD Samsung è fatto con ...
Russia contro WhatsApp: il piano per spe...
Battlefield 6, oltre 2,39 milioni di ten...
La Cina spiazza tutti: nuovo chip per l'...
Nexperia, altro che caso chiuso: il caos...
Nuova tecnologia AMD FSR Ray Regeneratio...
Motorola Edge 60 Neo e Motorola Moto Wat...
Weekend e offerte Amazon Black Friday ag...
Il tuo indirizzo IP è compromesso...
Eureka J15 Evo Ultra in super sconto: or...
Robot aspirapolvere in super sconto per ...
Black Friday Amazon: le migliori occasio...
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: 00:31.


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