Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-10-2008, 19:27   #1
rnuzzo
Senior Member
 
L'Avatar di rnuzzo
 
Iscritto dal: Nov 2005
Città: Cavallino (LE)
Messaggi: 335
[C++]Parere sul listato

Eccomi di nuovo per un vostro parere .Questo è un programma che verifica se un numero di 5 cifre sia palindromo o meno:
Codice:
#include<iostream>
using std::cout;
using std::cin;
using std::endl;

int main()
{
	int a = 0;
	int n1 = 0;
	int n2 = 0;
	int n3 = 0;
	int n4 = 0;
	int n5 = 0;


	cout << "Inserire un numero a 5 cifre (-1 per uscire):  ";
	 cin >> a;

	while (a != -1)
	{
		if (a > 99999)
		{
			cout << "\nIL NUMERO SUPERA LE 5 CIFRE\n"<< endl;
		}
		else
		{
			n1 = ( a / 10000);
			n2 = ( a % 10000) / 1000;
			n3 = ( a % 1000) / 100;
			n4 = ( a % 100) / 10;
			n5 = ( a % 10);
		}
		
		if (n1 == n5)
		{
			if (n2 == n4)
				cout << "\nIl numero e' palindromo\n" << endl;
			else
				cout << "\nIl numero non  e' palindromo\n" << endl;
		}
		else 
			cout << "\nIl numero non  e' palindromo\n" << endl;

		

        cout << "Inserire un numero a 5 cifre (-1 per uscire):  ";
		cin >> a;
	}
	system("PAUSE");
	return 0;
}
Usando solo gli if - if else c'e un modo per scrivere una sola volta "Il numero non è palindromo"?

Non mi dispiacerebbe nemmeno un giudizio sul listato... .Grazie
rnuzzo è offline   Rispondi citando il messaggio o parte di esso
Old 10-10-2008, 19:50   #2
17Qwerty71
Senior Member
 
Iscritto dal: Jul 2005
Città: San Marino
Messaggi: 309
Eviterei anche di ripetere le stesse istruzioni più volte
Ho anche sistemato la parte per quanto riguarda il numero maggiore di 99999, nel tuo caso il programma ti stampava che il numero era sempre palindromo se maggiore di 99999, questo perché n1 n2 n3 n4 n5 erano inizializzati tutti a 0 e con numero maggiore di 5 cifre il controllo di n1 n2 n3 n4 n5 veniva svolto uguale

Codice PHP:
#include<iostream>
using std::cout;
using std::cin;
using std::endl;

int main()
{
    
bool exit = false;
    
int a 0;
    
int n1 0;
    
int n2 0;
    
int n3 0;
    
int n4 0;
    
int n5 0;



    while (!exit)
    {
        
cout << "Inserire un numero a 5 cifre (-1 per uscire):  ";
        
cin >> a;

        if (
99999)
        {
            
cout << "\nIL NUMERO SUPERA LE 5 CIFRE\n"<< endl;
        }
        else
        {
            if(
== -1)
                exit = 
true;
            else
            {
                
n1 = ( 10000);
                
n2 = ( 10000) / 1000;
                
n3 = ( 1000) / 100;
                
n4 = ( 100) / 10;
                
n5 = ( 10);

                if (
n1 == n5 && n2 == n4)
                    
cout << "\nIl numero e' palindromo\n" << endl;
                else
                    
cout << "\nIl numero non  e' palindromo\n" << endl;
            }
        }
        
    }
    
system("PAUSE");
    return 
0;

__________________
17Qwerty71 è offline   Rispondi citando il messaggio o parte di esso
Old 10-10-2008, 19:53   #3
rnuzzo
Senior Member
 
L'Avatar di rnuzzo
 
Iscritto dal: Nov 2005
Città: Cavallino (LE)
Messaggi: 335
Possibilmente senza operatori logici
rnuzzo è offline   Rispondi citando il messaggio o parte di esso
Old 10-10-2008, 20:21   #4
rnuzzo
Senior Member
 
L'Avatar di rnuzzo
 
Iscritto dal: Nov 2005
Città: Cavallino (LE)
Messaggi: 335
Sto studiando il libro della deitel c++ fondamenti di programmazione 2 ed.
Perciò devo seguirne " le lezioni " .Comunque grazie a tutti
rnuzzo è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2008, 12:25   #5
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Non era meglio una stringa controllata tramite for?
Oltre ad essere più elastico sarebbe anche più facile da fare. Oltre che terribilmente più corto.

Codice:
while( true )
{
     cout << "inserisci un numero/parola qualsiasi - exit per uscire." << endl;

     std::string n;
     cin >> n;

     if( n == "exit" )     break;


     bool palindromo = true;
     size_t length = n.length();

     for(unsigned int i = 0; i < (int)length/2; ++i)
     {
           if( n[i] != n[ length - i - 1 ] )
           {
                 palindromo = false;
            break;
           }
     }

     cout << "La stringa immessa" << (palindromo ? " non" : " ")  << " e' palindroma!" << endl;

}
Dovrebbe funzionare

OT E' tanto brutto while(true)? Lo uso spesso ma non l'ho visto da nessun'altra parte. /OT
__________________
*ToMmO*

devlog | twitter

Ultima modifica di Tommo : 12-10-2008 alle 12:28.
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 12-10-2008, 18:06   #6
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
io francamente "while(true)" in C non l'ho mai visto e mi sa tanto che mai lo vedrò
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 13-10-2008, 11:19   #7
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Bhe, io lo uso perchè trovo comodo non dover assegnare una varabile solo al while; per esempio, se avessi dovuto modificare n, sarei dovuto stare attento a ricreare alla fine un valore sensato per il prossimo controllo.

Invece così esco quando mi aggrada... però ammetto che così è difficile capire qual'è la condizione di uscita...
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Microsoft aggiunge i modelli Claude di A...
iPhone 16e all'incredibile prezzo di 499...
OpenAI - NVIDIA, tra investimenti e GPU ...
Un androide dal volto umano e in grado d...
Amazfit Balance 2 XT arriva in Italia: p...
Realme spoilera il nuovo GT 8 Pro: svela...
La Cina sorprende tutti: annunciato il p...
Samsung Galaxy S26 Ultra: la ricarica sa...
Disagi al traffico aereo europeo: le ind...
Intel in crisi chiama Apple: un riavvici...
Snapdragon X2 Elite Extreme, il cuore de...
Snapdragon 8 Elite Gen 5 è il nuovo rife...
Bombe Apple su Amazon: iPhone di scorsa ...
Micron: memoria HBM4 a 11 Gbps e patto d...
NVIDIA rende Audio2Face open source: ecc...
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: 07:54.


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