Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-10-2003, 16:02   #1
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
[C++]Liste

Codice:
 
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#define OK 0
#define ERR -1

using namespace std;

struct List
{
   /*
    * The information index
    */
	int index;
    /*
    * The information value
    */
    void * data;
    /*
    * The list size 
    */
    int _size;	
   /*
    * The next list element
    */
	List * next;	
	/*
     * Create struct
     * 1. The struct index
     * 2. The struct data
     * 3. The next structure addres
     */
	List(int Index, void * Data,  List * Next)
	{
	    data = Data;
		index = Index;
		next = Next;
	}
	/* 
    * Return next element list 
	* 1.A list pointer
	*/
	List *Next(List * pr)
	{
	    // first element of list
    	if(pr->next == NULL)
    	     return pr;
    	// another case
        List * tmp = pr;
        tmp = tmp->next;
        return tmp;           
	}
	/*
     * Add a element
     * 1. A List pointer
     * 2. A index of element
     * 3. The value of element
     */
	int add(List * pr, int index, void * data)
	{
		if(pr == NULL){ /* first element */
		  return ERR; // error
		}
		/* another case */
		List * p = pr;
		while(p->next != NULL)
		  p = p->next;
		p->next = new List(index, data, NULL);
		inc_size(false);
		return OK;
	}
	/*
     * Print all element
     * 1. A List pointer
     * 2. A mode
     * 0 = wiew into a addres
     * 1 = wiew into a string
     */
	void print(List * pr, int mode=1)
	{
	    List * p = pr;
	    while(p != NULL){
	        if(mode==0) 
                cout << "Info " << p->index <<" = " << p->data << "\n";
            else if(mode==1)  
                cout << "Info " << p->index <<" = " << (char *) p->data << "\n";       
                p = p->next;
            if(mode > 1){
                cout << "\nUndefined Mode!\n";
            }
        }
	}
	/*
     * Find a element
     * 1. A List pointer
     * 2. A index that you wont to find
     */
	List *find(List * pr, int index)
	{
         List * p = pr;
         while((p->next != NULL) && (p->index != index))
             p = p->next;
         return p;
	}	
	/*
     * Remove a element
     * 1. A List pointer
     * 2. A index of element
     */
	void remove(List* pr, int n)
	{	   
	   List *p;	   
	   while((pr != NULL))
	   {
		   if(pr->next != NULL && pr->index == n)
		   {
			   p = pr->next;
			   pr->next = pr->next->next;
			   delete p;
		   }
		   pr = pr->next;
		   dec_size(false);
	   }
	}
	/*
     * Generate a list.
     * 1. a array 
     * 2. a array lenght
	 */
	List *generate(List * pr, void * parms[], int lenght)
	{
         for(register int i=0; i<lenght; i++){
             pr->next = new List(i, parms[i], NULL);
         }
	}	
	/* 
    * Return the size of list
	*/
	int size() const
	{ 
        return _size;
	}
	/*
	* Increment a list size
	* 1. The mode
	* true = increment 
	* false = show
	*/
	void inc_size(bool show)
	{
    	if(show == true){
            cout << _size;
        	return;
    	}
    	_size++;
	}
	/*
	* Decrement a list size
	* 1. The mode
	* true = decrement 
	* false = show
	*/
	void dec_size(bool show)
	{
    	if(show == true){
            cout << _size;	
        	return;
    	}
    	_size--;
	}
};
}

Ultima modifica di Luc@s : 16-10-2003 alle 16:08.
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:09   #2
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
Perchè ci hai messo questo ?

int index; //information index

Usa i commenti in C++ style... Quelli in C style sono troppo dispersivi...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:11   #3
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
index lo ho messo x find(), remove() e add()..........
In complesso va bene?
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:12   #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
Fai una lista standard...senza funzioni e costruttori... Almeno per imparare...poi il resto viene dopo...

Nell'implementazione classica della lista non si tiene la dimensione della lista...si calcola con una funzione... Poi non mi piace la struttura che hai dato alla classe...c'è un notevole spreco di informazioni... Ad esempio _size viene duplicato in ogni istanza di List...cosa che non va assolutamente bene...al massimo potevi dichiararlo static...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:13   #5
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
ci avevo pensato anche io a metterlo static ma mi da errore se cerco di farlo
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:15   #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
Quote:
Originariamente inviato da Luc@s
index lo ho messo x find(), remove() e add()..........
In complesso va bene?
Nell'implementazione classica non c'è... Il remove dell'implementazione classica taglia il primo nodo trovato con un dato valore...

Parti da questo:
Codice:
struct list {
   int info;
   list *next;
};
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:15   #7
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da cionci
Fai una lista standard...senza funzioni e costruttori... Almeno per imparare...poi il resto viene dopo...

Nell'implementazione classica della lista non si tiene la dimensione della lista...si calcola con una funzione... Poi non mi piace la struttura che hai dato alla classe...c'è un notevole spreco di informazioni... Ad esempio _size viene duplicato in ogni istanza di List...cosa che non va assolutamente bene...al massimo potevi dichiararlo static...
cmq di esempi come dici 2 li ho fatti con le normali, le bilaterali...............volevo fare qualcosa di + ingegnoso
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 16:16   #8
Luc@s
Senior Member
 
L'Avatar di Luc@s
 
Iscritto dal: Apr 2002
Città: Vigevano(PV)
Messaggi: 2124
Quote:
Originariamente inviato da cionci
Nell'implementazione classica non c'è... Il remove dell'implementazione classica taglia il primo nodo trovato con un dato valore...

Parti da questo:
Codice:
struct list {
   int info;
   list *next;
};

Codice:
 
#include <iostream>
#include <string>
#include <cmath>
#include <cstdio>

using namespace std;
// Liste bilaterale
typedef struct SList
{
    int irq;
    SList *next;
    SList *prev;    
}Lista;

int main( )
{
    Lista prima, seconda, terza, quarta, quinta;
    /* definisco */
    prima.irq = 9;
    seconda.irq = 8;
    terza.irq = 7;
    quarta.irq = 6;
    quinta.irq = 5;
    /* concateno creando la lista*/
    prima.next = &seconda;
    prima.prev = NULL;
    // ----------
    seconda.next = &terza; 
    seconda.prev = &prima;
    // ----------
    terza.next = &quarta;
    terza.prev = &seconda;
    // -----------
    quarta.next = &quinta;
    quarta.prev = &terza;
    // -----------
    quinta.next = NULL; // ultimo anello nullo, cosi la lista e finita
    quinta.prev = &quarta;
    Lista *primoel = &prima;
    // stampa
    Lista *cercare = primoel;
    const unsigned indicenodo = 4;
    for( unsigned i=0; i < indicenodo; i++ )
    {
       cercare = cercare->next;    
    }
    cout << cercare->irq << "\n"; 
    system( "PAUSE" );
    return 0;
}
Luc@s è offline   Rispondi citando il messaggio o parte di esso
Old 16-10-2003, 18:19   #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
Comunque il primo codice è un po' confusionario...
Si fa l'intestazione della classe e dopo l'implementazione...
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
Apple MacBook Neo 13'' con chip A18 Pro ...
Insieme a Leica SL3-P presentate le otti...
La Cina svilupperà anche il razzo...
Rocket Lab e la missione Victus Haze per...
Starship: Ship 40 ha eseguito uno static...
I nuovi Samsung Galaxy Watch 9 si mostra...
Einsten aveva ragione, di nuovo: captate...
Top 10 offerte Amazon: 5 sono partite qu...
AI Conf 2026: l'intelligenza artificiale...
Samsung Galaxy S26 scende a 711,49€: un ...
Dopo il maxi blackout, la Spagna cambia ...
Costa meno di un MacBook e fa molto di p...
Ecco tutti i robot aspirapolvere rimasti...
Più partite da seguire in contemporanea?...
389€ sono veramente pochi per questo PC ...
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: 18:29.


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