Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque
Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque
Dal salotto al giardino, il nuovo proiettore laser di Hisense promette esperienze cinematografiche in qualsiasi contesto: qualità d’immagine, semplicità d’uso, versatilità e prezzo competitivo il suo poker d'assi
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe
La flessibilità di configurazione è il punto di forza di questo 2-in-1, che ripropone in un form factor alternativo tutta la tipica qualità dei prodotti Lenovo della famiglia ThinkPad. Qualità costruttiva ai vertici, ottima dotazione hardware ma costo che si presenta molto elevato.
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart
Mentre Ubisoft vorrebbe chiedere agli utenti, all'occorrenza, di distruggere perfino le copie fisiche dei propri giochi, il movimento Stop Killing Games si sta battendo per preservare quella che l'Unione Europea ha già riconosciuto come una forma d'arte. Abbiamo avuto modo di parlare con Daniel Ondruska, portavoce dell'Iniziativa Europa volta a preservare la conservazione dei videogiochi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-11-2007, 11:40   #1
norbertom
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 1075
c - concatenazione dei calcoli

evitatemi discorsi su questo codice, perché già qualcuno mi ha detto che si può realizzare in altri modi. Ma da quello che vedete sotto non posso sviare... è un esercizio del prof in cui biosogna convertire un numero decimale in binario. Sono riuscito a scriverlo da solo, il punto è che non riesco a capire in che modo vengono concatenati i dati durante il calcolo (dall'else in poi).
#include <stdio.h>
int main(void)
{
int dec;
int r1,r2,r3,r4,r5,r6,r7,r8;

printf("Immetti un valore decimale minore di 128 da convertire in binario\n");
scanf("%d",&dec);

if(dec>=128)
{
printf("ATTENZIONE:Il valore immesso e' troppo alto, immetterne uno minore di 128\n");
return 0;
}

else
{
r8=dec%2;
dec=dec/2;
r7=dec%2;
dec=dec/2;
r6=dec%2;
dec=dec/2;
r5=dec%2;
dec=dec/2;
r4=dec%2; <---- come si riescono a concatenare???
dec=dec/2;
r3=dec%2;
dec=dec/2;
r2=dec%2;
dec=dec/2;
r1=dec%2;
dec=dec/2;
}

printf("Il valore immesso in codice binario corrisponde a: %d%d%d%d%d%d%d%d\n",r1,r2,r3,r4,r5,r6,r7,r8);

getchar();

return 0;

}
norbertom è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 12:08   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da norbertom Guarda i messaggi
evitatemi discorsi su questo codice, perché già qualcuno mi ha detto che si può realizzare in altri modi.
Sì, lo evito che è meglio .....

Quote:
Originariamente inviato da norbertom Guarda i messaggi
il punto è che non riesco a capire in che modo vengono concatenati i dati durante il calcolo (dall'else in poi).

r8=dec%2;
dec=dec/2;
r7=dec%2;
dec=dec/2;
Se ho capito bene, non riesci a capire come funziona la sequenza di moduli e divisioni, giusto?

È abbastanza semplice, immaginiamo di avere il valore binario 00100101

Il primo modulo %2 ti fornisce il bit più a destra, quindi: 00100101
La successiva divisione, divide per due, che equivale a shiftare a destra i bit, quindi ottieni: 00010010
A quel punto continua allo stesso modo come prima.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 13:33   #3
norbertom
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 1075
Quote:
Sì, lo evito che è meglio .....
hehehe. più che altro il prof ci ha detto di farlo senza iterazioni. Poi non so se anche con questo limite possa essere fatto in maniera migliore.
grazie per la chiarezza. ho capito qualcosina in più ma non completamente

ps: potresti farmi un esempio con numeri decimali??
es 35 è = a 00100011
ovvero:

35/2=17 r=1
17/2=8 r=1
8/2=4 r=0
4/2=2 r=0
2/2=1 r=0
1/2=0 r=1

prenderli dal basso verso l'alto ed otteniamo il numero 35 in binario...
ma in quel codice non riesco ad individuare questa sequenzialità.

Ultima modifica di norbertom : 05-11-2007 alle 13:40.
norbertom è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 13:42   #4
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da norbertom Guarda i messaggi
hehehe. più che altro il prof ci ha detto di farlo senza iterazioni.
Giusto per complicare la vita .....

Quote:
Originariamente inviato da norbertom Guarda i messaggi
Poi non so se anche con questo limite possa essere fatto in maniera migliore.
Anche senza iterazione si potrebbe fare di meglio. Penso ad esempio ad una funzione che fa modulo+divisione e che ha come valore di ritorno la divisione e ritorna, attraverso un puntatore passato, il digit binario.

Quote:
Originariamente inviato da norbertom Guarda i messaggi
ps: potresti farmi un esempio con numeri decimali??
Sì.

Valore 37 (binario 00100101)

37 % 2 = 1
37 / 2 = 18 (binario 00010010)

18 % 2 = 0
18 / 2 = 9 (binario 00001001)

9 % 2 = 1
9 / 2 = 4 (binario 00000100)

ecc...
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 13:51   #5
norbertom
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 1075
ho capito... quindi basta ripetere una riga dopo l'altra questa formula e lui automaticamente ti riporta il numero sotto,.. ok.


ps: scusami se ti scasso le OO ma per scrivere 2 righe in C sto tirando giù i santi e non riesco a fare qualcosa di decente!

Ultima modifica di norbertom : 05-11-2007 alle 13:56.
norbertom è offline   Rispondi citando il messaggio o parte di esso
Old 05-11-2007, 14:29   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da norbertom Guarda i messaggi
non riesco a fare qualcosa di decente!
Il codice che hai scritto comunque è corretto, salvo il fatto che non andrebbe bene per valori negativi (il modulo ti ritornerebbe con segno negativo, quindi -1 o 0) e se hai 8 bit il valore massimo sarebbe 255, non 127.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Hisense M2 Pro: dove lo metti, sta. Mini proiettore laser 4K per il cinema ovunque Hisense M2 Pro: dove lo metti, sta. Mini proiett...
Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il convertibile di classe Lenovo ThinkPad X1 2-in-1 G10 Aura Edition: il c...
Intervista a Stop Killing Games: distruggere videogiochi è come bruciare la musica di Mozart Intervista a Stop Killing Games: distruggere vid...
Samsung Galaxy S25 Edge: il top di gamma ultrasottile e leggerissimo. La recensione Samsung Galaxy S25 Edge: il top di gamma ultraso...
HP Elitebook Ultra G1i 14 è il notebook compatto, potente e robusto HP Elitebook Ultra G1i 14 è il notebook c...
Cooler Master MasterFrame 600: modularit...
Questi case sembrano GPU RTX 50 e costan...
Elgato Facecam 4K: ecco la nuova webcam ...
Stampa 3D senza sprechi e senza rifiuti?...
OPPO Find X9 Pro potrebbe battere ogni r...
Le nuove Sony WH-1000XM6 ora disponibili...
ChatGPT Agent come un essere umano: l'AI...
Samsung rivaluta la fabbrica per il pack...
'La potenza di 16 core, nel palmo della ...
Windows 10 compie 10 anni, ma il cambiam...
Un altro Pixel 6a ha preso fuoco: la pro...
NVIDIA, ritorno in Cina in grande stile?...
Tutti contro Windows Recall: un altro se...
PlayStation FlexStrike: il sogno di un f...
WhatsApp sorprende tutti: ecco la nuova ...
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: 22:09.


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