Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Cos'è la bolla dell'IA e perché se ne parla
Cos'è la bolla dell'IA e perché se ne parla
Si parla molto ultimamente di "bolla dell'intelligenza artificiale", ma non è sempre chiaro perché: l'IA è una tecnologia molto promettente e che ha già cambiato molte cose dentro e fuori le aziende, ma ci sono enormi aspettative che stanno gonfiando a dismisura i valori delle azioni e distorcendo il mercato. Il che, com'è facile intuire, può portare a una ripetizione della "bolla dotcom", e forse anche di quella dei mutui subprime. Vediamo perché
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-07-2009, 11:57   #1
Napalm
Senior Member
 
L'Avatar di Napalm
 
Iscritto dal: May 2000
Messaggi: 1135
[C#] Soluzione logica problema

Salve, vi spiego la situazione:
io inserisco record in un db in cui un campo "valore" inserisco appunto un valore monetario; io vorrei che quando la somma del campo valore supera i valori di X (o multipli di esso) debba fare una operazione ma solamente la 1° volta che supera la soglia
Il mio problema appunto è quella di creare un algoritmo che risolva il problema.

X= 90

Valore
10 --> niente
40 --> niente
30 --> niente
15 --> sum 95 superato X, prima volta, eseguo operazione
20 --> sum 105 superato X, seconda volta, niente
60 --> sum 165 superato X, seconda volta, niente
25 --> sum 190 superato X*2, prima volta, eseguo operazione
20 --> sum 210 superato X*2, seconda volta, niente

ps: ovviamente posso registrare il fatto di aver superato la soglia per la prima volta


__________________
Quote:
Originariamente inviato da trallallero Guarda i messaggi
Gli anti-fascisti, quelli fascisti coi fascisti, "i diversamente fascisti" (cit. "Napalm"), non meritano il mio rispetto

Ultima modifica di Napalm : 14-07-2009 alle 12:03.
Napalm è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2009, 12:32   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
te la cavi con un "counter" inizializzato a 1 e che viene incrementato di 1 ogni volta che superi un multiplo del tuo numero X.

A questo punto basta che ogni volta che confronti il risultato della somma del campo attuale con le somme già accumulate, se il risultato è uguale o maggiore a "X*counter" (counter vale 1 all'inizio) fai quello che devi fare e incrementi counter di 1.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2009, 12:43   #3
0rph3n
Senior Member
 
L'Avatar di 0rph3n
 
Iscritto dal: Apr 2005
Città: Resana - TV
Messaggi: 960
Esempio in T-SQL, assolutamente non controllato, assolutamente non la migliore soluzione

Codice:
CREATE PROCEDURE dbo.InserisciEdEseguiSeSommaMaggioreUgualeASoglia
(
    @nuovoValore FLOAT
   ,@soglia FLOAT
)
AS
   DECLARE @sommaValorePreInsert FLOAT
   SELECT @sommaValorePreInsert = SUM(Tabella.Valore)
   FROM Tabella
   WHERE ...

   INSERT INTO Tabella
   VALUES (@nuovoValore)

   IF @sommaValorePreInsert < @soglia BEGIN

      DECLARE @sommaValorePostInsert FLOAT
      SELECT @sommaValorePostInsert = SUM(Tabella.Valore)
      FROM Tabella
      WHERE ...

      IF @sommaValorePostInsert >= @soglia BEGIN

         FAI QUELLO CHE DEVI

      END

   END

END
0rph3n è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2009, 13:56   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da Napalm Guarda i messaggi
X= 90

Valore
10 --> niente
40 --> niente
30 --> niente
15 --> sum 95 superato X, prima volta, eseguo operazione
20 --> sum 105 superato X, seconda volta, niente
60 --> sum 165 superato X, seconda volta, niente
25 --> sum 190 superato X*2, prima volta, eseguo operazione
20 --> sum 210 superato X*2, seconda volta, niente
Anzitutto, piccola e pignola precisazione :

10 --> niente
40 --> niente
30 --> niente
15 --> sum 95 superato X, prima volta, eseguo operazione
20 --> sum 115 superato X, seconda volta, niente
60 --> sum 175 superato X, seconda volta, niente
25 --> sum 200 superato X*2, prima volta, eseguo operazione
20 --> sum 220 superato X*2, seconda volta, niente

Non so se cerchi una soluzione più Sql o più C#, comunque puoi risolvere semplicemente usando come incremento il valore stesso della "soglia" 90, senza contatori o variabili boolean accessorie :

Codice:
        private static int sum = 0;
        //oppure calcolo sum facendo la Select Sum dal DB...
        private static int incrSogliaSum = 90;
        //calcolo della prossima soglia basata su sum attuale
        private int sogliaSum = sum / incrSogliaSum * incrSogliaSum;
E poi ad ogni Insert a DB :

Codice:
            if (sogliaSum == 0) { sogliaSum = incrSogliaSum; }
            MessageBox.Show(sogliaSum.ToString(),"Soglia =");

            //inserimento nuovo record
            int nuovoValore = Convert.ToInt32(textBox1.Text) ;
            //insert ...
            //...
            sum += nuovoValore;
            if ( sum >= sogliaSum ) 
            {
                //esegui operazione
                MessageBox.Show(sum.ToString(),"Eseguita Operazione su sum =");
                //...
                sogliaSum += incrSogliaSum;                 
            }
Nel mio esempio il nuovo valore sta, appunto, in una TextBox.
La prima MsgBox informa sul "cambio di soglia", mentre la seconda è una simulazione del tuo "esegui operazione"...
Funziona con un sum=0 ( DB vuoto ), ma anche con sum casuale > 0, nel qual caso sum andrà calcolato ad ogni apertura dell'applicazione, mentre la prossima "sogliaSum" viene calcolata in auto, basandosi sul sum attuale.
Prova...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Cloud sovrano: l'approccio di Broadcom c...
HONOR conferma l'arrivo in Italia di Mag...
La Cina sotto pressione impone maniglie ...
OpenAI integra le app in ChatGPT per tra...
NVIDIA sarebbe pronta a tagliare la prod...
Prezzo minimo storico per iPhone 16 Pro:...
Riot Games scopre una falla nei BIOS che...
Beats in super offerta su Amazon: aurico...
Batterie elettriche, Samsung SDI e Stell...
Clivet presenta Fullness, la pompa di ca...
SpaceX lancerà 167 razzi spaziali...
Yakuza Kiwami 3 e Dark Ties protagonisti...
Privacy a rischio: ecco la VPN che regis...
SpaceX ha annunciato che un satellite St...
ASUSTOR presenta i nuovi NAS Lockerstor ...
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:09.


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