Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
C
cours
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
algorithmique
cours
Commits
ff666259
Verified
Commit
ff666259
authored
3 years ago
by
orestis.malaspin
Browse files
Options
Downloads
Patches
Plain Diff
updated complexite slides
parent
ffa1b6ee
No related branches found
No related tags found
No related merge requests found
Pipeline
#14782
failed
3 years ago
Stage: test
Changes
1
Pipelines
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
slides/complexite.md
+191
-0
191 additions, 0 deletions
slides/complexite.md
with
191 additions
and
0 deletions
slides/complexite.md
+
191
−
0
View file @
ff666259
...
@@ -50,3 +50,194 @@ Et sur votre machine les résultats seront **différents**.
...
@@ -50,3 +50,194 @@ Et sur votre machine les résultats seront **différents**.
*
Nécessité d'avoir une mesure indépendante du/de la
*
Nécessité d'avoir une mesure indépendante du/de la
matériel/compilateur/façon de mesurer/météo.
matériel/compilateur/façon de mesurer/météo.
# Analyse de complexité algorithmique (1/N)
*
On analyse le
**temps**
pris par un algorithme en fonction de la
**
taille de
l'entrée
**
.
## Exemple: recherche d'un élément dans une liste triée de taille N
```
C
int sorted_list[N];
bool in_list = is_present(N, sorted_list, elem);
```
*
Plus
`N`
est grand, plus l'algorithme prend de temps sauf si...
. . .
*
l'élément est le premier de la liste (ou à une position toujours la même).
*
ce genre de cas pathologique ne rentre pas en ligne de compte.
# Analyse de complexité algorithmique (2/N)
## Recherche linéaire
```
C
bool is_present(int n, int tab[], int elem) {
for (int i = 0; i < n; ++i) {
if (tab[i] == elem) {
return true;
} else if (elem < tab[i]) {
return false;
}
}
return false;
}
```
*
Dans le
**meilleurs des cas**
il faut
`1`
comparaison.
*
Dans le
**pire des cas**
(élément absent p.ex.) il faut
`n`
comparaisons.
. . .
La
**complexité algorithmique**
est proportionnelle à
`N`
: on double la taille
du tableau $
\R
ightarrow$ on double le temps pris par l'algorithme.
# Analyse de complexité algorithmique (3/N)
## Recherche dichotomique
```
C
bool is_present_binary_search(int n, int tab[], int elem) {
int left = 0;
int right = n - 1;
while (left <= right) {
int mid = (right + left) / 2;
if (tab[mid] < elem) {
left = mid + 1;
} else if (tab[mid] > elem) {
right = mid - 1;
} else {
return true;
}
}
return false;
}
```
# Analyse de complexité algorithmique (4/N)
## Recherche dichotomique

](https://upload.wikimedia.org/wikipedia/commons/a/aa/Binary_search_complexity.svg){width=80%}
. . .
*
Dans le
**meilleurs de cas**
il faut
`1`
comparaison.
*
Dans le
**pire des cas**
il faut $
\l
og_2(N)+1$ comparaisons
. . .
## Linéaire vs dichotomique
*
$N$ vs $
\l
og_2(N)$ comparaisons logiques.
*
Pour $N=1000000$:
`1000000`
vs
`21`
comparaisons.
# Notation pour la complexité
## Constante de proportionnalité
*
Pour la recherche linéaire ou dichotomique, on a des algorithmes qui sont
$
\s
im N$ ou $
\s
im
\l
og_2(N)$
*
Qu'est-ce que cela veut dire?
. . .
*
Temps de calcul est $t=C
\c
dot N$ (où $C$ est le temps pris pour une
comparaisons sur une machine/compilateur donné)
*
La complexité ne dépend pas de $C$.
## Le $\mathcal{O}$ de Leibnitz
*
Pour noter la complexité d'un algorithme on utilise le symbole
$
\m
athcal{O}$ (ou "grand Ô de").
*
Les complexités les plus couramment rencontrées sont
. . .
$$
\m
athcal{O}(1),
\q
uad
\m
athcal{O}(
\l
og(N)),
\q
uad
\m
athcal{O}(N),
\q
uad
\m
athcal{O}(
\l
og(N)
\c
dot N),
\q
uad
\m
athcal{O}(N^2),
\q
uad
\m
athcal{O}(N^3).
$$
# Quelques exercices (1/3)
## Complexité de l'algorithme de test de primalité naïf?
```
C
for (i = 2; i < sqrt(N); ++i) {
if (N % i == 0) {
return false;
}
}
return true;
```
. . .
## Réponse
$$
\m
athcal{O}(
\s
qrt{N}).
$$
# Quelques exercices (2/3)
## Complexité de trouver le minimum d'un tableau?
```
C
min = MAX;
for (i = 0; i < N; ++i) {
if (tab[i] < min) {
min = tab[i];
}
}
return min;
```
. . .
## Réponse
$$
\m
athcal{O}(N).
$$
# Quelques exercices (3/3)
## Complexité du tri par sélection?
```
C
ind = 0
while (ind < SIZE-1) {
min = find_min(tab[ind:SIZE]);
swap(min, tab[ind]);
ind += 1
}
```
. . .
## Réponse
### `min = find_min`
$$
(N-1)+(N-2)+...+2+1=
\s
um_{i=1}^{N-1}i=N
\c
dot(N-1)/2=
\m
athcal{O}(N^2).
$$
## Finalement
$$
\m
athcal{O}(N^2
\m
box{ comparaisons}) +
\m
athcal{O}(N
\m
box{
swaps})=
\m
athcal{O}(N^2).
$$
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment