IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Turbo Pascal Discussion :

Transformation d'une matrice en un tableau à une seule dimension


Sujet :

Turbo Pascal

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2014
    Messages : 19
    Points : 13
    Points
    13
    Par défaut Transformation d'une matrice en un tableau à une seule dimension
    Salut à tous,
    j'ai un problème : je veux transformer ma matrice n*m en un tableau à une seule dimension. Voilà, j'ai essayé mais ça n'a pas marché.
    Aidez-moi s'il vous plaît ..
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
     
    program heh;
    uses crt;
    var
      t:array[1..10,1..1à] of integer;
      k:array[1..1)] of integer;
      i,n,j,l,m:integer;
    begin
      clrscr;
      readln(n);readln(m);
      clrscr;
      for i:= 1 to n do
        for j:=1 to m do 
          begin
            readln(t[i,j]);
          end;
      for i:= 1 to n do
        for j:=1 to m do 
          begin
            l:=1;
            while l<m*n do 
              begin
                k[l]:=t[i,j];
                l:=l+1;
              end;
          end;
      for l:=1 to m*n do 
        begin
          writeln(k[l]);
        end;
      readln;
    end.

  2. #2
    Membre éclairé
    Homme Profil pro
    web a11y
    Inscrit en
    Avril 2014
    Messages
    158
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : web a11y
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2014
    Messages : 158
    Points : 718
    Points
    718
    Par défaut
    Bonjour,

    Tu étais "un peu" fatigué en écrivant (vu l'heure du post) ? Rien qu'en lisant les déclarations de t & k on note un gros problème de la gestion de la touche Shift, gauche ou droite. Bref, le compilateur doit te recracher le code dès ces lignes, je pense.

    Ensuite, un conseil : déclare les dimensions maximales en constantes (p.ex. m_max et n_max), et déclare t et k à partir de ces constantes. Ce sera toujours ça de gagné si tu dois adapter/réutiliser ce code plus tard.
    Quand tu veux lire m et n : écris un message (write) avant de lire la donnée, ça permet de savoir où on en est. Ensuite, il est préférable de contrôler l'entrée avant de passer à la suite avec soit un if un peu brutal, soit avec une boucle si c'est passé dans ton cours (mais déjà, fais en sorte que ça fonctionne avant de faire ces contrôles si tu ne te sens pas encore à l'aise).

    Lecture de t : ok pour la double boucle. Mais idem, affiche quelques mots pour savoir où l'on en est. Comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    write ('valeur de t[', i, ',', j, '] : ');
    readln (t[i,j]);
    Passer de t à k : la double boucle suffit, puisque tu parcours t. Et ta variable l a une valeur qui dépend directement d'une combinaison de i et j : boucle while inutile. Si on y regarde de plus près, on peut même directement affecter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    k[la_bonne_formule] = t[i,j]
    Ton dernier readln ne sert à rien tant que le programme se termine juste après.
    Regardes cela à tête reposée, tu y es presque !

  3. #3
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 942
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 942
    Points : 5 654
    Points
    5 654
    Par défaut
    Jia,

    Et j'ajoute que vouloir utiliser ce tableau
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      k:array[1..1)] of integer;
    pour y stocker les données d'une matrice à 2 dimensions est pour le moins curieux.
    Si les cons volaient, il ferait nuit à midi.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2014
    Messages : 19
    Points : 13
    Points
    13
    Par défaut
    ouii :p c'etait trop tard bon j'ai pas encore arrivè ...pour la bonne formule (k[bonne formue]) j'ai reflèchi a k[i+j-1] mais ça n'a pass marchè alors qu'est ce que je peux faire ???

  5. #5
    Membre éclairé
    Homme Profil pro
    web a11y
    Inscrit en
    Avril 2014
    Messages
    158
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : web a11y
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2014
    Messages : 158
    Points : 718
    Points
    718
    Par défaut Que faire : réveiller les neurones ?
    Cela ne semble pas nécessiter beaucoup de réflexion, pourtant...
    Les meilleurs amis du programmeur : papier et crayon.

    Bon, reprenons : je suppose une matrice t de n lignes par m colonnes.
    - on parcours les lignes de 1 à n, donc i varie de 1 à n.
    - la i-ème ligne, c'est t[i,1] à t[i,m], donc j varie de 1 à m,

    Ce qui donne, à la queue-leu-leu (c'est à dire pour remplir k[]) :
    t[1,1] à t[1,m], t[2,1] à t[2,m], ... , t[n,1] à t[n,m]

    - la première ligne (i=1) remplit k[1] à k[m],
    - la seconde ligne (i=2) remplit k[m+1] à k[m+m],
    - la troisième ligne (i=3) remplit k[2m+1] à k[2m+m],
    etc
    Et là, cela doit faire tilt pour la formule.

    Essaye avec un crayon avant de lire le résultat :
    k[ ((i-1)*m) + j] = t[i,j]
    Pour le coup, j'espère bien ne pas faire d'erreur...

  6. #6
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    19
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2014
    Messages : 19
    Points : 13
    Points
    13
    Par défaut
    regarde mon ami moi je fais pas le grand j'ai aps pu le faire c pour ça je vous demande j'ai bien essayè mais ça n'a pas marchè alors je veux bien la solution

  7. #7
    Membre éprouvé
    Homme Profil pro
    Inscrit en
    Août 2008
    Messages
    282
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Secteur : Service public

    Informations forums :
    Inscription : Août 2008
    Messages : 282
    Points : 939
    Points
    939
    Par défaut
    Peut-être ne connais-tu pas l'astuce ?
    Tu places ta souris au début de l'avant-dernière ligne, tu tiens le bouton de souris enfoncé, et tu sélectionnes la ligne.
    ET paf ! Magie ! La formule devient visible !
    (elle est écrite en blanc)
    poke 1024,0; poke 214,214

Discussions similaires

  1. Réponses: 3
    Dernier message: 27/05/2013, 10h23
  2. Comment obternir une matrice triangulaire à partir d'une matrice quelconque ?
    Par membreComplexe12 dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 13/11/2011, 22h05
  3. Réponses: 5
    Dernier message: 23/01/2009, 08h13
  4. Réponses: 4
    Dernier message: 01/03/2008, 15h04
  5. Réponses: 10
    Dernier message: 26/06/2007, 14h14

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo