Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-07-2003, 10:43   #1
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
ordinamento lista di strutture C

Sono alle prime armi con la programmazione ed ho il seguente problema:
ho creato una lista di elementi tipo strutture che contiene un intero long in un suo campo........indipendentemente dagli elementi inseriti (dinamicamente) voglio ordinare crescentem o decresc in base ai valori long negli elementi ( ho un pò di problemi a lavorare con puntatori e perciò ad esempio leggendo come funziona il mergesort sugli array non riesco a capire come utilizzarlo nel mio caso). DIMENTOICAVO, POSSIBILMENTE DEVE ESSERE UNA FUNZIONE RICORSIVA AD ORDINARE.......grazie ciao a tutti
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 11:36   #2
Icedguardian
Member
 
Iscritto dal: May 2003
Messaggi: 283
Lista monodirezionale o bidirezionale?
Cmq non credo tu possa utilizzare il merge (a meno di modifiche pesanti), io punterei sull'insertion-sort (semplice anche se non efficacissimo).

Ciao
__________________
/***
* Nulla è impossibile per chi non deve farlo
***/
Icedguardian è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 11:52   #3
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
Si può lavorare in due modi....

Metti di avere una lista di questo tipo:

D -> A -> C -> B

da ordinare alfabeticamente...

Il primo modo è di cambiare i puntatori all'interno degli elementi della lista estraendo un elemento e posizionandolo dove ci interessa...
Metto da parte A...
Modifico il puntatore di D e lo faccio puntare a C...

C -> D -> B

Ora prendo a A lo faccio puntare a C...

A -> C -> D -> B

E questa è una iterazione (attenzione non ho specificato il tipo di algoritmo, diciamo che vale per tutto l'insieme di algoritmi che non fanno scambi fra elementi)...

Quelli che fanno scambi si posso adattare scambiando le informazioni di ogni elemento (non va bene l'assegnazione normale perchè i puntatori non vanno scambiati)...

D -> A -> C -> B

TMP = A
A = D
D = TMP

A -> D -> C -> B

Un semplice algoritmo ricorsivo è quello che scambia un elemento con il successivo se si verifica una certa condizione:
Codice:
struct st {
   int info;
   st *next;
};

....

st *ordina(st *primo)
{
   struct st *secondo;
   struct st *tmp; //per il primo metodo
   //int tmp; //per il secondo metodo
   //condizioni di arresto
   if(!primo)
      return NULL;
   if(!primo->next)
      return primo;

   //condizione normale
   secondo = ordina(primo->next); //ricorsione

   if(secondo->info > primo->info) //condizione di scambio
   {
      //con il primo metodo   
      tmp = secondo->next;
      secondo->next = primo;
      primo->next = secondo
      return secondo;
      //con il secondo metodo
      /*
      tmp = secondo->info;
      secondo->info = primo->info;
      primo->info = tmp;
      */
   }
   return primo;
}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 14:45   #4
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
Mi ero scordato un pezzettino e avevo sbagliato qualcosa
Codice:
struct st {
   int info;
   st *next;
};

....

int ciclo(st **primo)
{
   int scambio = 0;
   struct st *secondo;
   struct st *tmp; //per il primo metodo
   //int tmp; //per il secondo metodo
   //condizioni di arresto
   if(!*primo)
      return 0;
   if(!*primo->next)
      return 0;

   //condizione normale
   secondo = *primo->next;

   if(secondo->info > *primo->info) //condizione di scambio
   {
      //con il primo metodo   
      tmp = secondo->next;
      secondo->next = *primo;
      *primo->next = tmp;
      //devo scambiare anche questi valori per far sì che torni
      tmp = *primo;
      secondo = tmp;
      *primo = secondo;

      //con il secondo metodo
      /*
      tmp = secondo->info;
      secondo->info = *primo->info;
      *primo->info = tmp;
      */

      scambio = 1;
   }
   return scambio + ciclo(&secondo);
}

void ordina(st **testa)
{
   //fino a quando viene fatto almeno uno scambio cicla
   while(ciclo(testa));
}
Se questa volta non ho fatto errori questo dovrebbe funzionare e dovrebbe anche essere veloce...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 16:56   #5
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
ok grazie

Mi sembra che possa andar bene, ma dimmi una cosa..... E' normale che non riesco a ragionare in C? Mi si ingarbuglia il cervello e anche se c'è una strada corta per arrivare ad una soluzione, prendo quella lunga!!
Per te è stato difficile?
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 17:46   #6
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
Bisogna un po' prenderci la mano... Non ti preoccupare...ci vuole un po' di tempo... Ti ci trovi un po' male soprattutto se già conosci linguaggi di altissimo livello come VB o Java...
Non ti posso dire come mi ci sono trovato io perchè è il primo linguaggio che ho imparato...ed il primo ha per forza una curva di apprendimento più lunga...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 17:55   #7
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
Problema

credo che ci sia un errore: quando all'interno della funzione ciclo che restituisce un valore di tipo INT fai : return secondo......il quale è un puntatore. Non è detto che c'ho preso ma se così fosse potresti darle una corretta? Ti volevo chiedere anche un ' altra cosa: dove posso guardare su internet per trovare algoritmi o esercizi svolti, utili per farmi imparare?
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 18:00   #8
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
Scusa...mi era rimasto dal codice che avevo scritto sopra...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 19:04   #9
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
Ho fatto un altro errore... Sai, non avendolo provato certe cose si vedono male... Coretto...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 19:14   #10
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
Per esercizi...dovresti fare una ricerca... Di solito si trovano le dispense di qualche corso universitario con esercizi svolti...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2003, 19:18   #11
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
Ad esempio:

http://www.elet.polimi.it/upload/fugini/linguaggio_C_esempi.doc
http://www.dia.uniroma3.it/~torlone/calcolatori/Esercizi.pdf

E molti altri... Sono i primi che ho trovato cercando su Google "esercizi liste linguaggio C"...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2003, 18:10   #12
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
perché

perché usi come argomento della funzione ciclo, un puntatore ad un puntatore? Lo attaccata al mio programma cambiando le cose che mi sembravano giuste, ma non senza dubbi.

es: io dopo aver definito la strurrura col nome lista ho fatto:

typedef struct lista LISTONE;
typedef struct LISTONE *LINK;/* per il puntatore alla strurrura */

quindi come argomento di ciclo ho passato (LINK testa) dove testa è il puntatore al primo elemento della lista. Così che nel resto della funzione
al posto di *primo ho usato testa...... E' GIUSTO QUELLO CHE HO FATTO.....mi dà un errore terribile in esecuzione: errore di accesso illegittimo al segmento o qualcosa del genere, insomma quando si tratta di accessi illegittimi non è un bel segno.....
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2003, 18:31   #13
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
Gli passo un puntatore ad un puntatore perchè in caso venga cambiato il valore di *primo questo cambiamento si riflette anche sul puntatore usato per la chiamata...

Lunedì mi ci metto e lo compilo...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2003, 10:37   #14
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
Ecco qua:
Codice:
#include <stdio.h>
#include <stdlib.h>

struct st { 
   int info; 
   struct st *next; 
}; 


int ciclo2(struct st *primo) 
{ 
   int scambio = 0; 
   struct st *secondo; 
   int tmp;
   //condizioni di arresto 
   if(!primo) 
      return 0; 
   if(!primo->next) 
      return 0; 

   //condizione normale 
   secondo = primo->next; 

   if(secondo->info > primo->info) //condizione di scambio 
   { 
      tmp = secondo->info; 
      secondo->info = primo->info; 
      primo->info = tmp; 
	  scambio = 1;
   } 
   return scambio + ciclo2(secondo); 
} 


int ciclo1(struct st **primo) 
{ 
   int scambio = 0; 
   struct st *secondo; 
   struct st *tmp; //per il primo metodo 
   //condizioni di arresto 
   if(!*primo) 
      return 0; 
   if(!(*primo)->next) 
      return 0; 

   //condizione normale 
   secondo = (*primo)->next; 

   if(secondo->info > (*primo)->info) //condizione di scambio 
   { 
      //con il primo metodo    
      tmp = secondo->next; 
      secondo->next = *primo; 
      (*primo)->next = tmp; 
      //devo scambiare anche questi valori per far sì che il valore modificato di primo
     //venga cambiato anche nel chiamante
      tmp = *primo; 
      *primo = secondo; 
      secondo = tmp; 

      scambio = 1; 
   } 
   scambio += ciclo1(&secondo);
   (*primo)->next = secondo; //se eventualmente secondo è cambiato lo aggiorno
   return scambio; 
} 

void ordina(struct st **testa) 
{ 
   //fino a quando viene fatto almeno uno scambio cicla 
   while(ciclo1(testa)); 
}

void inserisci(struct st **testa, int info)
{
   struct st *tmp;
   tmp = (struct st *)malloc(sizeof(struct st));
   tmp->next = NULL;
   if(!*testa)
     *testa = tmp;
   else
   {
      tmp->next = *testa;
      *testa = tmp;
   }
   (*testa)->info = info;
}

void stampa(struct st *t)
{
   if(!t)
      return;
   printf("%d\n", t->info);
   stampa(t->next);
}

int main()
{
   struct st *testa = NULL;
   inserisci(&testa, 4);
   inserisci(&testa, 10);
   inserisci(&testa, 1);
   inserisci(&testa, 0);
   inserisci(&testa, 10);
   inserisci(&testa, 1);
   inserisci(&testa, 0);
   inserisci(&testa, 10);
   inserisci(&testa, 1);
   inserisci(&testa, 0);
   inserisci(&testa, 5);
 
   ordina(&testa);
   
   stampa(testa);  
   
   return 0;
}
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2003, 17:08   #15
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
ok ma:......

Il tuo algoritmo è perfetto ma non riesco a far funzionare il mio programmino d'apprendimento.

devo leggere un file di input (esempio: un txt creato con il block note dove ho inserito: il nome di un programma televisivo, separato da questo il codice che lo identifica, e ancora più avanti l'odiens.

ES, per una righa ho:

canale5 ch5 1000000

e a seguire ho altre righe con altri canali........

Devo leggere questi dati, metterli in una lista e dire quali sono i due canali più visti (per questo cercavo di ordinare la lista)

ECCO IL MIO CODICE: ti prego di dirmi tutti gli errori e perché li ho fatti...... ti ringrazio.

Codice:
#include <stdio.h>
#include <stdlib.h>

#ifndef NULL
  #define NULL 0
#endif

/* dichiarazione della lista semplice*/
struct lista{
       int spettatori;
       char programma;
       char codice;
       struct lista *prossimo;
};
typedef  struct lista LISTONE;
typedef LISTONE **LINK;
struct lista *testa = NULL; /*puntatore alla testa della lista*/
/*dichiarazione del puntatore al file da aprire*/
FILE *fp;          

void add_to_list(FILE *disco,LINK first);
int ciclo(LINK first);  
void ordina(LINK first); 
int main()
{
 /*dichiaro alcune variabili locali alla funzione main*/
 int number;
 char buffer[20];
 int count;
 int scelta;
 printf("inserire il nome del file da aprire con estensione:   ");
 gets(buffer);
 
 
    
 printf("inserire il numero di righe da leggere:   ");
 scanf("%d", &number);
 
   if (number == 0)
   exit(0);
  else 
    {
     /*apertura del file */
     if ((fp = fopen(buffer, "r")) == NULL )
          {
          fprintf(stderr,"errore nell apertura del file");
          exit(0);
          }       
     for (count = 0 ; count < number ; count++)
     	add_to_list(fp, &testa);
        
    }
fclose(fp); 
/* ora creo un menu per scegliere diverse operazioni da fare*/

 ordina(&testa);
 
 printf("Il canale piu visto è :  %s con %d spettatori",testa->programma,testa->spettatori);
 
   return 0;
}
/* codice delle funzioni */
void add_to_list(FILE *disco,LINK first)
{
 struct lista *nuovo = NULL;
 struct lista *temp = NULL;
 struct lista *preced = NULL;
 
 /*alloca la memoria in modo dinamico*/
 nuovo = (struct lista *)malloc(sizeof(LISTONE));
      if (!nuovo)
      {
       fprintf(stderr,"errore nell/' allocazione della memoria");
       exit(0);
      }
     /*legge la prima riga del file aperto */
  fscanf(disco,"%s %s %ld", &nuovo->programma,&nuovo->codice,&nuovo->spettatori);
    
     if ((*first) == NULL)
        /* aggiungo il primo elemento */         
        {
         *first = nuovo;
         nuovo->prossimo = NULL;
        }
      else
        {
         preced  = *first;
         temp =preced->prossimo;
             while (temp != NULL)
              {
               temp = temp->prossimo;
               preced = preced->prossimo;
              }
         temp = nuovo;
         temp->prossimo = NULL;  
        }
 }

int ciclo(LINK first)  
{ 
   int scambio = 0; 
   struct lista *secondo = NULL; 
   struct lista *tmp = NULL; //per il primo metodo 
   //int tmp; //per il secondo metodo 
   //condizioni di arresto 
   if(!*first) 
      return 0; 
   if(!(*first)->prossimo) 
      return 0; 

   //condizione normale 
   secondo = (*first)->prossimo; 

   if((secondo->spettatori) > ((*first)->spettatori)) //condizione di scambio 
   { 
      //con il primo metodo    
      tmp = secondo->prossimo; 
      secondo->prossimo = *first; 
      (*first)->prossimo = tmp; 
      //devo scambiare anche questi valori per far sì che torni 
      tmp = *first; 
      secondo = tmp; 
      *first = secondo;
       

      //con il secondo metodo 
      /* 
      tmp = secondo->info; 
      secondo->info = *primo->info; 
      *primo->info = tmp; 
      */ 

      scambio = 1; 
   } 
   
   scambio += ciclo(&secondo); 
   (*first)->prossimo = secondo;
   return scambio;
} 

void ordina(LINK first) 
{ 
   //fino a quando viene fatto almeno uno scambio cicla 
   while(ciclo(first)); 

}
[/code][/u]
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2003, 17:17   #16
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
Magari se mi dai anche un file di prova...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2003, 17:53   #17
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
Ecco qua:
Codice:
#include <stdio.h> 
#include <stdlib.h> 

#ifndef NULL 
  #define NULL 0 
#endif 

/* dichiarazione della lista semplice*/ 
struct lista{ 
       int spettatori; 
       char programma[100]; 
       char codice[5]; 
       struct lista *prossimo; 
}; 
typedef  struct lista LISTONE; 
typedef LISTONE **LINK; 
struct lista *testa = NULL; /*puntatore alla testa della lista*/ 
/*dichiarazione del puntatore al file da aprire*/ 
FILE *fp;          

void add_to_list(FILE *disco,LINK first); 
int ciclo(LINK first);  
void ordina(LINK first); 
int main() 
{ 
 /*dichiaro alcune variabili locali alla funzione main*/ 
 int number; 
 char buffer[20]; 
 int count; 
 int scelta; 
 printf("inserire il nome del file da aprire con estensione:   "); 
 gets(buffer); 
  
  
    
 printf("inserire il numero di righe da leggere:   "); 
 scanf("%d", &number); 
  
   if (number == 0) 
   exit(0); 
  else 
    { 
     /*apertura del file */ 
     if ((fp = fopen(buffer, "r")) == NULL ) 
          { 
          fprintf(stderr,"errore nell apertura del file"); 
          exit(0); 
          }        
     for (count = 0 ; count < number ; count++) 
        add_to_list(fp, &testa); 
        
    } 
fclose(fp); 
/* ora creo un menu per scegliere diverse operazioni da fare*/ 

 ordina(&testa); 
  
 printf("Il canale piu visto è :  %s con %d spettatori",testa->programma,testa->spettatori); 

   return 0; 
} 
/* codice delle funzioni */ 
void add_to_list(FILE *disco,LINK first) 
{ 
 struct lista *nuovo = NULL; 
 struct lista *temp = NULL; 
 struct lista *preced = NULL; 
  
 /*alloca la memoria in modo dinamico*/ 
 nuovo = (struct lista *)malloc(sizeof(LISTONE)); 
      if (!nuovo) 
      { 
       fprintf(stderr,"errore nell/' allocazione della memoria"); 
       exit(0); 
      } 
     /*legge la prima riga del file aperto */ 
  fscanf(disco,"%s %s %ld", &nuovo->programma,&nuovo->codice,&nuovo->spettatori); 
    
     if ((*first) == NULL) 
        /* aggiungo il primo elemento */          
        { 
         *first = nuovo; 
         nuovo->prossimo = NULL; 
        } 
      else 
        { 
         nuovo->prossimo = *first;
         *first = nuovo;
        } 
 } 

int ciclo(LINK first)  
{ 
   int scambio = 0; 
   struct lista *secondo = NULL; 
   struct lista *tmp = NULL; //per il primo metodo 
   //int tmp; //per il secondo metodo 
   //condizioni di arresto 
   if(!*first) 
      return 0; 
   if(!(*first)->prossimo) 
      return 0; 

   //condizione normale 
   secondo = (*first)->prossimo; 

   if((secondo->spettatori) > ((*first)->spettatori)) //condizione di scambio 
   { 
      //con il primo metodo    
      tmp = secondo->prossimo; 
      secondo->prossimo = *first; 
      (*first)->prossimo = tmp; 
      //devo scambiare anche questi valori per far sì che torni 
      tmp = *first; 
      *first = secondo; 
      secondo = tmp;         

      //con il secondo metodo 
      /* 
      tmp = secondo->info; 
      secondo->info = *primo->info; 
      *primo->info = tmp; 
      */ 

      scambio = 1; 
   } 
    
   scambio += ciclo(&secondo); 
   (*first)->prossimo = secondo; 
   return scambio; 
} 

void ordina(LINK first) 
{ 
   //fino a quando viene fatto almeno uno scambio cicla 
   while(ciclo(first)); 

}
C'erano diversi errori a giro...

La struttura deve essere composta da stringhe...mentre tu avevi emsso solo un char...
Era sbagliato l'inserimento... Ci ho messo un inserimento in testa...
Ti mancava na modifica sul codice della funzione ciclo che avevo fatto l'ultima volta...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 08-07-2003, 07:05   #18
burohkr
Member
 
Iscritto dal: Jan 2002
Messaggi: 103
prova

adesso lo provo, cmq il file di prova te lo puoi creare, è un .txt con la struttura che ti ho detto sopra......mi sei stato di molto aiuto, ciao
__________________
w.axl
burohkr è offline   Rispondi citando il messaggio o parte di esso
Old 08-07-2003, 07:11   #19
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
Me lo sono già fatto
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
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...
Opera Browser Connector: ChatGPT e Claud...
Nuova Opel Astra: maturità elettr...
Il film di Call of Duty ha finalmente un...
Tra nuove mappe e modalità: Battl...
Narwal Flow 2 ufficiale: 31000 Pa di asp...
GPT-Rosalind: OpenAI lancia il suo primo...
Meta aumenta i prezzi dei visori Meta Qu...
Metro 2039 annunciato con un trailer di ...
UMC aumenterà i prezzi dei wafer ...
Intel rafforza la divisione Foundry: arr...
Apple MacBook Pro 16'' M4 Max a 3.499€: ...
Apple ignora la crisi? Gli iPhone 18 Pro...
Claude Opus 4.7 è disponibile: Anthropic...
OnePlus conferma i rumor: la console por...
Netflix guarda al futuro: prezzi pi&ugra...
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: 10:33.


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