Accueil > > > TRI PAR INSERTION AVEC SENTINELLE
TRI PAR INSERTION AVEC SENTINELLE
Information sur la source
Description
Il s'agit d'un tri classique et peu efficace, mais qui montre l'usage d'une sentinelle.
Source
- #include "stdafx.h"
- #include "stdlib.h"
- #include "time.h"
-
- #define DIM 10
-
- int main(int argc, char* argv[])
- {
-
- int i,j, t[DIM+1];
-
- t[1] = 1;
- srand(unsigned(time(NULL)));
-
- // Tirage
- for ( i = 2; i <= DIM; i++ ) {
- j = rand()%i+1;
- t[i] = t[j];
- t[j] = i;
- }
-
- // Affichage
- for ( i = 1; i <= DIM; i++ )
- printf("t[%d] = %d\n", i, t[i]);
-
- puts("");
-
- // Tri
- int aux;
- for ( i = 1; i <= DIM - 1; i++ ) {
- aux = t [i + 1];
- t[0] = aux; // sentinelle
- j = i;
- while (t[j] > aux) { t[j+1] = t[j]; j = j - 1; }
- t[j+1] = aux;
- }
-
- // Affichage
- for ( i = 1; i <= DIM; i++ )
- printf("t[%d] = %d\n", i, t[i]);
-
- return 0;
- }
#include "stdafx.h"
#include "stdlib.h"
#include "time.h"
#define DIM 10
int main(int argc, char* argv[])
{
int i,j, t[DIM+1];
t[1] = 1;
srand(unsigned(time(NULL)));
// Tirage
for ( i = 2; i <= DIM; i++ ) {
j = rand()%i+1;
t[i] = t[j];
t[j] = i;
}
// Affichage
for ( i = 1; i <= DIM; i++ )
printf("t[%d] = %d\n", i, t[i]);
puts("");
// Tri
int aux;
for ( i = 1; i <= DIM - 1; i++ ) {
aux = t [i + 1];
t[0] = aux; // sentinelle
j = i;
while (t[j] > aux) { t[j+1] = t[j]; j = j - 1; }
t[j+1] = aux;
}
// Affichage
for ( i = 1; i <= DIM; i++ )
printf("t[%d] = %d\n", i, t[i]);
return 0;
}
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Tri par insertion sur listes simplement chainées [ par ichigoZ710 ]
Bonjour, voilà, je vous explique rapidement mon problème, je dois élaborer une procédure de tri par insertion sur une liste qui vient en paramètre de
tri insertion langage C et appel de fonction [ par washh ]
Bonjour,Je débute en langage C et j'ai écrit l'algorithme du tri d'un tableau contenant des chaines de caractères, mais dès la compilation, le program
Tri par insertion sur liste simplement chainée [ par Jordy89 ]
Bonjour,Dans le cadre de la manipulation d'une liste chaînée, je suis amené à effectuer un tri; Je me suis renseigné à gauche et à droite, et il appar
tri par insertion dans une liste chaînée [ par titi4659 ]
Bonjour,j'ai un problème avec une liste chaînée.j'ai une liste d'element que j'arrive a récupéré mais je souhaiterai que lorsque je récupère un elemen
PB sortitems() [ par titi4659 ]
Bonjour,J'ai une liste d'element de type CListCtrl je souhaite la trié selon la colonne:Pour cela j'utilise la fonction SortItems(mysort, num_colonne)
Complexité de l'algorithme de Tri Fusion [ par ousin ]
Salut tout le monde, je voudrais de l'aide pour demontrer mathematiquement en urilisant la resolution des reccurences que la complexité du Tri Fusion
insertion grille Excel / HTML [ par yepla75 ]
Salut,Je fais un programme en C qui crée un fichier Excel, et envoie des valeurs dedans, en utilisant du code HTML (je débute). A la fin du traitement
tri du couvain [ par souf2casa ]
bonjour je cherche un projet de simulation du tri du couvain d'une fourmilière ( projet de language C)
boucle de tri d'etudiant [ par yanboui ]
merci pour votre aide mais j'ai trouvé des difficultés concernant la boucle de classer le tableaud'étudiants par ordre de mérite est ce que vou pouver
|
Derniers Blogs
[HTML5] AUTOUR DU W3C : NOUVEAUX STANDARDS ET WEB MOBILE (LILLE)[HTML5] AUTOUR DU W3C : NOUVEAUX STANDARDS ET WEB MOBILE (LILLE) par Gio
Je m'y prends un peu tard je sais, mais bon je suis développeur web et donc hyper fainéant ! Toujours dans le cadre des technologies émergentes, ici HTML5, parce qu'on aime HTML5 chez Wyg , nous seront présent, le vieux ( Aurélien V.) et moi, pour pr...
Cliquez pour lire la suite de l'article par Gio [WP7] DYNAMICALLY CHANGE STARTUP PAGE[WP7] DYNAMICALLY CHANGE STARTUP PAGE par KooKiz
Let's say that you want to allow the user to customize the startup page of your application. You can easily change the startup page by editing the 'NavigationPage' attribute in the manifest file. But the manifest cannot be modified once the applicatio...
Cliquez pour lire la suite de l'article par KooKiz SESSION SILVERLIGHT 5 3D : SLIDES ET DEMOSSESSION SILVERLIGHT 5 3D : SLIDES ET DEMOS par Groc
Durant les techdays, j'ai eu le plaisir d'animer une session sur Silverlight 5 et la 3D avec Simon Ferquel. Comme promis, voici nos slides et mes démos (celles avec le viper BSG) ici et là. Pour mémoire, les démos utilisent toutes le viper BSG...
Cliquez pour lire la suite de l'article par Groc [TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES[TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES par gpommier
Suite à la session que j'ai présenté sur WebMatrix 2, vous pouvez trouver les slides ici, ainsi que les démos en packages nuget : démos1 et démos2 J'en profite pour remercier chaleureusement tous ceux qui sont venus très nombreux à cette sess...
Cliquez pour lire la suite de l'article par gpommier
Logiciels
Tribler (2012)TRIBLER (2012)Tribler est un client pair à pair (P2P/Peer-to-Peer) open source avec la capacité de regarder des... Cliquez pour télécharger Tribler OneSwarm (2012)ONESWARM (2012)Le peer-to-peer qui protège votre vie privée, c'est OneSwarm.
Ce logiciel de peer-to-peer crypté... Cliquez pour télécharger OneSwarm PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning
|