summaryrefslogtreecommitdiff
path: root/sem_5/HLIN504_Systeme/TP1/pascal.c
diff options
context:
space:
mode:
Diffstat (limited to 'sem_5/HLIN504_Systeme/TP1/pascal.c')
-rw-r--r--sem_5/HLIN504_Systeme/TP1/pascal.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/sem_5/HLIN504_Systeme/TP1/pascal.c b/sem_5/HLIN504_Systeme/TP1/pascal.c
new file mode 100644
index 0000000..9e98eda
--- /dev/null
+++ b/sem_5/HLIN504_Systeme/TP1/pascal.c
@@ -0,0 +1,35 @@
+#include <stdio.h>
+#include <stdlib.h>
+
+int ** pasc(int n);
+void printtab(int ** tab, int n);
+int main ( int argc, char ** argv){
+ // pasc(atoi(argv[1]));
+ printtab(pasc(atoi(argv[1])), (atoi(argv[1])));
+ return 0;
+}
+
+void printtab(int ** tab, int n){
+ for(int i = 0; i < n; i ++){
+ for (int j = 0; j < n; j ++){
+ printf ("%d \t ", tab[i][j]);
+ }
+ printf("\n");
+ }
+}
+int ** pasc(int n){
+ int ** tab = malloc ( sizeof(int*)*n);
+ for (int i =0; i < n; i ++){
+ tab[i]=malloc(sizeof(int)*n);
+ for (int j = 0 ; j < n; j ++){
+ tab[i][j]=0;
+ }
+ }
+ for (int i=0; i < n; i ++){
+ for (int j = 0 ; j <= i; j ++){
+ tab[i][j]= (i>0?(j>0?tab[i-1][j]+tab[i-1][j-1]:tab[i-1][0]):1);
+ // printf("%d %d %d \n",i,j, tab[i][j]);
+ }
+ }
+ return tab;
+}