Torna indietro   Hardware Upgrade Forum > Software > Programmazione

WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-03-2012, 16:32   #1
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
[Algoritmico-Java] Prendere una percentuale di punti di una rotta

Salve,
ho il classico problema algoritmico che mi sta facendo impazzire, però questa volta è molto semplice da spiegare:

Ho una rotta composta da una lista contenente un certo numero di punti, io voglio prendere solo una certa percentuale della rotta, come posso fare?

Ovviamente se ho la rotta rappresentata dalla seguente lista di punti 1,2,3,4,5,6,7,8,9,10 e voglio prenderne il 30% voglio grossomodo che mi restituisca qualcosa del tipo:
1,5,10

Ovvero voglio che i punti li prenda in maniera uniforme nella mia lista e non che vengano presi tutti uno dopo l'altro.

Come posso fare considerato che le uniche informazioni che io avrò saranno la lista, quindi il numero totale dei punti contenuti e la percentuale di punti che voglio prendere?

Io stavo pensando a qualcosa del tipo se i è la posizione del punto nella lista allora se i % qualcosa == 0 allora prendilo/non prenderlo. Non riesco però bene a formulare questa condizione. Avete qualche suggerimento?

Vi ringrazio in anticipo per l'aiuto,
guylmaster
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2012, 16:40   #2
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 22056
così su due piedi direi indice % ( 1/(percentuale/100))==0 controlla se ti và bene
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 30-03-2012, 18:16   #3
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
Quote:
Originariamente inviato da !fazz Guarda i messaggi
così su due piedi direi indice % ( 1/(percentuale/100))==0 controlla se ti và bene
Io avevo pensato a questo ragionamento anche se intricatissimo:

Codice:
float modulo = (((float)rotta.size()) / 100) * percentuale;
	    	  modulo = ((float)rotta.size()) / modulo;
	    	  int salta = 0;

Poi nel for che scandisce la rotta (usando come indice l'intero i) metto questo:

Codice:
	    		  if(salta < modulo && i > 0)
	    		  {
                                  //Lo salto, ovvero aggiungo alla linea % che è il mio carattere di commento
	    			  linee.add(0,"% "+linea);
	    			  salta++;
	    		  }
	    		  else
	    		  {
                                 //Lo prendo
	    			  linee.add(0,linea);
	    			  salta = 0;
	    		  }
Ovvero modulo mi dice quanti ne devo prendere, in base alla percentuale e alla lunghezza totale della rotta.

Il mio con il 10% ne prende 1 si e 10 no, il tuo con il 10% ne prende 1 si e 9 no su una rotta di 915 nodi. Ora il 10% è prenderne 1 si e 9 no come fa il tuo o è giusto il mio? mi sto confondendo.


EDIT: se ho 915 punti prenderne il 10% significa prenderne 91,5, il mio che ne prende 1 si e 10 no non significa prenderne 1/10 ? quindi proprio 91 (vabbè il .5 non può pregne mezzo) mentre ad occhio e croce il tuo ne prenderebbe il 9% o mi sto confondendo?

Ultima modifica di guylmaster : 30-03-2012 alle 18:19.
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2012, 07:36   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da guylmaster Guarda i messaggi
...
Il mio con il 10% ne prende 1 si e 10 no, il tuo con il 10% ne prende 1 si e 9 no su una rotta di 915 nodi. Ora il 10% è prenderne 1 si e 9 no come fa il tuo o è giusto il mio? mi sto confondendo.


EDIT: se ho 915 punti prenderne il 10% significa prenderne 91,5, il mio che ne prende 1 si e 10 no non significa prenderne 1/10 ? quindi proprio 91 (vabbè il .5 non può pregne mezzo) mentre ad occhio e croce il tuo ne prenderebbe il 9% o mi sto confondendo?
prenderne il 10% significa che se hai una rotta di 100 punti ne prendi 10(e 90 li salti), ergo se hai una rotta di 10 punti ne prendi 1(e 9 li salti).
__________________

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 02-04-2012, 10:46   #5
ally
Bannato
 
L'Avatar di ally
 
Iscritto dal: Jan 2003
Città:
Messaggi: 4423
...dalla percentuale ti calcoli lo step (valore intero)...cicli e quando la divisione intera con lo step non restituisce resto rispetto al counter del ciclo preni il valore...
ally è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
"Quasi sociopatico": Sam Altma...
Star Wars Eclipse in difficoltà: ...
Gestione del team e romance organiche: l...
Intel lancia Core Ultra X9 378H: hardwar...
Tomodachi Life non supporterà Handheld M...
Identificati i boss di REvil e GandCrab:...
Google Chrome 148 introduce il caricamen...
Tomb Raider: Legacy of Atlantis, l'uscit...
Casa Bianca: proposto un budget ridotto ...
Telecamere Arlo in offerta su Amazon: Es...
Maine primo stato USA a vietare i data c...
DDL PMI, stop alle false recensioni: le ...
Classifiche JustWatch marzo: Una battagl...
iPhone Fold a rischio ritardo: problemi ...
Artemis II: raggiunto il punto più...
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: 14:19.


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