Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-05-2013, 07: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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Samsung aggiorna Bixby con One UI 8.5: p...
L'Etiopia vieta le auto a combustione: a...
Pirateria audiovisiva: la Guardia di Fin...
Ubisoft conferma due nuovi Far Cry in sv...
Chi vincerà il Festival di Sanrem...
G42 e Cerebras portano in India un super...
Offerte aggiornate del weekend Amazon: 7...
4 MacBook Air in offerta e scende a 939€...
Chrome cambia il tuo modo di lavorare: o...
Minimo storico iPhone 17 su Amazon: 909€...
USA, incriminati tre ingegneri della Sil...
Xbox: Phil Spencer lascia dopo 38 anni, ...
Cuffie e sostanze chimiche: uno studio e...
Terremoto sui dazi USA: la Corte Suprema...
Arianespace potrebbe lanciare il primo r...
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: 16:56.


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