Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-05-2013, 06:04   #1
fedkara
Junior Member
 
Iscritto dal: Nov 2012
Messaggi: 4
HELP! puntatori in c++

Salve a tutti i sto provando a realizzare l'algoritmo di ricerca calcolata utilizzando le linked-list
il programma prende dei dati strutturati e li ordina in un tabella hash ogni elemento dell'hash e un puntatore a la testa di una linked-list. il mio è un problema di segmentetion fault ho capito + o - deve sta l'errore ma non riesco a risolverlo : nella funzione hash appena provo a lavorare su ptr[] va in segmentetion fault qualcuno che ha un pò di dimistichezza con i puntatori può aiutarmi please !!!

Codice:
#include <iostream>


using namespace std;

struct archivio
{
	unsigned int key;
	
	char nome[20];
	
	struct archivio *next;
};

typedef struct archivio *archivioPtr;

void inizializza(archivioPtr *,int);

int hash(archivioPtr *,int ,archivioPtr );

archivioPtr hash_search(archivioPtr *,int ,unsigned int);

int main(int argc, char **argv)
{
	
	archivioPtr a,*b=NULL,trovato;	
	
	int n,chiave;
	
	cout << "Quanti nomi vuoi inserire nell'archivio ? : ";
	cin >>n;
	
	a = new archivio [n];
	
	for(int i=0; i<n; i++)
	{
		
		cout << "Inserire chiave : ";
		cin >>a[i].key;
		
		cout << "Inserire nome : ";
		cin >> a[i].nome;
		
		a[i].next=NULL;
							
	}

	inizializza(b,n);
	
			
	for(int i=0; i<n; i++)
	
		hash(b,n,&a[i]);
			
	cout << "Inserisci la chiave da cercare : ";
	cin >> chiave;	
	
	if((trovato=hash_search(b,n,chiave))!=NULL)	
		
		cout << "La chiave "<< chiave << "e' stata trovata nell'archivio il nome e' "<< trovato->nome<<endl;
	
	else 
	
		cout << "La chiave non e' stata trovata."<<endl;
		
	cout <<"Premere invio per terminare il programma _ _ _ ";
	
	cin.get();	
		
	
	return 0;
}

void inizializza(archivioPtr *ptr,int dim)
{		
	ptr = new archivioPtr [dim];
	
	for (int i=0; i<dim; i++)
	{
		
		ptr[i] = NULL;
		
		
	}
		
}		
	
int hash(archivioPtr *ptr,int dim,archivioPtr info)
{
	
	int k;
	
	archivioPtr current,previous;
				
	k= info->key % dim;
	
	if(ptr[k] == NULL)
	{	
		ptr[k]=info;
		
	}
				
	
	else
	{
		current=ptr[k]->next;
		
		while(current!=NULL)
		{
			previous=current;
			current=current->next;
		}
	}
		
	previous->next=info;
	
	return 0;		
}		
	
archivioPtr hash_search(archivioPtr *ptr,int dim,unsigned int key)
{
	int pos;
	
	archivioPtr current;
		
	pos=key%dim;
	
	if(ptr[pos]->key==key)
	
		return ptr[pos];
		
	else
	{
		current=ptr[pos]->next;
		
		while(current!=NULL && current->key!=key)
			
			current=current->next;
	}
	
	return current;
}

Grazie in anticipo per le risposte mi rendo conto che è un problema difficile ma propio nn so come risolvere visto che non mi da errori di compilazione.
fedkara è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Elgato Embrace: una sedia ergonomica pro...
Brad Pitt torna in pista: F1 – Il Film a...
Hitachi Vantara annuncia la sua AI Facto...
Brembo passa all'alluminio riciclato al ...
HONOR pronta a sfidare gli iPad Pro con ...
OpenAI esce allo scoperto: confermati i ...
In arrivo altri due prodotti da Apple en...
Il tool per aggiornare da Windows 10 a W...
Rishi Sunak entra in Microsoft e Anthrop...
Porsche in poche ore chiude la formazion...
iPhone 17 disponibili su Amazon al prezz...
La Ferrari Elettrica non è la cau...
Ricarica da record: Zeekr supera i 1.300...
Un 'capezzolo' con feedback aptico al po...
Porsche Taycan Rush a Misano: prima al v...
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: 00:26.


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