Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-05-2007, 22:24   #1
zergling
Senior Member
 
L'Avatar di zergling
 
Iscritto dal: Oct 2003
Città: Chicago, IL
Messaggi: 504
Calcolatrice

Ciao a tutti,
Inanzitutto vorrei precisare che sono un nubbio e che sono ancora alle prime armi .
Detto cio, passiamo al codice sorgente:

#include <cstdlib>
#include <iostream>

using namespace std;

int main(int argc, char *argv[])
{
int num1, num2, add, sub, div, mol;
cout << "Please give me two integers numbers\n";
cout << "for example 2+5 or 78-4 etc.\n\n";
cin >> num1 >> num2;

if ( '+' )
{
add = num1 + num2;
cout << "= " << add << endl;
cout << endl;
system("PAUSE");
return EXIT_SUCCESS;
}

if ( '-' )
{
sub = num1 - num2;
cout << "= " << sub << endl;
cout << endl;
system("PAUSE");
return EXIT_SUCCESS;
}

if ( '/' )
{
div = num1 / num2;
cout << "= " << div << endl;
cout << endl;
system("PAUSE");
return EXIT_SUCCESS;
}

if ( '*' )
{
mol = num1 * num2;
cout << "= " << mol << endl;
cout << endl;
system("PAUSE");
return EXIT_SUCCESS;
}



system("PAUSE");
return EXIT_SUCCESS;
}

Funziona tutto correttamente a parte la divisione e la moltiplicazione

Dove ho sbagliato?
Ciao e grazie

Ultima modifica di zergling : 11-05-2007 alle 22:27.
zergling è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2007, 22:42   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Sicuro che funzionare tutto correttamente? Io ne dubito guardando il codice.

Non può funzionare, sbagli già quando fai if('+'), che sarà sicurmemte sempre vera essendo '+' un valore diverso da zero e non nullo.
In più come fai ad essere sicuro che num1 e num2 sono numeri? hai controllato che non prenda anche gli operatori?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2007, 23:02   #3
zergling
Senior Member
 
L'Avatar di zergling
 
Iscritto dal: Oct 2003
Città: Chicago, IL
Messaggi: 504
Si, se provi a compilare il file, vedrai che "+ e - " funzionano correttamente.
zergling è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 00:18   #4
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
... funzionano per puro caso.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 09:24   #5
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Rivediti bene come funziona la condizione "if".
Inoltre ci devi spiegare dove leggi l'operatore.

@memon

c++ converte automaticamente il tipo di dato con l'operatore di estrazione >> in base al tipo a destra (non è come il C, essendo più type strict di C ti lascia meno libertà - e fa lui...), ovviamente quando ci riesce.
Infatti, con un minimo di eleganza, io farei così:

Codice:
int operands[2];

...

for (unsigned char i = 0; i < 2; i++)
{
   if ((cin >> operands[i] >> dec).fail())
   {
      cerr << "Operando " << (i + 1) << " non valido." << endl;
      exit(1);
   }
}
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 11:52   #6
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
mmm, ho provato a compilarlo... un esempio 5-7 , stampando num2 infatti non è un numero ma è una stringa formata da "-7", quindi con quel codice non era sicuro che num1 e num2 siano numero. CVD
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 12:28   #7
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Quote:
Originariamente inviato da MEMon Guarda i messaggi
mmm, ho provato a compilarlo... un esempio 5-7 , stampando num2 infatti non è un numero ma è una stringa formata da "-7", quindi con quel codice non era sicuro che num1 e num2 siano numero. CVD
non proprio

Prova questo codice:

Codice:
#include <iostream>

using namespace std;

int main()
{
   int operands[2];

   cout << "Inserisci 2 numeri interi: ";
   for (unsigned char i = 0; i < 2; i++)
   {
      if ((cin >> operands[i] >> dec).fail())
      {
         cerr << "Operando " << (i + 1) << " non valido." << endl;
         exit(1);
      }
   }
   cout << "Numeri: " << operands[0] << " " << operands[1] << endl;
   return 0;
}
e prova ad inserire ad esempio "5-7".
come vedi, >> converte bene. Ecco perche a lui funziona la sottrazione e la somma.
>> converte in due interi, uno positivo ed uno negativo. Nel suo programma, entra nel primo if (per forza, visto che la condizione che ha specificato è sempre vera) e fa una somma tra un numero positivo ed uno negativo (quindi una sottrazione) e va. Idem se i due numeri sono entrambi positivi, o entrambi negativi. Tra l'altro, gli altri 3 'if' neanche li vede, entra sempre nel primo e fa la somma tra i due numeri convertiti dall'operatore di estrazione >>.
Ovviamente la divisione e il prodotto non vanno, perchè le condizioni che ha specificato sono errate alla radice (il primo if lo prende sempre, quindi è sono "un caso" se funziona).
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson

Ultima modifica di -fidel- : 12-05-2007 alle 12:37.
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 12:30   #8
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Si hai ragione lo converte in un numero negativo
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 18:43   #9
zergling
Senior Member
 
L'Avatar di zergling
 
Iscritto dal: Oct 2003
Città: Chicago, IL
Messaggi: 504
Hmmm, quindi come dovrebbe essere il codice?
Io per adesso ho soltanto visto IF...
zergling è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 19:03   #10
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Quote:
Originariamente inviato da zergling Guarda i messaggi
Hmmm, quindi come dovrebbe essere il codice?
Io per adesso ho soltanto visto IF...
Se non ti offendi, cambio il nome delle variabili e rendo il tutto più compatto
Seguo comunque la sintassi di input da te definita prima, ma aggiungo un minimo controllo dell'input.

Codice:
#include <iostream>
 
using namespace std;
 
int main(int argc, char *argv[])
{
	int op1, op2;
	char operation;

	cout << "Inserisci due numeri interi" << endl;
	cout << "ad esempio 2+5 o 78-4 etc." << endl << endl;
	if ((cin >> op1 >> dec).fail())
	{
		cerr << "Primo operando non valido." << endl;
		system("PAUSE"); // Ok stai usando Windows... ;)
		exit(1);
	}
	cin >> operation;
	if ((cin >> op2 >> dec).fail())
	{
		cerr << "Secondo operando non valido." << endl;
		system("PAUSE");
		exit(1);
	}
 
	switch(operation)
	{
		case '+':
			cout << "= " << (op1 + op2) << endl;
			break;
		case '-':
			cout << "= " << (op1 - op2) << endl;
			break;
		case '*':
			cout << "= " << (op1 * op2) << endl;
			break;
		case '/':
			cout << "= " << (op1 / op2) << endl;
			break;
		default:
			cout << "Operazione non valida." << endl;
	}
 	system("PAUSE");
	return EXIT_SUCCESS; // anche return 0 va bene.
}
EDIT: in fase di test, prova anche a dargli input "particolari", tipo -5--8, oppure a separare con degli spazi, tipo 20 / 4
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson

Ultima modifica di -fidel- : 12-05-2007 alle 19:11.
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 12-05-2007, 19:14   #11
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Scusami non avevo visto che finora hai studiato solo 'if'. Ok, riposto il programma usando if:

Codice:
#include <iostream>
 
using namespace std;
 
int main(int argc, char *argv[])
{
	int op1, op2;
	char operation;

	cout << "Inserisci due numeri interi" << endl;
	cout << "ad esempio 2+5 o 78-4 etc." << endl << endl;
	if ((cin >> op1 >> dec).fail())
	{
		cerr << "Primo operando non valido." << endl;
		system("PAUSE"); // Ok stai usando Windows... ;)
		exit(1);
	}
	cin >> operation;
	if ((cin >> op2 >> dec).fail())
	{
		cerr << "Secondo operando non valido." << endl;
		system("PAUSE");
		exit(1);
	}
 
	if (operation == '+')
		cout << "= " << (op1 + op2) << endl;
	else if (operation == '-')
		cout << "= " << (op1 - op2) << endl;
	else if (operation == '*')
		cout << "= " << (op1 * op2) << endl;
	else if (operation == '/')
		cout << "= " << (op1 / op2) << endl;
	else
		cout << "Operazione non valida." << endl;

 	system("PAUSE");
	return EXIT_SUCCESS; // anche return 0 va bene.
}
Nota che quando un blocco 'if' contiene una sola riga di codice, puoi omettere le parentesi graffe.
Certo, nessuno ti vieta di fare:

Codice:
	if (operation == '+')
	{
		cout << "= " << (op1 + op2) << endl;
	}
	else if (operation == '-')
	{
		cout << "= " << (op1 - op2) << endl;
	}
	else if ...
ma secondo me è meno leggibile, perchè rende il sorgente inutilmente più lungo (poi personalmente cose del tipo:
if (condizione) {
una sola riga di codice; }
non le sopporto
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson

Ultima modifica di -fidel- : 12-05-2007 alle 19:18.
-fidel- è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2007, 20:10   #12
zergling
Senior Member
 
L'Avatar di zergling
 
Iscritto dal: Oct 2003
Città: Chicago, IL
Messaggi: 504
Ciao -Fidel-
Finalemnte grazie al vostro aiuto e consigli ho finalmente capito dove sbagliavo.
Ho fatto un mischione tra IF e Case perche ho visto nel penultimo esempio di -Fidel- che il mio codice sorgente e' veramente simile al "Case".

Avrei bisogno di un ultima delucidazione da parte tua -Fidel-.
Che cosa fa questa cosa ? dec).fail()

Ciao e grazie a tutti per il vostro aiuto
zergling è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2007, 20:37   #13
-fidel-
Senior Member
 
L'Avatar di -fidel-
 
Iscritto dal: Jan 2006
Messaggi: 2722
Quote:
Originariamente inviato da zergling Guarda i messaggi
Ciao -Fidel-
Finalemnte grazie al vostro aiuto e consigli ho finalmente capito dove sbagliavo.
Ho fatto un mischione tra IF e Case perche ho visto nel penultimo esempio di -Fidel- che il mio codice sorgente e' veramente simile al "Case".

Avrei bisogno di un ultima delucidazione da parte tua -Fidel-.
Che cosa fa questa cosa ? dec).fail()

Ciao e grazie a tutti per il vostro aiuto
Semplice: con "dec" dico a c++ di trattare la variabile come un valore numerico (qualunque esso sia: intero, non intero (float), negatico, ecc). Quindi con:

cin >> op1 >> dec

dico a c++ di prendere da tastiera il primo valore che incontra, metterlo in op1 e trattarlo (forzarlo) come un numero decimale (in base 10), del tipo definito dalla variabile che conterrà il valore (int, float, double, ecc.) . Come puoi immaginare, non è assolutamente detto che questa operazione vada a buon fine (magari ho inserito delle lettere invece che dei numeri, oppure ho inserito un numero tipo 10,4 ma op1 è di tipo "int" e non "float", ecc.). Nel caso l'operazione non vada a buon fine, l'operatore >> setta un bit di errore interno, chiamato failbit: controllando quindi il valore di questo bit, si può sapere se l'operazione è andata a buon fine oppure no: è come un valore di ritorno dell'operatore >>. Per controllare se il failbit è stato settato (quindi c'è stato un errore) uso il metodo "fail()" dello stream: se esso ritorna "true" significa che il failbit è stato settato (è a 1) e quindi c'è stato un errore, di conseguenza entro nell'if, dove segnalo l'errore ed esco.

In pratica, con una riga di codice, ho fatto un controllo dei dati presi da tastiera

Se vuoi saperne di più su "dec" dai un'occhiata qui (vedrai che non esiste solo dec ):

http://www.cplusplus.com/reference/i...ators/dec.html
__________________

- Spesso gli errori sono solo i passi intermedi che portano al fallimento totale.
- A volte penso che la prova piu' sicura che esiste da qualche parte una forma di vita intelligente e' il fatto che non ha mai tentato di mettersi in contatto con noi. -- Bill Watterson
-fidel- è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
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...
The Grand Tour 2026: ecco chi saranno i ...
SSD NVMe M.2 e Pentium III insieme? Si.....
Un altro iPhone economico è in arrivo a ...
Svolta Polestar per la ricarica: Plug&am...
Windows 11, cali di prestazioni sulle GP...
QNAP lancia myQNAPcloud One: l'archiviaz...
Clamoroso in Formula 1: FIA pronta a cam...
iPhone 18 Pro Max con batteria da oltre ...
L'UE dà ragione ad Apple: Maps e ...
Droni accecati e comunicazioni isolate: ...
Accesso alla memoria su Windows 11 solo ...
Regali di San Valentino: 15 idee tech sf...
Stellantis a picco in Borsa: 22 miliardi...
Baldur's Gate 3 diventa una serie TV: pr...
Intel riapre la sfida con Steam Deck: Pa...
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: 14:06.


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