» »

sortirni algoritem v Cju

sortirni algoritem v Cju

|Luka| ::

A ma kdo kksno idej kako napisat cimkrajsi sortirni algoritem v cju.

Tr0n ::

Imas vec sortov oz. algoritmov. Recimo navadni sort, bubble sort, shell,... in quick sort, ki je zelo hiter (rekurzija).

private void QuickSort(int a[], int l, int r) throws Exception
{
int M = 4;
int i;
int j;
int v;

if ((r-l)>M)
{
i = (r+l)/2;
if (a[l]>a[i]) swap(a,l,i); // Tri-Median Methode!
if (a[l]>a[r]) swap(a,l,r);
if (a[i]>a[r]) swap(a,i,r);

j = r-1;
swap(a,i,j);
i = l;
v = a[j];
for(;;)
{
while(a[++i] while(a[--j]>v);
if (j swap (a,i,j);
pause(i,j);
if (stopRequested) {
return;
}
}
swap(a,i,r-1);
pause(i);
QuickSort(a,l,j);
QuickSort(a,i+1,r);
}
}

|Luka| ::

Algoritem je ql, problem je v mojem compilerju(pacific C).
Ne pozna metod kot je throws,...

Trenutno uporablam tega, ce mas kksn predlog kerga pa kje dobit...

Thx Lix

webblod ::

Borlandov C++ Command line Compiler skupaj v družbi s Turbo Debuger-jem dobiš na Borland / C++ strani brezplačno...

Kolikor vidim zgornjo kodo ustreza ...

Upam, da sem ti kaj pomagal!!! :))
There must be a reason, why I'm so damn dissapointed on M$ Visual Basic
WEBblod.NET :: Slovenska programerska scena

wintermute ::

Ce ze moras izumljat toplo vodo (domace naloge ipd, ...) imas spodaj najpreprostejsi bubble sort. Sicer ima C knjiznica v ta namen funkcijo qsort, C++ knjiznica pa std::sort.

#include &ltiostream&gt
#include &ltalgorithm&gt // za std::sort

using namespace std;

// genericni bubbleSort
template&lttypename T&gt
void bubbleSort(T* array, unsigned int size)
{
bool sorted = false;

while (!sorted)
{
sorted = true;

for (int i = 0; i < size - 1; ++i)
{
if (array[i] > array[i + 1])
{
T temp = array[i];
array[i] = array[i + 1];
array[i + 1] = temp;

sorted = false;
}
}
}
}

int main()
{
int intArray[] = { 1, 3, 5, 2, 5, 8, 2, 5, 10, 1 };
double dblArray[] = {3.2, 6.4, 1.8, 0.4, 7.5, 2.1 };

int numInts = sizeof(intArray) / sizeof(intArray[0]);
int numDbls = sizeof(dblArray) / sizeof(dblArray[1]);

// Takole bi uporabil std::sort
// sort(&intArray[0], &intArray[numInts]);
// sort(&dblArray[0], &dblArray[numDbls]);

bubbleSort(intArray, numInts);
bubbleSort(dblArray, numDbls);

for (int i = 0; i < numInts; ++i) cout << intArray[i] << ", ";
cout << endl;

for (int i = 0; i < numDbls; ++i) cout << dblArray[i] << ", ";
cout << endl;
}

&nbsp
Aja, tisto TrOnovo pa je bolj podobno javi, kot C++.
HTH.

Tr0n ::

Aja, za C ... saj je isti olaz :).

GaPe ::

Čimkrajši algoritem za sortiranje:

# include "stdio.h"
# include "conio.h"

void Sort(int *a, int *b);

int main()
{
int a1, b1, c1;

clrscr();
printf("nVpiši 3 številke: ");
scanf("%d %d %d", &a1, &b1, &c1);
Sort(&a1, &b1);
Sort(&b1, &c1);
Sort(&a1, &c1);
printf("nSortirane številke so: %d, %d, %d", a1, b1, c1);
getch();
return 0;
}

void Sort(int *a, int *b)
{
int temp=0;

if (*a < *b)
{
temp = *a;
*a = *b;
*b = temp;
}
}

lp
Don't steal! The government hates competition.


Vredno ogleda ...

TemaSporočilaOglediZadnje sporočilo
TemaSporočilaOglediZadnje sporočilo
»

[Java - DN] Naključna števila

Oddelek: Šola
121370 (899) nyler
»

Algoritmi za urejanje tabel

Oddelek: Programiranje
51240 (977) lebdim
»

Digitalna evolucija (strani: 1 2 3 426 27 28 29 )

Oddelek: Znanost in tehnologija
141675964 (26133) pietro
»

It means business (strani: 1 2 3 4 5 6 7 8 )

Oddelek: Znanost in tehnologija
37428510 (14509) Thomas
»

[C++] dinamicna alokacija iz subrutine

Oddelek: Programiranje
171202 (1052) spin

Več podobnih tem