===== Postavka problema =====
//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.//
===== Rešenje =====
==== Pomoćna skripta za generisanje proizvoljnih vektora ====
% 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 vektor((Matrica dimenzija //m// x //n//, koja sadrži proizvoljne vrednosti iz intervala //(0,1)//, može se napraviti pomoću funkcije rand(m,n). **Vektor je matrica čija je jedna dimenzija 1**.)).
==== Glavna skripta ====
% 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**, **n**2 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.