Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

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;
}

Commentaires et avis

Aucun commentaire pour le moment.

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

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 scripte d'une requête d'insertion [ par benlac_o ] Bonjour, j'ecris un script shell, le but c'est d'inserer des valeurs dans une tables, comme vous pouvez le voire dans la requête ci-dessous, je veux i Tri de vecteur [ par dodo1309 ] hello, Je suis actuellement etudiant en C et lors d'un exercice on m'a imposé de trier un vecteur sans algorithme de tri. Comment pourrais -je faire


Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,312 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.