Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-10-2014, 15:47   #1
YamIevenhere
Junior Member
 
Iscritto dal: Oct 2014
Messaggi: 4
Bubble Sort di una struttura con puntatori

Devo acquisire una serie di coordinate ed allocarle dinamicamente in una struct, quindi ordinarle in maniera decrescente secondo la distanza del punto dall'origine 0 0.
Ho provato ad usare un Bubble sort ma non funziona , ecco il codice:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

typedef struct {

int x, y;
float d_o;
} punto;

int main()
{
FILE *f1;
int i, j, end=0, tempx, tempy;
float tempd_o;
punto *p, *p2;

f1=fopen("punti.txt","r");
if (f1==NULL)
{
printf("Errore nell'apertura del file.\n");
return 0;
}
fscanf(f1,"%d", &end)
p=malloc(end*sizeof(punto));
if(p==NULL)
{
printf("Errore allocazione memoria.\n");
return 0;
}
p2=p;
for(i=0;i<end;i++)
{
fscanf(f1,"%d %d", &p2->x, &p2->y);
p2->d_o=sqrt((p2->x*p2->x)+(p2->y*p2->y));
p2++;
}
fclose(f1);

//Bubble sort
for(i=0;i<end-1;i++)
{
for(j=0;j<end-i;j++)
{
if(p[j].d_o<p[j+1].d_o)
{
tempx=p[j].x;
p[j].x=p[j+1].x;
p[j+1].x=tempx;
tempy=p[j].y;
p[j].y=p[j+1].y;
p[j+1].y=tempy;
tempd_o=p[j].d_o;
p[j].d_o=p[j+1].d_o;
p[j+1].d_o=tempd_o;

}
}
}
return 0;
}
YamIevenhere è offline   Rispondi citando il messaggio o parte di esso
Old 28-10-2014, 17:21   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da YamIevenhere Guarda i messaggi
for(j=0;j<end-i;j++)
deve essere -1, non -i:
Codice:
for(j=0;j<end-1;j++)
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2014, 10:31   #3
monte.cristo
Senior Member
 
Iscritto dal: May 2014
Messaggi: 1377
Un paio di cose:
1) Dichiari p e p2 che di fatto puntano alla stessa area di memoria, ma dal codice che hai postato uno dei due non sembra necessario
2) L'algoritmo bubble sort è praticamente standard. Questo è lo pseudocodice della versione ottimizzata presa di wikipedia
Codice:
procedure BubbleSort( A : lista di elementi da ordinare)
  alto ← lenght(A) - 1
  while (alto > 0) do
    for i ← 0 to alto do
      if (A[i] > A[i + 1]) then       //scambiare il '>' con '<' per ottenere 
        swap ( A[i], A[i+1] )                  // un ordinamento decrescente
    alto ← alto - 1
Puoi semplicemente adattarla al tuo caso
monte.cristo è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2014, 10:43   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da monte.cristo Guarda i messaggi
Un paio di cose:
1) Dichiari p e p2 che di fatto puntano alla stessa area di memoria, ma dal codice che hai postato uno dei due non sembra necessario
Direi di si, invece:
Codice:
    p2=p;
    for(i=0;i<end;i++)
    {
        fscanf(f1,"%d %d", &p2->x, &p2->y);
        p2->d_o=sqrt((p2->x*p2->x)+(p2->y*p2->y));
        p2++;
    }
Puntano solo inizialmente allo stesso indirizzo, poi usa p2 per scandire l'array, quindi servono entrambi per questa implementazione
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2014, 12:21   #5
monte.cristo
Senior Member
 
Iscritto dal: May 2014
Messaggi: 1377
Edit: commento non più necessario

Ultima modifica di monte.cristo : 29-10-2014 alle 12:25.
monte.cristo è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2014, 21:17   #6
YamIevenhere
Junior Member
 
Iscritto dal: Oct 2014
Messaggi: 4
Ho risolto

Grazie a tutti per le risposte!
YamIevenhere è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Bentornati nel 2007: le memorie DDR3 rin...
Stellantis aderisce ad AI4I e Fondazione...
Google Pixel 10a: prime conferme sul pre...
ISRO potrebbe lanciare la capsula Gagany...
Un nuovo leak conferma dimensioni e novi...
Steam Machine: requisiti Verified piu' s...
NVIDIA GeForce RTX 5070 Ti fuori produzi...
Sony ha annunciato i nuovi giochi che en...
IBM Sovereign Core: la sovranità ...
Cerchi un'asciugatrice conveniente su Am...
Ayaneo Pocket Play arriverà in ri...
iPad Pro 11'' con chip M4 scende a 949€ ...
The Sims entra in una nuova era, ma l'ac...
Netflix, Disney o Prime Video: qual &egr...
Perplexity blocca la generazione di imma...
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:01.


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