Neka su date 3 ulazne datoteke, ulaz1.txt, ulaz2.txt i ulaz3.txt gde svaka sadrži isti broj vrednosti u decimalnom zapisu koje su rezultati nekog eksperimenta. Vrednosti ima onoliko koliko je bilo vremenskih trenutaka u kojima je vrednost posmatrana. Odrediti aritmetičku srednju vrednost za svaki vremenski trenutak na osnovu vrednosti u sve 3 datoteke. Zatim odrediti koja datoteka sadrži najviše vrednosti koji su najudaljenije od srednje vrednosti (vrednost se najviše razlikuje).
Primer : Neka ima 1000 vrednosti u svakoj datoteci. Ako se desilo da u prvoj ima 340, u drugoj 450 i trećoj 210 vrednosti koje su najviše udaljene od srednje vrednosti u trenutku posmatranja, onda ispisujemo ime datoteke ulaz2.txt.
% generise tri proizvoljne kolone % i upisuje ih u tri datoteke % ulaz1.txt, ulaz2.txt i ulaz3.txt n=round(1000-9999*rand(1,1)); vektor1=round(1000-999*rand(1,n))'; vektor2=round(1000-999*rand(1,n))'; vektor3=round(1000-999*rand(1,n))'; save ulaz1.txt vektor1 save ulaz2.txt vektor2 save ulaz3.txt vektor3
Deo koda
round(1000-999*rand(1,1))
zaokrugljuje proizvoljan razlomljen broj iz intervala (1,1000) na najbliži ceo broj. Tako dobijamo dimenziju vektora. Na isti način generišemo proizvoljni vektor1).
% Ucitava vrednosti tri vektora, % Nalazi aritmeticku sredinu (takodje vektor), % i vektor koji najvise odstupa od nje load ulaz1.txt vektor1 load ulaz2.txt vektor2 load ulaz3.txt vektor3 aritmeticka=(vektor1+vektor2+vektor3)/3; domen=1:1:numel(vektor1); od1=abs(vektor1-aritmeticka); od2=abs(vektor2-aritmeticka); od3=abs(vektor3-aritmeticka); n1=0; n2=0; n3=0; for i=domen z=[od1(i) od2(i) od3(i)]; m=max(z); if od1(i)==m n1=n1+1; endif if od2(i)==m n2=n2+1; endif if od3(i)==m n3=n3+1; endif end m=max([n1 n2 n3]); if n1==m 'ulaz1.txt' endif if n2==m 'ulaz2.txt' endif if n3==m 'ulaz3.txt' endif
Niz aritmeticka* čuva aritmetičku sredinu vrednosti vektora. U okviru petlje, za svaku vrstu pronađemo maksimum i smestimo ga u promenljivu m. Odstupanje svakog vektora smestićemo u odgovarajući vektor. Naredba max( [ a b c … x] ) nalazi maksimum vektora čiji su elementi a, b, c … x. Promenljive n1, n2 i n3 sadrže informacije o tome u koliko vrsta su vektori vektor1, vektor2, odnosno vektor3 imali najveće odstupanje od aritmetičke sredine. Na kraju pronađemo maksimalni broj odstupanja i uporedimo ga sa svakom od vrednosti n1, n2 i n3 zato što se može desiti da bar dve od njih budu jednake maksimalnoj vrednosti. Svaka vrednost jednaka maksimumu dovodi do štampanja naziva datoteke na koju se odnosi.