Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT
Nelle ultime settimane abbiamo provato tre delle proposte top di gamma di NZXT nelle categorie case, dissipatori e ventole. Rispettivamente, parliamo dell'H9 Flow RGB+, Kraken Elite 420 e F140X. Si tratta, chiaramente, di prodotti di fascia alta che si rivolgono agli utenti DIY che desiderano il massimo per la propria build. Tuttavia, mentre i primi due dispositivi mantengono questa direzione, le ventole purtroppo hanno mostrato qualche tallone d'Achille di troppo
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-03-2011, 16:24   #1
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
[C++] Algoritmo: quante lettere ci sono tra queste due??

Ho una di stringa (o un array di char)...che contiene delle lettere...ad esempio: "a t q r s g".
Ora... vorrei creare una funzione che mi dica quante lettere ci sono ad esempio tra 'a' e 'r'.. come faccio?

Io avevo pensato di ordinare alfabeticamente le lettere con un bubble sort magari.. e poi fare delle verifiche con un if.. ma non mi sembra molto buona quest'idea. anche perchè può capitare come nell'esempio che non ci siano tutte le lettere!
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2011, 16:48   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Forse non ho capito ma...
Codice:
string <- [a][t][q][r][s][g]
delimiter1 <- [a]
delimiter2 <- [r]

index1 <- string.indexOf(delimiter1) -> 0
index2 <- string.indexOf(delimiter2) -> 3
result <- countElementBetween(index1, index2)

// countElementBetween...
countElementBetween(index1, index2)
    max <- max(index1, index2)
    min  <- min(index1, index2)
    -> max - (min+1)
... l'idea è quella di vedere la stringa come un array di caratteri, quindi trovare gli indici dei due caratteri "delimitatori", a quel punto con una operazione di sottrazione tra l'indice più grande e quello più piccolo trovi il numero di elementi tra i due indici/caratteri.

Questo in linea di massima, bisogna però definire alcuni casi limite, ad esempio cosa dovrebbe succedere in questo caso?
Codice:
string <- [a][b][a][t][v][z]
delimiter1 <- [a]
delimiter2 <- [z]
__________________

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)

Ultima modifica di banryu79 : 31-03-2011 alle 16:50.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2011, 16:49   #3
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Beh dai è semplice, non hai bisogno di alcun algoritmo di sorting.

Scansioni le lettere nella stringa, quando incontri il primo delimitatore cominci a contare, quando incontri la seconda lettera smetti di farlo e restituisci il risultato.

Ragionevolmente si può fare con un for ed un paio di if.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2011, 17:18   #4
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
e quale sarebbe il delimitatore?!
potresti farmi vedere gli if perfavore? se non chiedo troppo
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2011, 18:36   #5
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Quote:
Originariamente inviato da mistergks Guarda i messaggi
e quale sarebbe il delimitatore?!
potresti farmi vedere gli if perfavore? se non chiedo troppo
I delimitatori sarebbero le due lettere che passerai alla tua funzione.

Codice:
var begin = 0;
var start = false;
for (..)
{
   if carattere corrente == 'a':
       start = true;
       begin = i;
   else
   if carattere corrente == 'r':
      break;
}

if start and i < length:
   return  i - begin - 1;

return -1;
Se i due caratteri sono completamente assenti la funzione ritorna un numero negativo.

Se viene incontrata 'a' ma mai 'r' la funzione termina con un valore negativo.

Se si incontrano più a viene considerata l'ultima .

Quindi se ho aaabbr viene restituito 2.

Si potrebbe migliorare magari facendo un automa con un contatore.

Ultima modifica di WarDuck : 31-03-2011 alle 18:59.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 31-03-2011, 23:00   #6
mistergks
Senior Member
 
L'Avatar di mistergks
 
Iscritto dal: Mar 2011
Messaggi: 1050
Ho cercato di convertire il tuo pseudocodice in codice c++..mi compila...però appare la console e sparisce subito...all'inizio pensavo per la mancanza del system("pause"); però ho controllato e l'ho messo!...cosa può essere?
Poi un'altra cosa: se io volessi rendere generica la cosa? cioè volessi contare quante lettere ci sono tra la prima lettera dell'array e la lettera che sta nella metà dell'array(cioè dimensione/2)



Codice:
#include <iostream>
using namespace std;

int main()
{
char stringa[7]={"atqrsg"};    
int begin = 0;
bool start = false;
for (int i=0; stringa[i]!='\0'; i++)
{
   if(stringa[i] == 'a'){
       start = true;
       begin = i;}
   else if(stringa[i] == 'r'){
      break;
}


if (start && i < 7)
   return  i - begin - 1;
}
return -1;
 
 
 
system("pause");
return 0;
}
mistergks è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 00:15   #7
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Codice:
if (start && i < 7)
   return  i - begin - 1;
}
return -1;
 
 
 
system("pause");
return 0;
è abbastanza ovvio che la chiamata a system non verrà mai eseguita se prima deve essere eseguita una tra "return i - begin - 1" e "return -1"
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 09:30   #8
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Per rendere generica la cosa devi mettere il codice all'interno di una funzione la cui intestazione sarà:

Codice:
conta_tra(char* str, char begin, char end);
E modificare opportunamente il codice affinché usi come delimitatori begin ed end.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
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...
EK Waterblock si arrende agli aumenti, i...
Geekbench si aggiorna: tutti i test con ...
Per la prima volta un computer quantisti...
Telecamere Reolink 4K su Amazon: Wi-Fi 6...
Anthropic vuole farsi i chip da sola? Co...
Il fondatore di Framework: il personal c...
JBL Live Flex 3 a 129€ su Amazon: ANC ad...
Come un uomo ha costruito un'azienda da ...
Multe fino a 400 euro anche se hai pagat...
Tapo lancia una valanga di offerte su Am...
Little Snitch su Linux: finalmente dispo...
John Deere accetta un accordo da 99 mili...
Gli astronauti di Artemis II osservano i...
OpenAI lancia ChatGPT Pro da 100 dollari...
Allarme rosso: CPU-Z e HWMonitor, segnal...
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: 19:35.


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