Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-04-2010, 17:09   #1
giannimesa
Senior Member
 
Iscritto dal: Aug 2004
Città: Padova
Messaggi: 727
[C] coda

Ciao a tutti, sto lavorando ad un progetto di un simulatore che necessita di una struttura come la Coda con priorità.
L'idea innanzitutto è di crearmi una Linked List e poi eventualmente affiancarla ad una struttura tipo Heap.
Sto facendo delle prove nella realizzazione di questa "Linked list" semplicemente creando diversi elementi collegando e stampando su console per ogni elemento:

Identificativo Elemento, Identificativo elemento precedente, Identificativo elemento successivo.

Ogni elemento della coda ha all'interno un elemento "job".
Il problema è che nel momento in cui vado a stampare l'elemento precedente o successivo con l'istruzione:

Quote:
printf("PREC = %d , SUCC = %d \n", p->prev->jobElement.idJob, p->next->jobElement.idJob);
l'esecuzione di questa istruzione e in particolare il fatto di accedere agli elementi "jobElement" mi blocca inaspettatamente il programma (uso eclipse) senza alcun messaggio di errore (almeno un ubuntu).

Ecco i file:

FILE JOB.H
Codice:
typedef struct job{
	int idJob;
	int priority;
	int releaseTime;
	int exeTime;
	int endTime; // variable used only by periodic jobs
	int numProc;
	int processorOwner;
}job;
FILE QUEUEELEMENT.H
Codice:
#include "job.h"
typedef struct queueElement{
	job jobElement;
	struct queueElement* next;
	struct queueElement* prev;
}queueElement;
FILE MAIN.C
Codice:
#include "job.h"
#include "queueElement.h"
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <malloc.h>

int main(){
	int i;
	printf("simulazione di coda");
	queueElement* p;
	queueElement* temp;
	p=(queueElement *)malloc(sizeof(queueElement));
	p->jobElement.idJob=0;
	for(i =10; i>0; i--){
		p->next = (queueElement *)malloc(sizeof(queueElement));
		temp = p->next;
		temp->jobElement.idJob=i;
		printf("inserito elemento %d ",p->jobElement.idJob);
		if(i<10){
			printf("PREC = %d , SUCC = %d \n", p->prev->jobElement.idJob, p->next->jobElement.idJob);
		}
		p=temp;
	}
}
Chi mi riesce a dare una mano? Grazie mille a tutti!
__________________
If You want a job done right you do it yourself

A64 3200+@240x10 Mhz | A8N SLI | X800GT 256MB Sapphire 570/580 | HD WD160GB | MASTER DVD SONY DRU-810A | 2x512 ram twinmos @480Mhz | LCD 17''SAMSUNG 730BF
---->IL MIO SITO : TESTE DI...<-----VENDO PC P4!!
giannimesa è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 17:47   #2
CaMbA
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 11
Codice:
// ATTENTO: job.h è già stato incluso in queueElement.h
//#include "job.h"
#include "queueElement.h"
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <malloc.h>

int main(){
	int i;
	printf("simulazione di coda");
	queueElement* p;
	queueElement* temp;
	p=(queueElement *)malloc(sizeof(queueElement));
	p->jobElement.idJob=0;
	for(i =10; i>0; i--){
		p->next = (queueElement *)malloc(sizeof(queueElement));
		temp = p->next;
		// ti mancava questo
		temp->prev = p;
		temp->jobElement.idJob=i;
		printf("inserito elemento %d ",p->jobElement.idJob);
		if(i<10){
			printf("PREC = %d , SUCC = %d \n", p->prev->jobElement.idJob, p->next->jobElement.idJob);
		}
		p=temp;
	}
}
In pratica dimenticavi di assegnare il campo prev di temp.

Ciao!
CaMbA è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 17:53   #3
giannimesa
Senior Member
 
Iscritto dal: Aug 2004
Città: Padova
Messaggi: 727
ora provo a vedere, grazie mille!! :-)

Ultima modifica di giannimesa : 20-04-2010 alle 17:57.
giannimesa è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 18:11   #4
giannimesa
Senior Member
 
Iscritto dal: Aug 2004
Città: Padova
Messaggi: 727
Ora funziona almeno il codice scritto fin'ora, grazie mille!
Però nel momento in cui ad esempio voglio andarmi a stampare la situazione della coda con un ciclo for mi da lo stesso problema:

Codice:
for(i=10; i>0;i--){
  printf("ELEMENTO = %d    , PRECEDENTE = %d     , SUCCESSIVO = %d     \n", p->jobElement.idJob, p->prev->jobElement.idJob, p->next->jobElement.idJob);
  p = p->prev;
 }
che sbaglio?
__________________
If You want a job done right you do it yourself

A64 3200+@240x10 Mhz | A8N SLI | X800GT 256MB Sapphire 570/580 | HD WD160GB | MASTER DVD SONY DRU-810A | 2x512 ram twinmos @480Mhz | LCD 17''SAMSUNG 730BF
---->IL MIO SITO : TESTE DI...<-----VENDO PC P4!!
giannimesa è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 20:21   #5
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
La butto lì. Stai partendo dall'ultimo elemento e stai cercando di accedere ad un campo di next, che non esiste.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 20-04-2010, 22:49   #6
CaMbA
Junior Member
 
Iscritto dal: Feb 2009
Messaggi: 11
Quote:
Originariamente inviato da Kenger Guarda i messaggi
La butto lì. Stai partendo dall'ultimo elemento e stai cercando di accedere ad un campo di next, che non esiste.
Ed è esattamente così.
Ti consiglio di impostare a NULL la memoria che non allochi, così quando vai a scorrere la coda puoi effettuare dei controlli sul valore del puntatore e regolarti di conseguenza.
CaMbA è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2010, 07:39   #7
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 creare una coda non serve una lista doppiamente linkata, ma basta una lista singolarmente linkata. Però bisogna mantere sia un puntatore alla testa che uno alla coda.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 21-04-2010, 17:50   #8
giannimesa
Senior Member
 
Iscritto dal: Aug 2004
Città: Padova
Messaggi: 727
grazie a tutti ragazzi per i consigli! Ho fatto tutto e ora funziona ... bene sembra. Ora il primo elemento ha come prev = NULL e l'ultimo ha come next = NULL. Ioltre ho aggiornato il tutto creandomi una struttura di tipo queue che posto qui:

Codice:
typedef struct queue{
	queueElement* first;
	queueElement* last;
	queueElement* pointer;
	int numberOfElements;

}queue;

queue* createQueue();
queueElement* deleteLast(queue* q);
queueElement* insertElement(queue* q, queueElement* J);
queueElement* deleteElement(queue* q, job* J);
queueElement* findElement(queue* q, queueElement F);
queueElement* findJob(queue* q, job* J);
void deleteQueue(queue* q);
int getJob(queueElement* e);
queueElement* findMinPrio(queue* q);
queueElement* findMaxPrio(queue* q);
void swapElements(queue* q, queueElement* s1, queueElement* s2);
queue* prioritySort(queue* q);
void printQueue(queue* q);

@cionci
Lo so che servirebbe solo una lista singolarmente linkata, non sono sceso in dettagli sulle specifiche, ma mi serve per ogni elemento della lista conoscere successore e predecessore, per questo ho optato ad una doppiamente connessa.


Vi sottopongo ad un altro problema a cui per ora non riesco a trovare soluzione, forse sono stanco.
Ho provato a crearmi un metodo che mi scambia due elementi della coda doppiamente linkata, ovviamente mantenendo integra la coda.
Dai test che effettuo qualcosa sembra non andare, e ovviamente C non aiuta in debug... :-\
Provo a postar il codice della funzione, magari sarà qualche macro svista!

Codice:
void swapElements(queue* q, queueElement* s1, queueElement* s2){
	if(s1!=s2){
	queueElement* prev;
	queueElement* next;
	//save s1 pointers
	next=s1->next;
	prev=s1->prev;
	//update new s1 location
	s1->next=s2->next;
	s1->prev=s2->prev;
	if(s2->prev!=NULL)
		s2->prev->next=s1;
	else q->first=s1;
	if(s2->next!=NULL)
		s2->next->prev=s1;
	else q->last=s1;
	//update new s2 location
	s2->next=next;
	s2->prev=prev;
	if(prev!=NULL)
		prev->next=s2;
	else q->first=s2;
	if(next!= NULL)
		next->prev=s2;
	else q->last=s2;
	}
}
grazie mille ancora.

P.S.
ovviamente il campo "first" dell'elemento coda è il primo elemento e il campo "last" è l'ultimo.
__________________
If You want a job done right you do it yourself

A64 3200+@240x10 Mhz | A8N SLI | X800GT 256MB Sapphire 570/580 | HD WD160GB | MASTER DVD SONY DRU-810A | 2x512 ram twinmos @480Mhz | LCD 17''SAMSUNG 730BF
---->IL MIO SITO : TESTE DI...<-----VENDO PC P4!!
giannimesa è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2010, 14:11   #9
giannimesa
Senior Member
 
Iscritto dal: Aug 2004
Città: Padova
Messaggi: 727
up... :-\
__________________
If You want a job done right you do it yourself

A64 3200+@240x10 Mhz | A8N SLI | X800GT 256MB Sapphire 570/580 | HD WD160GB | MASTER DVD SONY DRU-810A | 2x512 ram twinmos @480Mhz | LCD 17''SAMSUNG 730BF
---->IL MIO SITO : TESTE DI...<-----VENDO PC P4!!
giannimesa è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2010, 14:21   #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
Parti da questo ragionamento. Per lo scambio di due elementi puoi:
- scambiare le informazioni
- scambiare tutti i puntatori
Se le informazioni sono piccole, scambiare le informazioni è più semplice E nel tuo caso mi sembra la cosa più semplice.
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
Tineco Floor One S9 Master: aspira e pul...
Vivo X300 Ultra, il lancio globale è ini...
Offerte robot aspirapolvere Amazon: ECOV...
L'AI genera codice in 8 minuti e i senio...
Ring Intercom Audio a 44,99€ su Amazon: ...
Apple iPhone 16 crolla a 689€: ecco perc...
Google Pixel 9 a 449,90€ con caricatore ...
Ecco la top 7 delle offerte Amazon, aggi...
Ex ingegnere ammette il sabotaggio: migl...
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: 20:02.


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