Mihai Sprinceana
Un forum de programare cu de toate. Va astept sa va inscrieti si sa deveniti moderatori. Oricine este binevenit aici sa se inscrie si sa aiba acces la informatie free! Fiecare este liber sa adauge proiecte programe free etc. Ajutati acest forum sa devina o comunitate puternica unde fiecare invata de la fiecare! Tot ce trebuie sa faceti este sa va inregistrati si fiecare contributie se poate dovedi utila in timp! Forumul este free informatia free dk aveti timp liber ajutati si pe ceilalti si invatati si voi in acelasi timp! Haideti sa facem ceva pt.a ne ajuta intre noi! Cititi regulament postare forum inainte de a posta!
Lista Forumurilor Pe Tematici
Mihai Sprinceana | Inregistrare | Login

POZE MIHAI SPRINCEANA

Nu sunteti logat.
Nou pe simpatie:
mariaa5
Femeie
31 ani
Bucuresti
cauta Barbat
31 - 48 ani
Mihai Sprinceana / Pascal / Matrice patrat magic Moderat de Houssey, cosmin, cosmy, fireratbat, profu.info, sade5000
Autor
Mesaj Pagini: 1
mihaispr
Administrator

Inregistrat: acum 17 ani
Postari: 2142
O matrice este patrat magic daca suma pe liinii=suma pe coloane=suma pe cele 2 diagonale

Ex matrice:



17  24   1   8  15

23   5   7  14  16

4   6  13  20  22

10  12  19  21   3

11  18  25   2   9







Program magic;    { Programul  6.1.}
    { Se calculează un pătrat magic. }
    { Acesta este o matrice pătrata de ordinul n }
    { care are suma elementelor pe fiecare }
    { linie, coloană sau diagonală aceeaşi }
Uses Crt;
Var n,    { nN, n>1, reprezintă ordinul matricei }
    m1, m2,    { variabile curente pentru noua poziţie }
    i, j,    { dau poziţia curenta in pătrat }
    k : integer;    { valoarea ce se scrie in pătrat }
    a : array[1..19,1..19] of integer;    { Pătratul magic }

Begin
  Writeln('Se construieşte un pătrat magic cu n linii');
  Repeat write ('n=');
         readln (n)    { Citeşte n }
  until (n in [1..19]) and Odd(n);
  for i := 1 to n do
      for j := 1 to n do  a[i,j] := 0;    { iniţializare matrice }
  i:= 1; j:= n div 2 + 1;    { fixare locul de pornire}
  a[i,j]:=1;
  for k := 2 to n*n do
    begin
      m1 := (i+n 2) mod n + 1;    { calculul poziţiei următoare }
      m2 := j mod n + 1;
      if a[m1,m2] <> 0 then
         if (m1=n) and (m2=1)
            then begin m1 := 2; m2 := n end
            else begin m1:=i+1; m2 := j end;
      a[m1,m2] := k;    { atribuire noua valoare }
      i := m1; j := m2;
    end;
    { Tipărirea rezultatului  }
  ClrScr;
  for i := 1 to n do    { tipăreşte linia i }
      begin 
        writeln;
        for j := 1 to n do write (a[i,j]:4);
      end;
  writeln;
  writeln ('Suma magica = ', n*(n*n+1) div 2);
  readln;
END.


pus acum 15 ani
   
Pagini: 1  

Mergi la