Skip to content
GitLab
Explorer
Connexion
Navigation principale
Rechercher ou aller à…
Projet
C
Compilation_Belkacem_Tran
Gestion
Activité
Membres
Labels
Programmation
Tickets
Tableaux des tickets
Jalons
Wiki
Wiki externe
Code
Requêtes de fusion
Dépôt
Branches
Validations
Étiquettes
Graphe du dépôt
Comparer les révisions
Extraits de code
Compilation
Pipelines
Jobs
Planifications de pipeline
Artéfacts
Déploiement
Releases
Registre de conteneurs
Registre de modèles
Opération
Environnements
Surveillance
Incidents
Analyse
Données d'analyse des chaînes de valeur
Analyse des contributeurs
Données d'analyse CI/CD
Données d'analyse du dépôt
Expériences du modèle
Aide
Aide
Support
Documentation de GitLab
Comparer les forfaits GitLab
Forum de la communauté GitLab
Contribuer à GitLab
Donner votre avis
Raccourcis clavier
?
Extraits de code
Groupes
Projets
Afficher davantage de fils d'Ariane
Hélène TRAN
Compilation_Belkacem_Tran
Validations
1b85ed51
Valider
1b85ed51
rédigé
26 déc. 2017
par
Hélène TRAN
Parcourir les fichiers
Options
Téléchargements
Correctifs
Plain Diff
Correction labgen.c ok
parent
23616dc2
Branches
Branches contenant la validation
Aucune étiquette associée trouvée
Aucune requête de fusion associée trouvée
Modifications
3
Afficher les modifications d'espaces
En ligne
Côte à côte
Affichage de
3 fichiers modifiés
Labgen/a.out
+0
-0
0 ajout, 0 suppression
Labgen/a.out
Labgen/labgen.c
+86
-45
86 ajouts, 45 suppressions
Labgen/labgen.c
Labgen/labgen.h
+14
-8
14 ajouts, 8 suppressions
Labgen/labgen.h
avec
100 ajouts
et
53 suppressions
Labgen/a.out
+
0
−
0
Voir le fichier @
1b85ed51
Aucun aperçu pour ce type de fichier
Ce diff est replié.
Cliquez pour l'agrandir.
Labgen/labgen.c
+
86
−
45
Voir le fichier @
1b85ed51
#include
"labgen.h"
#include
"labgen.h"
point
size
;
point
size
;
/*Attention c'est la taille réelle de la matrice*/
char
***
matrice
=
NULL
;
char
***
matrice
=
NULL
;
int
in
,
out
;
int
in
,
out
;
variables
listevars
;
variables
listevars
;
...
@@ -15,21 +15,23 @@ point new_point(int x, int y)
...
@@ -15,21 +15,23 @@ point new_point(int x, int y)
}
}
/* Crée une matrice de taille (s1, s2) */
/* Crée une matrice de taille (s1, s2)
* /!\ Attention : toujours créer la matrice avant d'utiliser
* les autres fonctions */
void
create_matrice
(
int
s1
,
int
s2
)
void
create_matrice
(
int
s1
,
int
s2
)
{
{
int
i
,
j
;
int
i
,
j
;
matrice
=
malloc
(
s1
*
sizeof
(
char
**
));
matrice
=
malloc
(
(
s1
+
1
)
*
sizeof
(
char
**
));
for
(
i
=
0
;
i
<
s1
;
i
++
){
for
(
i
=
0
;
i
<
s1
+
1
;
i
++
){
matrice
[
i
]
=
malloc
(
s2
*
sizeof
(
char
*
));
matrice
[
i
]
=
malloc
((
s2
+
1
)
*
sizeof
(
char
*
));
for
(
j
=
0
;
j
<
s2
;
j
++
)
for
(
j
=
0
;
j
<
s2
+
1
;
j
++
)
{
{
matrice
[
i
][
j
]
=
malloc
(
sizeof
(
char
));
matrice
[
i
][
j
]
=
malloc
(
sizeof
(
char
));
strcpy
(
matrice
[
i
][
j
],
""
);
strcpy
(
matrice
[
i
][
j
],
""
);
}
}
}
}
size
=
new_point
(
s1
,
s2
);
size
=
new_point
(
s1
+
1
,
s2
+
1
);
/*Attention c'est la taille réelle de la matrice*/
in
=
0
;
in
=
0
;
out
=
0
;
out
=
0
;
}
}
...
@@ -38,10 +40,14 @@ void create_matrice(int s1, int s2)
...
@@ -38,10 +40,14 @@ void create_matrice(int s1, int s2)
/* Renvoie la valeur de la matrice de coordonnées p */
/* Renvoie la valeur de la matrice de coordonnées p */
char
*
lecture
(
point
p
)
char
*
lecture
(
point
p
)
{
{
if
(
p
.
x
>
0
&&
p
.
y
>
0
&&
p
.
x
<
size
.
x
&&
p
.
y
<
size
.
y
)
if
(
matrice
==
NULL
){
{
printf
(
"Matrice non initialisée.
\n
"
);
return
matrice
[
p
.
x
][
p
.
y
];
/* Définir la matrice avant ? */
}
}
else
if
(
p
.
x
>=
0
&&
p
.
y
>=
0
&&
p
.
x
<
size
.
x
&&
p
.
y
<
size
.
y
){
return
matrice
[
p
.
x
][
p
.
y
];
}
else
printf
(
"Impossible de lire la valeur au point (%d,%d).
\n
"
,
p
.
x
,
p
.
y
);
return
NULL
;
return
NULL
;
}
}
...
@@ -50,9 +56,12 @@ char* lecture(point p)
...
@@ -50,9 +56,12 @@ char* lecture(point p)
/* Change la valeur de la matrice de coordonnées p par la valeur msg */
/* Change la valeur de la matrice de coordonnées p par la valeur msg */
void
change_val_matrice
(
point
p
,
char
*
msg
)
void
change_val_matrice
(
point
p
,
char
*
msg
)
{
{
if
(
matrice
==
NULL
){
printf
(
"Matrice non initialisée.
\n
"
);
}
else
if
(
p
.
x
>=
0
&&
p
.
y
>=
0
&&
p
.
x
<
size
.
x
&&
p
.
y
<
size
.
y
)
{
char
*
m1
;
char
*
m1
;
if
(
p
.
x
>
0
&&
p
.
y
>
0
&&
p
.
x
<
size
.
x
&&
p
.
y
<
size
.
y
)
{
m1
=
malloc
(
strlen
(
msg
)
*
sizeof
(
char
));
m1
=
malloc
(
strlen
(
msg
)
*
sizeof
(
char
));
strcpy
(
m1
,
msg
);
strcpy
(
m1
,
msg
);
if
(
matrice
[
p
.
x
][
p
.
y
]
!=
NULL
){
if
(
matrice
[
p
.
x
][
p
.
y
]
!=
NULL
){
...
@@ -60,8 +69,14 @@ void change_val_matrice(point p, char * msg)
...
@@ -60,8 +69,14 @@ void change_val_matrice(point p, char * msg)
}
}
matrice
[
p
.
x
][
p
.
y
]
=
m1
;
matrice
[
p
.
x
][
p
.
y
]
=
m1
;
}
}
else
{
printf
(
"Impossible de changer de valeur la valeur au point (%d,%d).
\n
"
,
p
.
x
,
p
.
y
);
}
}
}
/* Initialise listevars */
void
init_listevars
(){
void
init_listevars
(){
listevars
.
last
=
0
;
listevars
.
last
=
0
;
}
}
...
@@ -70,10 +85,10 @@ void init_listevars(){
...
@@ -70,10 +85,10 @@ void init_listevars(){
/* Vérifie si var est dans listevars :
/* Vérifie si var est dans listevars :
* - si oui, renvoie l'adresse correspondante
* - si oui, renvoie l'adresse correspondante
- sinon, renvoie NULL */
- sinon, renvoie NULL */
int
find_var
(
char
*
var
)
int
find_var
(
char
*
var
)
{
{
int
i
;
int
i
;
int
ret
;
int
ret
;
for
(
i
=
0
;
i
<
listevars
.
last
;
i
++
)
{
for
(
i
=
0
;
i
<
listevars
.
last
;
i
++
)
{
ret
=
strcmp
(
listevars
.
ident
[
i
],
var
);
ret
=
strcmp
(
listevars
.
ident
[
i
],
var
);
if
(
ret
==
0
)
{
if
(
ret
==
0
)
{
...
@@ -89,8 +104,7 @@ int find_var (char* var)
...
@@ -89,8 +104,7 @@ int find_var (char* var)
* directement modifiée
* directement modifiée
* - Sinon rajoute le nom de la variable et sa valeur dans listevars
* - Sinon rajoute le nom de la variable et sa valeur dans listevars
si la taille de listevars le permet */
si la taille de listevars le permet */
void
create_modif_var
(
char
*
nom
,
int
val
)
void
create_modif_var
(
char
*
nom
,
int
val
)
{
{
int
index
=
find_var
(
nom
);
int
index
=
find_var
(
nom
);
if
(
index
!=
-
1
)
if
(
index
!=
-
1
)
...
@@ -99,41 +113,68 @@ if (index != -1)
...
@@ -99,41 +113,68 @@ if (index != -1)
}
}
else
{
else
{
if
(
listevars
.
last
>
TAILLE
)
if
(
listevars
.
last
>
TAILLE
)
{
{
printf
(
"Il n'y a plus de place pour tous ces variables.
\n
"
);
printf
(
" il n'y a plus de place pour tous ces variables
\n
"
);
exit
(
1
);
exit
(
1
);
}
}
else
else
listevars
.
ident
[
listevars
.
last
]
=
malloc
(
strlen
(
nom
)
*
sizeof
(
char
));
listevars
.
ident
[
listevars
.
last
]
=
malloc
(
strlen
(
nom
)
*
sizeof
(
char
));
strcpy
(
listevars
.
ident
[
listevars
.
last
],
nom
);
strcpy
(
listevars
.
ident
[
listevars
.
last
],
nom
);
listevars
.
val
[
listevars
.
last
]
=
val
;
listevars
.
val
[
listevars
.
last
]
=
val
;
listevars
.
last
++
;
listevars
.
last
++
;
}}
}
}
/*void ligne(){
int j;
for (j=0;j<size.y;j++)
printf(" -------");
printf("\n");
}*/
void
affichmat
()
{
int
i
,
j
;
/*ligne();*/
for
(
i
=
0
;
i
<
size
.
x
;
i
++
){
for
(
j
=
0
;
j
<
size
.
y
;
j
++
){
printf
(
"|%s
\t
"
,
matrice
[
i
][
j
]);
}
printf
(
"|
\n
"
);
/*ligne();*/
}
/*ligne();*/
}
int
main
()
{
int
main
()
{
create_matrice
(
5
,
4
);
create_matrice
(
5
,
4
);
point
p1
=
new_point
(
1
,
2
);
point
p1
=
new_point
(
5
,
4
);
change_val_matrice
(
p1
,
"ABC"
);
printf
(
"Point p1 (%d,%d)
\n
"
,
p1
.
x
,
p1
.
y
);
printf
(
"%s
\n
"
,
lecture
(
p1
));
printf
(
"
\n
Appel de la fonction change_val_matrice(p1,ABC)
\n
"
);
change_val_matrice
(
p1
,
"ABC"
);
printf
(
"Point p1 :%s
\n
"
,
lecture
(
p1
));
printf
(
"
\n
Appel de la fonction change_val_matrice(p1,DEF)
\n
"
);
change_val_matrice
(
p1
,
"DEF"
);
change_val_matrice
(
p1
,
"DEF"
);
printf
(
"%s
\n
"
,
lecture
(
p1
));
printf
(
"Point p1 :%s
\n
"
,
lecture
(
p1
));
printf
(
"
\n
Taille de la matrice : (%d,%d)
\n
"
,
size
.
x
-
1
,
size
.
y
-
1
);
printf
(
"Matrice correspondante :
\n
"
);
affichmat
(
matrice
);
init_listevars
();
init_listevars
();
create_modif_var
(
"IDENT"
,
1
);
create_modif_var
(
"IDENT"
,
1
);
create_modif_var
(
"IDENT"
,
2
);
create_modif_var
(
"IDENT"
,
2
);
create_modif_var
(
"IDENT"
,
1
);
create_modif_var
(
"IDENT"
,
1
);
create_modif_var
(
"IDENT2"
,
5
);
create_modif_var
(
"IDENT2"
,
5
);
printf
(
"Taille : %d
\n
"
,
listevars
.
last
);
printf
(
"
\n\n
Taille
listevars
: %d
\n
"
,
listevars
.
last
);
printf
(
"Premier nom : %s
\n
"
,
listevars
.
ident
[
0
]);
printf
(
"Premier nom : %s
\n
"
,
listevars
.
ident
[
0
]);
printf
(
"Première valeur : %d
\n
"
,
listevars
.
val
[
0
]);
printf
(
"Première valeur : %d
\n
"
,
listevars
.
val
[
0
]);
printf
(
"Deuxième nom : %s
\n
"
,
listevars
.
ident
[
1
]);
printf
(
"Deuxième nom : %s
\n
"
,
listevars
.
ident
[
1
]);
printf
(
"Deuxième valeur : %d
\n
"
,
listevars
.
val
[
1
]);
printf
(
"Deuxième valeur : %d
\n
"
,
listevars
.
val
[
1
]);
return
0
;
return
0
;
}
}
Ce diff est replié.
Cliquez pour l'agrandir.
Labgen/labgen.h
+
14
−
8
Voir le fichier @
1b85ed51
...
@@ -2,19 +2,25 @@
...
@@ -2,19 +2,25 @@
#include
<stdlib.h>
#include
<stdlib.h>
#include
<string.h>
#include
<string.h>
#define TAILLE 255
#define TAILLE 255
typedef
struct
{
typedef
struct
{
int
x
;
int
x
;
int
y
;
int
y
;
}
point
;
}
point
;
typedef
struct
{
typedef
struct
{
char
*
ident
[
TAILLE
];
char
*
ident
[
TAILLE
];
int
val
[
TAILLE
];
int
val
[
TAILLE
];
int
last
;
int
last
;
}
variables
;
}
variables
;
char
***
create_matrice
(
int
,
int
);
point
new_point
(
int
,
int
);
point
new_point
(
int
,
int
);
char
*
lecture
(
point
,
char
***
);
void
change_val_matrice
(
point
,
char
*
,
char
***
);
void
create_matrice
(
int
,
int
);
void
affichmat
(
char
***
matrice
);
char
*
lecture
(
point
);
void
change_val_matrice
(
point
,
char
*
);
void
init_listevars
();
int
find_var
(
char
*
);
void
create_modif_var
(
char
*
,
int
);
void
affichmat
();
Ce diff est replié.
Cliquez pour l'agrandir.
Aperçu
0%
Chargement en cours
Veuillez réessayer
ou
joindre un nouveau fichier
.
Annuler
You are about to add
0
people
to the discussion. Proceed with caution.
Terminez d'abord l'édition de ce message.
Enregistrer le commentaire
Annuler
Veuillez vous
inscrire
ou vous
se connecter
pour commenter