Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-03-2012, 02:48   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] Distanza alfabetica ricorsiva in una stringa

Provando a fare questo esercizio...ho incontrato una difficoltà... distanza la definisco come la differenza tra dim/2 e il primo elemento dell'array. In questo esempio mi dà l'intero 3.
Ora...quando faccio la ricorsiva... a volte mi da 3 e a volte -3.. quindi non rispetta la condizione e restituisce sempre false.. help me!!!


Quote:
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.

SOLUZIONE:
Codice:
#include <iostream>
using namespace std;

bool distanzaalfa(char alfa[], int dim, int i);


int main(){
    const int dim=8;
    char alfa[]={"athidqkf"};
    int i=1;
    if(distanzaalfa(alfa,dim,i))
    cout<<"ok"<<endl;
    else cout<<"no"<<endl;
    
    



system("pause");
return 0;
}

bool distanzaalfa(char alfa[], int dim, int i){
     int distanza=0;
     
     if(dim%2!=0)
     return false;
     
     if(i==dim/2)
     return true;
     
     distanza=alfa[dim/2]-alfa[0];
     
     if(alfa[dim/2+i] - alfa[i] != distanza)
     return false;


     return distanzaalfa(alfa, dim, ++i);
}
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2012, 03:25   #2
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Usa abs(int):
Codice:
bool distanzaalfa(char alfa[], int dim, int i)
{
	if (dim % 2 != 0) return false;
	
	static int distanza = abs(alfa[dim/2] - alfa[0]);
	
	if (i == dim/2) return true;

	if (abs(alfa[dim/2+i] - alfa[i]) != distanza) return false;
	
	return distanzaalfa(alfa, dim, i + 1);
}
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2012, 11:15   #3
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
sarebbe il modulo? è un po una scappatoia;-) ..ai fini di esercitazione universitaria come potrei fare?

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2012, 12:21   #4
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
...
Ma che scappatoia e scappatoia! La distanza, in ogni ambito della matematica e delle scienze è un numero positivo, le distanze negative non hanno senso, quindi ci metti il modulo e punto.
Te lo suggerisce pure il testo dell'esercizio dicendo esplicitamente "la distanza tra due lettere è un numero positivo".

Ultima modifica di vendettaaaaa : 11-03-2012 alle 12:23.
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 11-03-2012, 16:37   #5
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
...
Ma che scappatoia e scappatoia! La distanza, in ogni ambito della matematica e delle scienze è un numero positivo, le distanze negative non hanno senso, quindi ci metti il modulo e punto.
Te lo suggerisce pure il testo dell'esercizio dicendo esplicitamente "la distanza tra due lettere è un numero positivo".
beh in effetti hai ragione.. ok allora il problema era questo!

Inviato dal mio GT-I9003 usando Tapatalk
mistergks è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
31,4 Tbps: Aisuru sfonda il suo stesso r...
Giocattoli AI, una falla espone oltre 50...
OPPO Reno15 in viaggio con Gaia Gozzi: i...
Elon Musk valuta il gioco delle tre cart...
Nuove revisioni per Abarth 600e: arrivan...
Intelligenza artificiale, re-training e ...
LG presenta a ISE 2026 la nuova serie di...
Alienware: disponibile in Italia il nuov...
Arrivano le bodycam sui treni di Ferrovi...
Nike taglia 775 posti negli USA: l'autom...
Crimson Desert si mostra in un nuovo gam...
Addio transistor? Questo dispositivo usa...
Jensen Huang: le fabbriche negli Stati U...
Sam Altman ammette l'errore: GPT-5.2 &eg...
Super test al gelo della Norvegia: quant...
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: 19:04.


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