Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
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


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...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Tutte le offerte che meritano del Prime ...
Prime Day Apple: Studio Display, Apple W...
Prime Day FRITZ!: dal 5G al Wi‑Fi ...
Prime Day smartphone: Galaxy S26 in test...
Prime Day Amazon, pioggia di sconti sui ...
Nikon e Prime Day Amazon: si risparmiano...
Prime Day cuffie: Sony WH-1000XM6 e AirP...
Prime Day su schede video, memorie, stor...
Prime Day TV: LG, Philips, Samsung, TCL ...
Prime Day appena partito, tutti i robot ...
Prime Day portatili gaming, da HP Victus...
Portatili tuttofare: il meglio del Prime...
Prime Day e Amazon Seconda Mano, parte i...
Engwe O20 Boost: abbiamo provato in ante...
UWANT V800: addio al rullo rotante, l’as...
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: 05:40.


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