Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-04-2011, 21:16   #1
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
[C++] spiegazione di un errore di un eserzicio

salve io ho fatto un programma in C++...
ho trovato un problema quando vado a rikiamare la funzione visualizza_n_auto.
ora mi spiego. quando immeto i dati delle auto e poi metto il numero di auto da visualizzare, la visualizzazione me la fa ma escono caratteri strani.. mi aiutate?

#include<iostream>
using namespace std;
#include<string.h>
#define Max 20

class automobile{
char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;
public:
void registra(char codic[],char model[],char tip[],float km){
strcpy(codice,codic);
strcpy(modello,model);
strcpy(tipo,tip);
km_percorsi=km;
return;}

void visualizza(){
cout<<codice;
cout<<modello;
cout<<tipo;
cout<<km_percorsi;
return;}
friend void ricerca_auto(int i);
friend void media_km(int i);
};

automobile autom[Max];

int inserisci(){
int risposta,i=-1;
char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;
do{
i++;
cout<<"inserisci il codice dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il modello dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il tipo dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci i km percorsi dell'automobile "<<i+1<<endl;
cin>>codice;
autom[i].registra(codice,modello,tipo,km_percorsi);
cout<<"vuoi inserire un altro studente? (0=SI 1=NO)"<<endl;
cin>>risposta;
}while(risposta==0);
return i;}

void visualizza_n_auto(){
int n_auto,k;
cout<<"Dammi il numero di auto da visualizzare:"<<endl;
cin>>n_auto;
for(k=0;k<=n_auto;k++){
autom[k].visualizza();}
return;}

void ricerca_auto(int i){
char codiceauto[Max];
int k;
cout<<"dammi il codice dell'automobile:"<<endl;
cin>>codiceauto;
for(k=0;k<=i;k++){
if(strcmp(autom[k].codice,codiceauto)==0){
autom[k].visualizza();}
else cout<<"Il codice dell'automobile non esiste"<<endl;}
return;}

void media_km(int i){
int k;
float s,R;
for(k=0;k<i;k++){
s+=autom[k].km_percorsi;
}
R=s/i;
return;}

main(){
int dim;
dim=inserisci();
visualizza_n_auto();
ricerca_auto(dim);
media_km(dim);
system("PAUSE");
return 0;
}
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2011, 22:49   #2
simo33
Junior Member
 
Iscritto dal: Apr 2011
Messaggi: 25
Al momento non posso testare il codice con un compilatore quindi non sono sicuro, ma credo che il problema sia nella funzione inserisci.

Codice:
int inserisci(){
int risposta,i=-1;

char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;

do{
i++;
cout<<"inserisci il codice dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il modello dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il tipo dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci i km percorsi dell'automobile "<<i+1<<endl;
cin>>codice;
autom[i].registra(codice,modello,tipo,km_percorsi);
cout<<"vuoi inserire un altro studente? (0=SI 1=NO)"<<endl;
cin>>risposta;
}while(risposta==0);
return i;}
dal tuo codice quando chiede le variabili le salva tutte con cin nel char[] "codice", quindi "codice" dovrebbe essere l'unica variabile inizializzata alla creazione della classe "automobile". Dunque essendo l'unico valore inizializzato gli altri, ovverosia "modello", "tipo" e "km_percorsi" diventano valori precedenti dallo stack o acquistano un valore di default dal compilatore.
simo33 è offline   Rispondi citando il messaggio o parte di esso
Old 30-04-2011, 22:53   #3
simo33
Junior Member
 
Iscritto dal: Apr 2011
Messaggi: 25
Ok, sono riuscito a testare il sorgente, il problema era proprio quello. Continuavi a inizializzare la variabile codice che quindi alla fine prendeva il valore che sarebbe dovuto essere di km_percorsi lasciando tutto il resto non inizializzato.
Ora dovrebbe essere a posto:

Codice:
int inserisci(){
int risposta,i=-1;
char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;
do{
i++;
cout<<"inserisci il codice dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il modello dell'automobile "<<i+1<<endl;
cin>>modello;
cout<<"inserisci il tipo dell'automobile "<<i+1<<endl;
cin>>tipo;
cout<<"inserisci i km percorsi dell'automobile "<<i+1<<endl;
cin>>km_percorsi;
autom[i].registra(codice,modello,tipo,km_percorsi);
cout<<"vuoi inserire un altro studente? (0=SI 1=NO)"<<endl;
cin>>risposta;
}while(risposta==0);
return i;}
Già che ci sei aggiungi un <<endl alla funzione "visualizza_n_auto"

Codice:
void visualizza_n_auto(){
int n_auto,k;
cout<<"Dammi il numero di auto da visualizzare:"<<endl;
cin>>n_auto;
for(k=0;k<=n_auto;k++){
autom[k].visualizza();
cout<<endl;}
return;}
simo33 è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2011, 00:01   #4
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
grazie... cmq ora probo e vi faccio sapere.
ke errore di distrazione scrivere 2 volte codice...
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2011, 13:21   #5
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
raga lho modificato, ma da un errore: qui
cout<<"Dammi il numero di auto da visualizzare:"<<endl;
cin>>n_auto;

io ce lo dò ma nella visualizzazione mi fa visualizzare tutte le auto... perke?
ecco il codice:
#include<iostream>
using namespace std;
#include<string.h>
#define Max 20

class automobile{
char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;
public:
void registra(char codic[],char model[],char tip[],float km){
strcpy(codice,codic);
strcpy(modello,model);
strcpy(tipo,tip);
km_percorsi=km;
return;}

void visualizza(){
cout<<codice;
cout<<modello;
cout<<tipo;
cout<<km_percorsi;
return;}
friend void ricerca_auto(int i);
friend void media_km(int i);
};

automobile autom[Max];

int inserisci(){
int risposta,i=-1;
char codice[Max];
char modello[Max];
char tipo[Max];
float km_percorsi;
do{
i++;
cout<<"inserisci il codice dell'automobile "<<i+1<<endl;
cin>>codice;
cout<<"inserisci il modello dell'automobile "<<i+1<<endl;
cin>>modello;
cout<<"inserisci il tipo dell'automobile "<<i+1<<endl;
cin>>tipo;
cout<<"inserisci i km percorsi dell'automobile "<<i+1<<endl;
cin>>km_percorsi;
autom[i].registra(codice,modello,tipo,km_percorsi);
cout<<"vuoi inserire un'altra automobile? (0=SI 1=NO)"<<endl;
cin>>risposta;
}while(risposta==0);
return i;}

void visualizza_n_auto(){
int n_auto,k;
cout<<"Dammi il numero di auto da visualizzare:"<<endl;
cin>>n_auto;
for(k=0;k<=n_auto;k++){
autom[k].visualizza();}
cout<<endl;
return;}

void ricerca_auto(int i){
char codiceauto[Max];
int k;
cout<<"dammi il codice dell'automobile:"<<endl;
cin>>codiceauto;
for(k=0;k<=i;k++){
if(strcmp(autom[k].codice,codiceauto)==0){
autom[k].visualizza();}
else cout<<"Il codice dell'automobile non esiste"<<endl;}
return;}

void media_km(int i){
int k;
float s,R;
for(k=0;k<i;k++){
s+=autom[k].km_percorsi;
}
R=s/i;
return;}

main(){
int dim;
dim=inserisci();
visualizza_n_auto();
ricerca_auto(dim);
media_km(dim);
system("PAUSE");
return 0;
}
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2011, 15:41   #6
simo33
Junior Member
 
Iscritto dal: Apr 2011
Messaggi: 25
Al momento non ho compilatore e debugger sotto mano, però la funzione "visualizza_n_auto" è proprio brutta. Perchè metti i comandi console dentro alla funzione? Puoi farlo benissimo fuori, risulta più corretto sintatticamente e logicamente una cosa del genere.
Codice:
void visualizza_n_auto(int n_auto){
for(int k=0;k<=n_auto;k++){
autom[k].visualizza();}
cout<<endl;
return;}
E la domanda la fai nel main
Codice:
int n=0;
cout<<"Quante auto vuoi visualizzare? ";
cin>>n;
visualizza_n_auto(n);
Una funzione non dovrebbe chiedere all'user, dovrebbe solo eseguire, se possibile. Prova così, altrimenti vedrò di utilizzare un debugger per aiutarti meglio.
simo33 è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2011, 12:49   #7
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
simo ho riscontrado 2 problemi..
la funzione fa lo stesso errore ke mi stampa tutte le automobili, e poi la funzione di ricerca del codice macchina non funge e non so perke...
------------------------------
se percaso ti serve un compilatore usa Bloodsheed C++
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2011, 18:38   #8
simo33
Junior Member
 
Iscritto dal: Apr 2011
Messaggi: 25
Allora: visualizza_n_auto non funzionava perchè avevi messo come condizione nel for "k<=n_auto" invece avresti dovuto mettere "k<n_auto".
Questo perchè se tu dici alla funzione che vuoi visualizzare 2 auto, lei la legge come: devo visualizzare le auto fino a quando k non è unguale a 2, allora visualizzo auto[0],auto[1] e auto[2].
Praticamente visualizzava un auto in più di quelle che gli chiedevi.

Per la ricerca c'è sempre il problema della k, ma soprattutto il problema è un'altro:
Lui controlla ogni in ogni auto se corrisponde il codice e se non corrisponde scrive che il codice non esiste.
Il problema è di tipo logico, ovvero ora ti spiego meglio.
Tu vuoi fare in modo che lui prima cerchi e se trova l'auto la mette, se nessuna delle auto ha il codice inserito, allora il programma deve dire che l'auto non esiste.
Il problema è che la tua funzione dice questo:
auto[0] -> c'è il codice? NO -> scrivo che non esiste
auto[1] -> c'è il codice? NO -> scrivo che non esiste
auto[2] -> -> c'è il codice? SI -> allora scrivo che esiste.
Il problema è che prima di dire che esiste dice due volte che non esiste.

Io ho risolto il questo modo, ma ce ne possono essere molti altri:

Codice:
void ricerca_auto(int i)
{
	char codiceauto[Max];
	int k;
	bool trovato=false;
	cout<<"dammi il codice dell'automobile:"<<endl;
	cin>>codiceauto;

	for(k=0; k<i; k++)
	{
		if(strcmp(autom[k].codice,codiceauto)==0) 
		{
			autom[k].visualizza();
			trovato=true;
		}
		if(!trovato) cout<<"Codice non trovato.\n";
	}
	return;
}
Non capisco la funzione media_km, non restituisce nessun valore e anche se eseguita calcola la media, però se la tiene per sè.

C'erano un po' di cose nella visualizzazione che non mi piacevano, quindi le ho rifatte, ti posto il codice.

Codice:
#include<iostream>
using namespace std;
#include<string.h>
#define Max 20


class automobile
{
	char codice[Max];
	char modello[Max];
	char tipo[Max];
	float km_percorsi;
	public:
	void registra(char codic[],char model[],char tip[],float km)
	{
		strcpy(codice,codic);
		strcpy(modello,model);
		strcpy(tipo,tip);
		km_percorsi=km;
		return;
	}

	void visualizza()
	{
		cout<<"|CODICE\t\t|MODELLO\t|TIPO\t\t|KM PERCORSI\n";
		cout<<"|"<<codice<<"\t\t|"<<modello<<"\t\t|"<<tipo<<"\t\t|"<<km_percorsi<<"\n\n";
		return;
	}
friend void ricerca_auto(int i);
friend float media_km(int i);
};

automobile autom[Max];

int inserisci()
{
	int risposta,i=-1;
	char codice[Max];
	char modello[Max];
	char tipo[Max];
	float km_percorsi;
	do{
		i++;
		cout<<"Inserire il CODICE dell'automobile: "<<i+1<<endl;
		cin>>codice;
		cout<<"Inserire il MODELLO dell'automobile: "<<i+1<<endl;
		cin>>modello;
		cout<<"Inserire il TIPO dell'automobile: "<<i+1<<endl;
		cin>>tipo;
		cout<<"Inserire i KM PERCORSI dell'automobile: "<<i+1<<endl;
		cin>>km_percorsi;
		autom[i].registra(codice,modello,tipo,km_percorsi);
		cout<<"Vuoi inserire un'altra automobile? (0=SI 1=NO)"<<endl;
		cin>>risposta;
	} while(risposta==0);
	return i;
}

void visualizza_n_auto(int n_auto)
{
	for(int k=0;k<n_auto;k++){
	autom[k].visualizza();}
	cout<<endl;
	return;
}



void ricerca_auto(int i)
{
	char codiceauto[Max];
	int k;
	bool trovato=false;
	cout<<"Inserire il codice dell'automobile: "<<endl;
	cin>>codiceauto;

	for(k=0; k<i; k++)
	{
		if(strcmp(autom[k].codice,codiceauto)==0) 
		{
			autom[k].visualizza();
			trovato=true;
		}
		if(!trovato) cout<<"Codice non trovato.\n";
	}
	return;
}


float media_km(int i)
{
	int k;
	float s=0;
	for(k=0;k<i;k++){
	s+=autom[k].km_percorsi;
	}
	return s/i;
}

int main()
{
	int dim;
	dim=inserisci();

	int n=0;
	cout<<"Quante auto vuoi visualizzare? ";
	cin>>n;
	visualizza_n_auto(n);

	ricerca_auto(dim);
	cout<<"Media KM PERCORSI: "<<media_km(dim)<<"\n";
	system("PAUSE");
	return 0;

}
Poi volendo si può modificare inserisci.

---------------------------
Grazie per il compilatore, uso Visual C++ con cui mi trovo molto meglio, solo che non lo avevo sotto mano.
simo33 è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2011, 21:06   #9
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
grazie... ma ce un ultimo errore..
cioè quando chiedi il codice da cercare lui te lo cerca e se ce mi scrive prima il codice non esiste e poi me lo stampa come mai?
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2011, 21:53   #10
simo33
Junior Member
 
Iscritto dal: Apr 2011
Messaggi: 25
Ops, colpa mia

L' if-statement va fuori dal try, era questo che cercavo di dirti, solo che poi ho sbagliato anche io

Codice:
void ricerca_auto(int i)
{
	char codiceauto[Max];
	int k;
	bool trovato=false;
	cout<<"Inserire il codice dell'automobile: "<<endl;
	cin>>codiceauto;

	for(k=0; k<i; k++)
	{
		if(strcmp(autom[k].codice,codiceauto)==0) 
		{
			autom[k].visualizza();
			trovato=true;
		}
	}
	if(!trovato) cout<<"Codice non trovato.\n";
	return;
}
simo33 è offline   Rispondi citando il messaggio o parte di esso
Old 04-05-2011, 21:09   #11
Sax_93
Member
 
Iscritto dal: Apr 2011
Messaggi: 62
GRAZIE 1000!!!!
ma per info ma tu sei uno grande o alunno?
Sax_93 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Scope elettriche low cost a prezzo strac...
G-ASD di Geely, primo ADAS cinese certif...
La serie TV di Assassin's Creed su Netfl...
Nothing Phone (4a) disponibile su Amazon...
NemoClaw è la soluzione di NVIDIA...
Abarth Grande Panda ibrida: lo Scorpione...
European Hardware Awards 2026: la data &...
NVIDIA, nel futuro c'è la GPU Fey...
Doom: The Dark Ages è il primo gr...
Robot aspirapolvere ECOVACS in offerta: ...
22.000Pa e si pulisce da solo per 75 gio...
Samsung prepara i nuovi Galaxy Tab S12: ...
Virtual C-Suite: gli agenti IA di Master...
WINDTRE alza i prezzi: nuova rimodulazio...
Resident Evil Requiem non si ferma pi&ug...
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:58.


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