Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
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
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


Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
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...
AI Overviews, un editore statunitense po...
AMD promette 1000 FPS con i Ryzen 9000X3...
L'IA italiana di Aton punta alla Silicon...
Amazon taglia i prezzi: upgrade da gamer...
Aruba Cloud semplifica e potenzia l'offe...
Il futuro del nastro magnetico è ...
Roborock Q7 M5 sotto i 180€: super offer...
Borderlands 4 su PC, il CEO di Gearbox a...
Samsung Galaxy S25 a partire da 669€: of...
TikTok, un'ulteriore proroga da Trump in...
Amazon fa tremare i prezzi: 27 super off...
Apple perde l'ex capo di Siri e figura c...
Fine supporto anche per Windows 11 23H2:...
LG presenta la pompa di calore Therma V ...
Addio LED di debug: i display arrivano a...
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: 15:35.


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