Array78. Дан массив размера N. Заменить каждый элемент массива на среднее арифметическое этого элемента и его соседей.
>Решение Pascal
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 | program Array78; var a : array[1..10] of real; AkOld,Sred: real; N,i:Integer; begin Write('N: '); Readln(N); Writeln('A: '); for i:=1 to N do begin write(i,' :'); readln(a[i]); end; AkOld:=a[1]; a[1]:=(a[1]+a[2])/2; for i:=2 to N-1 do begin Sred:=(AkOld+a[i]+a[i+1])/3; AkOld:=a[i]; a[i]:=Sred; end; a[N]:=(AkOld+a[N])/2; for i:=1 to N do writeln(i,' :',a[i]); end. |
>
Решение C
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 | #include <stdio.h> int main(void) { float a[10]; int n; printf("N: "); scanf("%i",&n); int i; for (i=0; i<n; ++i){ printf("a[%i] : ",i+1); scanf("%f",&a[i]); } float ai1,ai=a[0]; a[0]=(ai+a[1])/2; for (i=1; i<n-1; ++i){ ai1=ai; ai=a[i]; a[i]=(ai1+ai+a[i+1])/3; } a[n-1]=(a[n-1]+ai)/2; printf("A: \n"); for (i=0; i<n; ++i) printf(" %i: %f\n",i+1,a[i]); return 0; } |
C#