Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Sortering med hjälp av Quicksort i C

Postades av 2004-01-26 18:20:33 - Fredrik Loren, i forum c++, Tråden har 2 Kommentarer och lästs av 814 personer

Hej!
Jag undrar hur jag ska göra för att sortera en lista som innehåller struktar. Struken innehåller Person.fNamn och Person.eNamn. Så jag skullle vilja sortera i bokstavsordning på eNamn.
Någon som är duktig på det kanske skulle kunna skriva ihop en kod som beskriver det.
//
Fredrik


Svara

Sv: Sortering med hjälp av Quicksort i C

Postades av 2004-01-26 20:58:16 - Fredrik Hansson

Det var så längesen jag höll på med C så jag var tvungen att testa om jag fixade det.

Vet inte riktigt om detta är den lösning du är ute efter, men den fungerar :)

<code>
#include <stdio.h>
#include <string.h>

struct person{
char fNamn[20];
char eNamn[20];
};

void main(void) {
struct person personer[4], tmpPersoner;
int i,j;

strcpy(personer[0].fNamn,"Kalle");
strcpy(personer[0].eNamn,"Kula");
strcpy(personer[1].fNamn,"Egon");
strcpy(personer[1].eNamn,"Egonson");
strcpy(personer[2].fNamn,"Kullagulla");
strcpy(personer[2].eNamn,"Andersson");
strcpy(personer[3].fNamn,"Urban");
strcpy(personer[3].eNamn,"Bengtsson");


printf("-- Osorterad --\n");
for (i=0;i<=3;i++){
printf("%s, %s\n",personer[i].eNamn,personer[i].fNamn);
}


for(i=0;i<4;i++){
for(j=i+1;j<4;j++){
if(strcmp(personer[i].eNamn,personer[j].eNamn) > 0){
tmpPersoner=personer[j];
personer[j]=personer[i];
personer[i]=tmpPersoner;
}
}
}

printf("-- Sorterad --\n");
for (i=0;i<=3;i++){
printf("%s, %s\n",personer[i].eNamn,personer[i].fNamn);
}
}

</code>

Fredrik


Svara

Sv: Sortering med hjälp av Quicksort i C

Postades av 2004-01-27 08:41:16 - Per Malmén

Nu bad han iofs om en quicksort-algoritm. Det du har beskrivit är vad jag kan se selection-sort som har en komplexitet på O(n^2) vilket inte är bra. Om antalet saker som ska sorteras är större än några få bör man byta sorteringsalgoritm till en med komplexitet O(n log n), exempelvis quicksort, mergesort eller heapsort.

I quicksort algoritmen jobbar man rekursivt (devide and conquer) och börjar i varje steg med att välja ett element som ska vara avdelare. Sen lägger man det först i listan och ser till att alla tal som är mindre än eller lika med det hamnar i listans första del, dock inte i inbördes rätt ordning. Sen sorterar man delen med små tal och den med stora tal var för sig med quicksort tills man bara har ett tal kvar eftersom ett tal alltid är sorterat. Därefter är det bara att slå ihop listorna.
Quicksort har mycket bra komplexitet i genomsnitt men kan ha O(n^2) OM det tal man väljer som avdelare alltid är det sämsta. Om man är intresserad av en bättre värsta falls-körtid bör man använda merge- eller heapsort istället.

Om det du ska koda inte är del av en labb-uppgift så att själva meningen är att konstruera en quicksort eller om du inte är väldigt nyfiken på att skriva en själv tycker jag att du ska titta på sort-algoritmen i standard-biblioteket. Den metod som heter sort använder sig av quicksort i de flesta implementationer.

/Per


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 615
27 953
271 709
5 535
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies