Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-10-2011, 01:29   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] Funzione ricorsiva: somma pari-dispari

Ho un problema con la seguente funzione.. non riesco a capire cosa c'è che non va.. mi stampa sempre false...

Ecco la specifica:
una funzione ricorsiva che riceva un array di numeri interi e la sua dimensione e restituisca TRUE se le somme di due interi consecutivi nell’array sono alternatamente una pari ed una dispari, ossia comunque si prenda un intero x nell’array, se la somma di x con l’intero che lo precede è pari (risp. dispari), la somma di x con l’intero che lo segue deve essere dispari (risp. pari). Esempio: la funzione invocata su un array contenente la sequenza di interi 1 3 2 6 3 3 2 dovrà restituire TRUE. Infatti le somme degli interi consecutivi sono 1+3 - pari, 3+2 – dispari, 2+6 – pari, 6+3 – dispari, 3+3 – pari, 3+2 – dispari.


Codice:
#include <iostream>
using namespace std;

bool ricorsiva(int v[], int dim, int i);

int main(){
    
    int i=0;
    const int dim=7;
    int v[dim]={1,3,2,6,3,3,2};
    if(ricorsiva(v,dim,i)){
                           cout<<"ok"<<endl;
                           }

    else{

                          cout<<"no"<<endl;
                          }
                              
system("pause");
return 0;
    
}

bool ricorsiva(int v[], int dim, int i){
     if(i==dim-3)
     return true;
     
     
     if(v[i] + v[i+1] % 2 == 0 && v[i+1] + v[i+2] % 2 == 0) 
     return false;
     
     if(v[i] + v[i+1] % 2 != 0 && v[i+1] + v[i+2] % 2 != 0)
     return false;
    
     return ricorsiva(v,dim,i++);   
}

Ultima modifica di mistergks : 30-10-2011 alle 01:33. Motivo: aggiunta
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2011, 08:05   #2
starfred
Senior Member
 
Iscritto dal: Jul 2011
Messaggi: 381
ciao, ci son diversi errori, prima di tutto le condizioni sono ambigue, cioè la precedenza tra gli operatori logici/matematici non è specificata. Quindi vanno corrette es:

Codice:
if(v[i] + v[i+1] % 2 == 0 && v[i+1] + v[i+2] % 2 == 0)
in

Codice:
if(((v[i] + v[i+1]) % 2 == 0) && ((v[i+1] + v[i+2]) % 2 == 0))
poi c'è l'errore nella return

Codice:
return ricorsiva(v,dim,i++);
Decisamente grave l'operatore incremento non è usato in maniera appropiata, nel tuo caso il valore di "i" viene prima usato poi incrementato con ovvie conseguenze.

ciao
__________________
Concluso positivamente con: Kamzata, Ducati82, Arus, TheLastRemnant, ghost driver, alexbull1, DanieleRC5, XatiX
starfred è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2011, 10:40   #3
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da starfred Guarda i messaggi
ciao, ci son diversi errori, prima di tutto le condizioni sono ambigue, cioè la precedenza tra gli operatori logici/matematici non è specificata. Quindi vanno corrette es:

Codice:
if(v[i] + v[i+1] % 2 == 0 && v[i+1] + v[i+2] % 2 == 0)
in

Codice:
if(((v[i] + v[i+1]) % 2 == 0) && ((v[i+1] + v[i+2]) % 2 == 0))
poi c'è l'errore nella return

Codice:
return ricorsiva(v,dim,i++);
Decisamente grave l'operatore incremento non è usato in maniera appropiata, nel tuo caso il valore di "i" viene prima usato poi incrementato con ovvie conseguenze.

ciao



Grazie mille per la risposta! Ho fatto le correzioni, ma ancora non va!
ecco la funzione corretta:
Codice:
bool ricorsiva(int v[], int dim, int i){
     if(i==dim-3)
     return true;
     
     
     if((v[i] + v[i+1] % 2 == 0) && (v[i+1] + v[i+2] % 2 == 0)) 
     return false;
     
     if((v[i] + v[i+1] % 2 != 0) && (v[i+1] + v[i+2] % 2 != 0))
     return false;
    
     return ricorsiva(v,dim,++i);   
}
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2011, 13:21   #4
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Non hai veramente applicato quanto suggerito da starfred: hai trascurato delle parentesi importanti per dare precedenza alla somma rispetto al resto intero.

Inoltre considero preferibile ridurre al minimo i confronti e gli elementi coinvolti nelle condizioni (senza arrivare all'illeggibilità).
Ripensando l'esercizio perseguendo questo obiettivo lo scriverei così:
  • la somma dell'elemento con indice pari più quello successivo dev'essere pari
  • la somma dell'elemento con indice dispari più quello successivo dev'essere dispari
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 01-11-2011, 12:16   #5
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da Gimli[2BV!2B] Guarda i messaggi
Non hai veramente applicato quanto suggerito da starfred: hai trascurato delle parentesi importanti per dare precedenza alla somma rispetto al resto intero.

Inoltre considero preferibile ridurre al minimo i confronti e gli elementi coinvolti nelle condizioni (senza arrivare all'illeggibilità).
Ripensando l'esercizio perseguendo questo obiettivo lo scriverei così:
  • la somma dell'elemento con indice pari più quello successivo dev'essere pari
  • la somma dell'elemento con indice dispari più quello successivo dev'essere dispari
Ho risolto mettendo le parentesi al posto giusto!!
Codice:
if((v[i] + v[i+1]) % 2 == 0 && (v[i+1] + v[i+2]) % 2 == 0) 
     return false;
     
if((v[i] + v[i+1]) % 2 != 0 && (v[i+1] + v[i+2]) % 2 != 0)
     return false;
cosa intendi per indice pari o dispari? potresti mostrarmi il codice?
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-11-2011, 13:40   #6
Gimli[2BV!2B]
Senior Member
 
L'Avatar di Gimli[2BV!2B]
 
Iscritto dal: Feb 2006
Città: Parma
Messaggi: 3010
Una condizione: la parità della somma dell'elemento più quello successivo
Codice:
( ( v[i] + v[i + 1] ) % 2 )
dev'essere uguale a quella dell'indice
Codice:
( i % 2 )
Non ti ho scritto esplicitamente il codice della funzione perché è un esercizio, ma credo che tu possa tranquillamente capire.
__________________
~Breve riferimento ai comandi GNU/Linux (ormai non molto breve...)
Gimli[2BV!2B] è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2011, 00:21   #7
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Quote:
Originariamente inviato da Gimli[2BV!2B] Guarda i messaggi
Una condizione: la parità della somma dell'elemento più quello successivo
Codice:
( ( v[i] + v[i + 1] ) % 2 )
dev'essere uguale a quella dell'indice
Codice:
( i % 2 )
Non ti ho scritto esplicitamente il codice della funzione perché è un esercizio, ma credo che tu possa tranquillamente capire.
tipo due if: uno per i pari e uno per i dispari..
però non capisco il nesso con l'indice... devo controllare solo gli indici pari nel primo if e quelli dispari nel secondo?! Sarebbe un discorso di efficienza?
mistergks è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
Nutanix accelera la migrazione da VMware...
Nutanix apre ai neocloud: piattaforma mu...
Nutanix amplia la piattaforma cloud e st...
Le fotografie dell'eclissi solare e dell...
Oracle AI Database si potenzia con nuove...
Russia offline: blackout internet mobile...
Gemini, Google investe 30 milioni per la...
Roborock Qrevo Edge S5A: 17.000 Pa, acqu...
Resa pubblica la foto della ''Terra che ...
Il robot che ha piegato 200 scatole di f...
SteelSeries Aerox 3 Wireless Gen 2: nuov...
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
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: 01:53.


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