Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F97866169
sort.c
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Mon, Jan 6, 23:08
Size
1 KB
Mime Type
text/x-c
Expires
Wed, Jan 8, 23:08 (18 h, 21 m)
Engine
blob
Format
Raw Data
Handle
23234805
Attached To
R1448 Lenstool-HPC
sort.c
View Options
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<fonction.h>
#include<constant.h>
#include<dimension.h>
#include<structure.h>
static
struct
arbre
*
mettre
(
struct
galaxie
*
M
,
struct
arbre
*
A
,
int
(
*
comp
)(
struct
galaxie
*
,
struct
galaxie
*
)
);
static
void
lecture
(
struct
arbre
*
R
,
struct
galaxie
*
B
,
long
int
*
i
);
void
sort
(
long
int
n
,
struct
galaxie
*
A
,
int
(
*
comp
)(
struct
galaxie
*
,
struct
galaxie
*
))
{
struct
arbre
*
racine
;
struct
galaxie
*
B
;
long
int
i
;
racine
=
NULL
;
for
(
i
=
0L
;
i
<
n
;
i
++
)
racine
=
mettre
(
&
A
[
i
],
racine
,
comp
);
i
=
0L
;
B
=
(
struct
galaxie
*
)
malloc
((
unsigned
long
int
)
n
*
sizeof
(
struct
galaxie
));
lecture
(
racine
,
B
,
&
i
);
for
(
i
=
0L
;
i
<
n
;
i
++
)
A
[
i
]
=
B
[
i
];
free
(
B
);
}
/***************************************************************/
static
struct
arbre
*
mettre
(
struct
galaxie
*
M
,
struct
arbre
*
A
,
int
(
*
comp
)(
struct
galaxie
*
,
struct
galaxie
*
)
)
{
if
(
A
==
NULL
)
{
A
=
(
struct
arbre
*
)
malloc
(
sizeof
(
struct
arbre
));
A
->
N
=
M
;
A
->
FG
=
A
->
FD
=
NULL
;
}
else
{
if
((
*
comp
)(
M
,
A
->
N
))
A
->
FG
=
mettre
(
M
,
A
->
FG
,
comp
);
else
A
->
FD
=
mettre
(
M
,
A
->
FD
,
comp
);
}
return
(
A
);
}
/***************************************************************/
static
void
lecture
(
struct
arbre
*
R
,
struct
galaxie
*
B
,
long
int
*
i
)
{
if
(
R
!=
NULL
)
{
lecture
(
R
->
FG
,
B
,
i
);
B
[(
*
i
)
++
]
=
*
(
R
->
N
);
lecture
(
R
->
FD
,
B
,
i
);
}
}
/***************************************************************/
int
comparer_z
(
struct
galaxie
*
A
,
struct
galaxie
*
B
)
{
return
(
A
->
z
<=
B
->
z
);
}
/***************************************************************/
int
comparer_tau
(
struct
galaxie
*
A
,
struct
galaxie
*
B
)
{
return
(
A
->
tau
>
B
->
tau
);
}
int
comparer_pos
(
struct
galaxie
*
A
,
struct
galaxie
*
B
)
{
return
(
A
->
C
.
x
>
B
->
C
.
x
);
}
Event Timeline
Log In to Comment