Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-09-2011, 14:40   #1
SerMagnus
Senior Member
 
L'Avatar di SerMagnus
 
Iscritto dal: Sep 2005
Messaggi: 1400
[C/C++] Sottrazione binaria

Salve raga,
stavo giocando un po' con l'aritmetica binaria e gli operatori di bitwise e mi sono incartato volendo implementare un algoritmo per la sottrazione aritmetica binaria (ossia op1>op2, e op1-op2 naturali).

so che è necessario effettuare un XOR tra gli operandi per ottenere il nuovo sottraendo da utilizzare per le successive iterazioni, e che per calcolarmi il resto devo effettuare una AND tra NOT(op1) e op2. il ciclo continua finquando il resto nn è zero.

il problema è il seguente, ho fatto l'algoritmo ma fa un po' quello che gli pare.. a volte somma, altre da una differenza giusta, altre spara numeri a caso


Codice PHP:
unsigned int differenza_binaria(unsigned int aunsigned int b){
     
int diff;
     
int resto=-1;
     while(
resto!=0){
             
diff b;
             
resto = !b;
             
resto resto << 1;
             
diff;
             
resto;
     }
     return 
a;


Qualcuno sa darmi una mano?


Il punto è questo, non so di preciso come implementare l'algoritmo, ho letto solo di come dovrebbe essere fatto (diff e resto), per il resto mi sono appoggiato a quello dell'addizione binaria. Ho googlato per svariate ore senza trovare nulla >.<

Ultima modifica di SerMagnus : 04-09-2011 alle 15:06.
SerMagnus è offline   Rispondi citando il messaggio o parte di esso
Old 04-09-2011, 16:12   #2
Freaxxx
Senior Member
 
L'Avatar di Freaxxx
 
Iscritto dal: Dec 2006
Messaggi: 3808
Quote:
Originariamente inviato da SerMagnus Guarda i messaggi
Salve raga,
stavo giocando un po' con l'aritmetica binaria e gli operatori di bitwise e mi sono incartato volendo implementare un algoritmo per la sottrazione aritmetica binaria (ossia op1>op2, e op1-op2 naturali).

so che è necessario effettuare un XOR tra gli operandi per ottenere il nuovo sottraendo da utilizzare per le successive iterazioni, e che per calcolarmi il resto devo effettuare una AND tra NOT(op1) e op2. il ciclo continua finquando il resto nn è zero.

il problema è il seguente, ho fatto l'algoritmo ma fa un po' quello che gli pare.. a volte somma, altre da una differenza giusta, altre spara numeri a caso


Codice PHP:
unsigned int differenza_binaria(unsigned int aunsigned int b){
     
int diff;
     
int resto=-1;
     while(
resto!=0){
             
diff b;
             
resto = !b;
             
resto resto << 1;
             
diff;
             
resto;
     }
     return 
a;


Qualcuno sa darmi una mano?


Il punto è questo, non so di preciso come implementare l'algoritmo, ho letto solo di come dovrebbe essere fatto (diff e resto), per il resto mi sono appoggiato a quello dell'addizione binaria. Ho googlato per svariate ore senza trovare nulla >.<
dipende dalla rappresentazione binaria che hai dato alle tue quantità decimali, nel modulo e segno, ad esempio, la sottrazione non è altro che una addizione ( come avviene anche nella classica algebra scolastica )

solitamente si usa proprio la rappresentazione in modulo e segno.

http://it.wikipedia.org/wiki/Sistema_numerico_binario
Freaxxx è offline   Rispondi citando il messaggio o parte di esso
Old 05-09-2011, 15:30   #3
SerMagnus
Senior Member
 
L'Avatar di SerMagnus
 
Iscritto dal: Sep 2005
Messaggi: 1400
la rappresentazione è quella predefinitita, quindi in modulo 2^n.
lo scopo dell'algoritmo è lavorare su interi positivi quindi è una semplice somma binaria (ecco perché unsigned int), quindi ha proprio l'obbiettivo di giocare direttamente sui singoli bit.
SerMagnus è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2012, 12:30   #4
Mr. Hgl
Junior Member
 
Iscritto dal: Mar 2012
Messaggi: 1
soluzione (anche se tardiva!)

Quote:
Originariamente inviato da SerMagnus Guarda i messaggi
Salve raga,
stavo giocando un po' con l'aritmetica binaria e gli operatori di bitwise e mi sono incartato volendo implementare un algoritmo per la sottrazione aritmetica binaria (ossia op1>op2, e op1-op2 naturali).

so che è necessario effettuare un XOR tra gli operandi per ottenere il nuovo sottraendo da utilizzare per le successive iterazioni, e che per calcolarmi il resto devo effettuare una AND tra NOT(op1) e op2. il ciclo continua finquando il resto nn è zero.

il problema è il seguente, ho fatto l'algoritmo ma fa un po' quello che gli pare.. a volte somma, altre da una differenza giusta, altre spara numeri a caso


Codice PHP:
unsigned int differenza_binaria(unsigned int aunsigned int b){
     
int diff;
     
int resto=-1;
     while(
resto!=0){
             
diff b;
             
resto = !b;
             
resto resto << 1;
             
diff;
             
resto;
     }
     return 
a;


Qualcuno sa darmi una mano?


Il punto è questo, non so di preciso come implementare l'algoritmo, ho letto solo di come dovrebbe essere fatto (diff e resto), per il resto mi sono appoggiato a quello dell'addizione binaria. Ho googlato per svariate ore senza trovare nulla >.<
Leggo ora questo tuo post, e anche se immagino tu abbia risolto, a quest'ora, volevo precisare che il programma è scritto in maniera ineccepibile, tranne per il fatto che alla riga 6 ("resto = !a & b;") neghi utilizzando "!" che è un operatore logico, mentre, visto che operi sui singoli bit dovresti utilizzare una tilde, "~".
In effetti è una function molto simile a quella relativa all'addizione binaria, cambia giusto qualcosina.
Mr. Hgl è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
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...
Sembra ormai certo: la prossima Xbox sar...
“Solutions Beyond Displays”: la strategi...
La società europea The Exploratio...
Dalle auto ai robot umanoidi: Faraday Fu...
Vodafone annuncia la dismissione di un s...
Stiga lancia i nuovi robot tagliaerba co...
Bullismo e cyberbullismo, Keenetic lanci...
Con AI Skills Checker Bitdefender mette ...
E-bike giapponese con 1.000 km di autono...
Un eVTOL con cui basta saper andare in b...
Dal mercato cinese al mondo: HONOR firma...
Sovranità digitale: l'UE sperimen...
Accesso alla memoria su Windows 11 solo ...
iPhone 18 Pro Max con batteria da oltre ...
Windows 11, cali di prestazioni sulle GP...
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: 05:58.


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