Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-03-2009, 06:23   #1
_fast_
Member
 
Iscritto dal: Oct 2007
Messaggi: 80
[C] albero semplice

hola!
come posso costruire in C un albero di questo tipo?:

----8541
--/ -- |-- \
8542 8543 8548
-------|
------8544
----/----|----\
8545 8546 8547

In questo caso riceve 4 in input e quindi lo fa4 volte..
quando io provo a fare fork() mi agiunge un figlio per ogni figlio!

ps partito dalla radice creo 3 figlio e solo uno di questi puo' fare3 figli(non piu, non mneo..)
_fast_ è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 13:12   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Potresti spiegare meglio? Magari con il codice e il problema riscontrato
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 13:33   #3
_fast_
Member
 
Iscritto dal: Oct 2007
Messaggi: 80
Devo riuscire a fare un programma in C che prende in input "x"
e fa l'albero alto x.
se per esempio x è 2 sara cosi:

8541 processo padre
8542 - 8543 - 8544 processi figli

(i numeri sono i pid)

se x è 4
8541 processo padre
8542 - 8543 - 8548 processi figli di 8541
...........8544..........processo figlo di 8543
8545 - 8546 - 8547 processi figli di 8544

il problema è che se faccio i fork(), non mi aggiunge solo un figlio al processo padre ma aggiunge figli a tutte le "foglie"

spero di essermi spiegato un po meglio
Immagini allegate
File Type: jpg albero.jpg (7.8 KB, 8 visite)
_fast_ è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 14:32   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Quote:
Originariamente inviato da _fast_ Guarda i messaggi
il problema è che se faccio i fork(), non mi aggiunge solo un figlio al processo padre ma aggiunge figli a tutte le "foglie"

spero di essermi spiegato un po meglio
Sì, un po' meglio. A sto punto il problema sarà lì dove vai a fare la fork. Se posti il codice forse posso aiutarti e se non posso aiutarti io ci sarà sicuramente qualcuno che ne è in grado
Comunque una cosa che non ho capito è questa: il programma prende in input x, e poi con quale criterio decide quanti processi figli lanciare per ogni singolo processo? Nel senso, se la richiesta è solo quella di avere alla fine un albero di altezza x, basta creare un figlio solo per ogni processo fino a raggiungere l'altezza desiderata, es:
8541
--|--
8542
--|--
8543
--|--
8544
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 15:17   #5
_fast_
Member
 
Iscritto dal: Oct 2007
Messaggi: 80
la richiesta è come l'immagine che ti ho allegato

mettiamo x=5
con livelli da 1 a 5
il processo del livello 1 fa3 figli
nel livello 2 ci sono 3 figli ma solo un figlio fa un'altro figlio
nel livello 3 cè solo un figlio e ne fa 3
nel livello 4 ci sono 3 figli ma solo un figlio fa un'altro figlio
...

l'immagine allegata rende un po piu l'idea

piu tardi posto il codice ma non ho fatto molto..
(la maggior parte sono stati tentativi accompagnati da relative arrabbiature)
_fast_ è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 15:53   #6
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Sì, ora è tutto chiaro. Appena puoi posta il codice, nel frattempo provo a scrivermi una soluzione in pseudocodice (all'uni abbiamo visto solo la teoria per ora).
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 13-03-2009, 17:23   #7
_fast_
Member
 
Iscritto dal: Oct 2007
Messaggi: 80
son disperato..
devo consegnare per lunedi un mega esercizio e l'albero è solo una minima parte...

una delle tante prove è questa:
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
pid_t pid;
pid = fork();
switch (pid)
{
case -1:
printf ("No he podido crear el proceso hijo \n");
break;
case 0:
printf ("Soy el hijo, mi PID es %d y mi PPID es %d \n", getpid(), getppid());
fork();
fork();

sleep (20);
break;
default:
printf ("Soy el padre, mi PID es %d y el PID de mi hijo es %d \n", getpid(), pid);
sleep (30);
}
printf ("Final de ejecución de %d \n", getpid());
exit (0);
}

ma mi crea un albero sbilanciato (come tutte le altre prove che ho fatto)
_fast_ è offline   Rispondi citando il messaggio o parte di esso
Old 14-03-2009, 01:45   #8
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Allora, io ho scritto uno pseudocodice, ecco quello che ho scritto:
Codice:
altezza=x
triplo=false
while(x>0){
    triplo=!triplo
    x--
    pidcorrente=pid
    if(triplo){
        pid=fork()
        if(pid==0)
            break
    }
    pid=fork()
    if(pid==0)
        continue
    wait(pid)
    if(triplo)
        fork()
    break
}
Penso che la logica sia corretta. Purtroppo non ho linux al momento e quindi non posso testarlo. L'idea è questa:
all'inizio ho un processo, questo prenderà in input l'altezza dell'albero ed entrerà nel ciclo. Per questo processo triplo sarà true, quindi, dopo aver decrementato x lancerà un processo figlio A (primo ramo sinistro) che però non proseguirà il ciclo, poi lancerà un altro processo B (il ramo centrale) (*). Poi attenderà che questo abbia terminato e solo allora farà partire un altro processo C (il ramo destro), a quel punto sia C che il processo padre usciranno dal ciclo.
(*) B ripartirà dall'inizio del ciclo, stavolta triplo sarà false e x sarà di nuovo decrementata. Verrà lanciato solo il processo B2 (ramo centrale).
B2 ripartirà dall'inizio del ciclo, triplo sarà true e così via...

Spero di non aver scritto cose sbagliate e di esserti stato di aiuto. Ciao
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 15-03-2009, 23:49   #9
_fast_
Member
 
Iscritto dal: Oct 2007
Messaggi: 80
? triplo=!triplo ?

ciao,
sì, sei d'aiuto!
ho capito cosa vorresti fare ma non conosco il comando:

triplo=!triplo

cosa fa??

grazie!
_fast_ è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2009, 01:12   #10
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Si usa proprio così in C, ! è l'operatore di negazione, quindi se prima triplo era true !triplo è false. Comunque in C non c'è true e false, quindi false sarà lo zero e true 1.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
SpaceX vuole portare nello Spazio 1 mili...
Realme 16: il nuovo mid-range che si isp...
DAZN lancia il piano Full Mobile a 19,99...
Samsung Galaxy S26, ormai è tutto...
Smartphone sempre più cari: super...
L'ultima puntata di Falsissimo rimossa d...
NASA Perseverance ha utilizzato percorsi...
Blue Origin sospende per almeno due anni...
Stampanti, Los Angeles verso il divieto ...
Roscosmos Amur: il razzo spaziale riutil...
Robot aspirapolvere per tutte le tasche:...
Accedere alle mail di un lavoratore lice...
Amazon Haul scatenato: migliaia di prodo...
Amazon Seconda Mano rilancia: sconto ext...
Super prezzo Amazon per ECOVACS DEEBOT T...
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:55.


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