Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
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


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Rocket Lab ha posticipato il lancio del ...
Dalla missione Artemis IV il razzo spazi...
Una delle sonde europee di ESA Proba-3 h...
Un modder fa girare Linux su PS5: GTA V ...
MacBook Neo: nessuna sorpresa nei primi ...
La serie POCO X8 Pro è pronta al ...
Smartphone: 2026 difficile per il mercat...
Star Wars: Knights of the Old Republic R...
Huang, NVIDIA: OpenClaw ha realizzato in...
Annunciano il recupero di 4,8 milioni di...
Oggi degli ottimi auricolari Sony con ca...
Muffa in casa? Questo deumidificatore da...
Sonos Era 100: il punto d'ingresso per u...
"Non stiamo sostituendo nessuno con...
Tutti i robot in offerta ora: prezzi bas...
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:14.


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