Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-10-2007, 11:07   #1
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
[C++] Elemento massimo di un vettore ricorsivamente

Non capisco perchè non funziona questo programma che calcola ricorsivamente il massimo elemento di un vettore

Codice HTML:
#include <iostream>

using namespace std;

int massimo(int v[], int n, int& max){
    if(n>0){
            if(v[n-1]>max){
                           max=v[n-1];
                           return massimo(v,n,max);}
                           else return massimo(v,n,max);}
                           else return max;}
    
main(){
       
       int max=0;
       int i;
       cin >>i;
       int* v = new int v[i];
       
       for(int j=0;j<i;j++){
               cin >> v[i];}
               
               cout << massimo(v, i);
               
               system ("pause");}
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 11:23   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
Codice HTML:
#include <iostream>

using namespace std;

int massimo(int v[], int n, int& max){
    if(n>0){
            if(v[n-1]>max){
                           max=v[n-1];
                           return massimo(v,n,max);}
                           else return massimo(v,n,max);}
                           else return max;}
    
main(){
       
       int max=0;
       int i;
       cin >>i;
       int* v = new int v[i];
       
       for(int j=0;j<i;j++){
               cin >> v[i];}
               
               cout << massimo(v, i);
               
               system ("pause");}
A parte l'errore nella riga
Codice:
cout << massimo(v, i);
che dovrebbe essere
Codice:
cout << massimo(v, i, max);
nella funzione ricorsiva passi sempre il valore di n, mai n-1. Oltretutto mi sembra inutile fare:
Codice:
if(v[n-1]>max){
 ...
return massimo(v,n,max);}
else
return massimo(v,n,max);}
Secondo me volendo seguire la tua traccia dovresti fare
Codice:
int massimo(int v[], int n, int& max)
{
    if(n>0)
    {
         if(v[n-1]>max)
             max=v[n-1];
         return massimo(v,n-1,max);
    }
    return max;
}
[EDIT] Non avevo letto il ricorsivamente nel titolo, la parte sotto può essere ignorata

Usando un pò di C++ per trovare il massimo di un vettore io farei così:

Codice:
#include <algorithm>
#include <vector>
#include <iostream>

	class MaxVector
	{
	public:
		MaxVector() : max(0xFFFFFFFF) {}
		void operator() (int value)
		{
                      if (value>max) 
                           max = value;
		}
		int GetMax() { return max; }
	private:
		int max;
	};

...
vector<int> v;
...
int val = 0;
cin >> val;
v.push_back(val);
...
MaxVector v = for_each(v.begin(), v.end(), MaxVector());
int max = v.GetMax();
...

Ultima modifica di tomminno : 12-10-2007 alle 11:36.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 11:36   #3
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
Codice HTML:
#include <iostream>

using namespace std;

int massimo(int v[], int n, int& max)
{
    if(n>0)
    {
         if(v[n-1]>max)
             max=v[n-1];
         return massimo(v,n-1,max);
    }
    return max;
}
    
main(){
       
       int max=0;
       int i;
       cin >>i;
       int* v = new int v[i];
       
       for(int j=0;j<i;j++){
               cin >> v[i];}
               
               cout << massimo(v, i, max);
               
               system ("pause");}

Non funziona lo stesso, mi da errore su questa riga int* v = new int v[i];21 expected `,' or `;' before "v"



comq le classi ancora non le ho fatte
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:10   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
xubbax: di nuovo con questa indentazione ?
Ti invito ad usare una indentazione standard quando posti problemi in questa sezione. Lo capisci che così facendo costringi chi legge il tuo codice a copiarlo, metterlo in un editor e applicare l'indentazione prima di risponderti ?
Fallo almeno come forma di rispetto per chi legge il tuo codice.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:11   #5
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
guarda che non lo faccio mica apposta.. sono abituato cosi
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:12   #6
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
E sei abituato male
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:18   #7
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
e lo so, ma mica posso aspettare di identare benissimo per scrivere una cosa sul forum
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:21   #8
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Per quelle 4 righe potevi fare lo sforzo
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:22   #9
xbubbax
Senior Member
 
Iscritto dal: Apr 2007
Messaggi: 381
ma per me quello è identato benissimo, non capisco cosa c'è che non va, per me è leggibilissimo
xbubbax è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:30   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
guarda che non lo faccio mica apposta.. sono abituato cosi
Disabituati...cambia le tue abitudini. In queste cose essere originali è solo dannoso. Inoltre se un giorno farai un progetto in C++ in collaborazione con altre persone sarai comunque costretto a cambiare le tue abitudini.

Almeno prima di postare il codice qui passalo da un indentatore automatico
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:38   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Cosa c'è che non va nel tuo modo di indentare ormai te l'ho già detto diverse volte.

Ad ogni modo per calcolare il max in maniera ricorsiva farei così:
Codice:
int getMax(int v[],int n){if(n>1){int prevMax=getMax(v,n-1);return (prevMax>v[n-1])?prevMax:v[n-1];}return v[0];}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 12:40   #12
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Non ci indurre in indentazione amen
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 13:05   #13
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da xbubbax Guarda i messaggi
[html]
Non funziona lo stesso, mi da errore su questa riga int* v = new int v[i];21 expected `,' or `;' before "v"

comq le classi ancora non le ho fatte
Mi era sfuggito:
Codice:
int * v = new int[i];
già che ci sei, per buona abitudine, io metterei anche una delete prima dell'uscita dal main.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2007, 15:46   #14
_Claudio
Senior Member
 
L'Avatar di _Claudio
 
Iscritto dal: Aug 2005
Messaggi: 579
Spero bene che il problema sia un problema didattico...
Perchè risolvere un problema di complessità n con la ricorsione è come usare un transatlantico per attraversare un fiume...
_Claudio è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2007, 10:57   #15
Furla
Senior Member
 
Iscritto dal: Feb 2004
Messaggi: 1454
Codice:
int max(int* v, int n)
{
 if (n==1) return *v;
 return *v>(n=max(v+1,n-1))?*v:n;
}
impara ad indentare, nel main l'indice del ciclo è j.

Ultima modifica di Furla : 13-10-2007 alle 11:00.
Furla è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Samsung Galaxy A07 5G: il nuovo entry le...
Realme 16 in arrivo: un mix tra iPhone A...
Domenica di follia su Amazon: iPhone 17 ...
Questo portatile HP OMEN con Core Ultra ...
Robot aspirapolvere al prezzo giusto: le...
Il nuovo M5 Max potrebbe avere una GPU p...
Pulizie automatiche al top (e a prezzo B...
Casa più calda, spese più leggere: Tado ...
Mini PC mostruoso in offerta nascosta su...
Netflix promette 45 giorni di esclusivit...
Gigabyte: un handheld? Sì, ma sol...
Samsung conferma l'arrivo di tre variant...
Sottile, veloce e con un'ottima autonomi...
Il top di gamma compatto di OnePlus &egr...
Modificare l'indirizzo Gmail è finalment...
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: 12:24.


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