Skip to content
Snippets Groups Projects
recherche.c 1.49 KiB
Newer Older
gossa's avatar
gossa committed
/**
 Recherche d'un entier alétoire dans un tableau de valeurs aléatoires
 */

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

gossa's avatar
gossa committed
#define MAX_VALEUR 15
gossa's avatar
gossa committed

int *generer_tableau(long long unsigned int n)
{
	int *tableau = malloc(n*sizeof(int));
	long long unsigned int i;

	for (i=0; i<n; i++) {
		tableau[i] = rand()%MAX_VALEUR;
	}

	return tableau;
}

void afficher_tableau(int *tableau, long long unsigned int n)
{
	long long unsigned int i;
	for (i=0; i<n; i++) {
		printf("%d ",tableau[i]);
	}
	printf("\n");

}

gossa's avatar
gossa committed
long long unsigned int rechercher(int *tableau, long long unsigned int n, int valeur)
gossa's avatar
gossa committed
{
gossa's avatar
gossa committed
	long long unsigned int i;
	long long unsigned int trouve = -1;
gossa's avatar
gossa committed

	for (i=0; i<n; i++) {
		if (tableau[i] == valeur) {
gossa's avatar
gossa committed
			trouve=i;
gossa's avatar
gossa committed
		}
	}

	return trouve;
}

int main(int argc, char *argv[])
{
	int *tableau;
	int taille, valeur;
	char trouve;

	if (argc<2) {
		printf("%s: opérande manquant\n",argv[0]);
		printf("Recherche une valeur aléatoire dans un tableau d'entier aléatoire de taille n\n");
		printf("Affiche le tableau et renvoie 1 si la valeur est trouvée, 0 sinon\n");
		exit(1);
gossa's avatar
gossa committed
		printf("Usage: %s taille [graine]\n",argv[0]);
gossa's avatar
gossa committed
	}

	unsigned int graine;
gossa's avatar
gossa committed
	if (argc>2) {
		graine = atoi(argv[2]);
gossa's avatar
gossa committed
	} else {
		graine = time(NULL);
	}

	srand(graine);

	taille = strtoull(argv[1], (char **) NULL, 10);
	valeur = rand()%MAX_VALEUR;
	tableau = generer_tableau(taille);

gossa's avatar
gossa committed
	afficher_tableau(tableau,taille);
	trouve = rechercher(tableau, taille, valeur);
gossa's avatar
gossa committed

gossa's avatar
gossa committed
  printf("Valeur %d trouvée: %u\n",valeur, trouve);
gossa's avatar
gossa committed
}