Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-01-2004, 15:26   #1
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
[C++]Espressioni algebriche

Come posso far parserare e risolvere expressioni alebriche come:

5 * (3a + 4a) + 4a * (x+1)(x-1)

Tnk
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 11-01-2004, 23:09   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Esistono strumenti di parsing già pronti...anche se ora non mi ricordo il nome...

Il parsing è abbastanza semplice...
Solitamente si scorre la stringa e si costruisce un albero di derivazione....in base a questo albero valuteremo poi l'espressione...
La scansione della stringa si fa semplicemente carattere per carattere...
In una situazione come quella sono determinanti per le suddivisoni degli operatori gli spazi, le parentesi e le operazioni aritmetiche...
Quindi la prima cosa da fare è cercare un termine fra quelli riconosciuti...
Leggo un carattere: 5
Leggo un altro carattere fino a quando trovo qualsiasi carattere diverso da un numero o dal "."...

Trovo " "
L'albero è composto esclusivamente dal 5...
Cerco un operatore...

"*" è un operatore...

L'albero è composto da:
Codice:
*
|-- 5
|-- parametro da trovare
Cerco un parametro...

"(" indica che l'intero albero che troverò fino alla corrispondente ")" va messo come figlio dell'operatore precedente...

Trovo 3...
Trovo a...allora a non è un numero, ma non è un operatore...sottointendo 3a come 3 * a...
Creo il sottoalbero:
Codice:
*
|-- 3
|-- a
Trovo + e l'albero diventa:
Codice:
+
|-- *
|   |-- 3
|   |-- a
|-- parametro da trovare
Trovo 4a e l'albero diventa:
Codice:
+
|-- *
|   |-- 3
|   |-- a
|-- *
    |-- 4
    |-- a
Il tutto diventa:
Codice:
*
|-- 5
|-- +
     |-- *
     |   |-- 3
     |   |-- a
     |-- *
         |-- 4
         |-- a
Capisci come a questo punto sia facile calcolare il risultato...

L'operazione di parsing si fa solitamente con una fuzione ricorsiva che costruisce i vari sottoalberi...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 06:20   #3
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
era + o - la soluzione che pensavo
Quindi poi alla fine mi ciappo tutto faccio le operazioni e ricompongo la string con il risultato, giusto???

Direi che è un buon esercizio per vedere se il Sedgewick(x alberi) è servito a qualcosa

Tnk cionci
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 08:25   #4
ri
Senior Member
 
L'Avatar di ri
 
Iscritto dal: Feb 2003
Città: fra casa e lavoro
Messaggi: 1061
ma perchè quando studi qualcosa di nuovo non ti preoccupi di fare qualche test per vedere se hai capito?
ri è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 08:26   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
L'unica cosa su cui devi stare attento è la precedenza fra gli operatori...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-01-2004, 12:34   #6
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da ri
ma perchè quando studi qualcosa di nuovo non ti preoccupi di fare qualche test per vedere se hai capito?
__________________
Gnu/Linux User
Luc@s è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Cos'è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
NVIDIA chiede più velocità...
Windows 11 in soli 2,8 GB: con questo sc...
Panico in casa HYTE: ritirato dal mercat...
OPPO Reno14, debutto tra rooftoop esclus...
3DAIQ, il progetto di Concept Reply e TE...
Il parlamento francese contro TikTok: '&...
Apple Watch SE 2ª gen. Cellular a soli 2...
MotoE sospesa dopo il 2025: fine tempora...
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: 03:42.


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