Ласло Краус |
Програмски језици (ЕГ) Испит 13. 3. 2005. |
|---|
Саставити на језику C функцију за израчунавање збирова елемената низа целих бројева који при дељењу са k дају исте остатке (резултат је низ од k елемената). На пример, за низ 8, 1, 3, 2, 5, 7, 4, 6 при k=3 резултат је низ 9, 12, 15 (3+6, 1+7+4, 8+2+5).
Саставити на језику C главни програм који прочита потребне податке, позове горњу функцију, испише добијене резултате и понавља претходне кораке све док за дужину низа или за k не прочита недозвољену вредност.
У секвенцијалној текстуалној датотеци у сваком реду се налази један цели број n и n+1 реалних бројева. Први реални број представља укупно задужење за претходну годину за неког потрошача електричне енергије, a осталих n реалних бројева представљају рате које је он уплатио у току године (0≤n≤12).
Саставити на језику C главни програм, који у нову секвенцијалну текстуалну датотеку упише, у посебном реду за сваког потрошачa, вредност обрачуна, која је негативна и без камате ако се новац враћа потрошачу, a позитивна и са каматoм oд 5% на разлику, ако je потрошач уплатио мање од задужења. Име улазне датотека je ulaz.txt, а излазне izlaz.txt.
Саставити на језику FORTRAN потпрограм за налажење коефицијената полинома који представља први извод задатог полинома са реалним коефицијентима.
Саставити на језику FORTRAN главни програм који прочита ред и коефицијенте полинома, позива горњи потпрограм, испише добијени резултат и понавља претходне кораке све док за ред полинома не прочита недозвољену вредност.
#include <stdio.h>
#include <stdlib.h>
#define N 50
#define K 10
void zbir (int a[], int n, int k, int b[]) {
int i;
for (i=0; i<k; b[i++]=0);
for (i=0; i<n; i++) b[a[i]%k] += a[i];
}
main () {
int a[N], b[K], n, k, i;
while (1) {
printf ("\nn? "); scanf ("%d", &n);
if (n<0 || n>N) break;
printf ("A? "); for (i=0; i<n; scanf("%f",&a[i++]));
printf ("k? "); scanf ("%d", &k);
if (k<=0 || k>K) break;
zbir (a, n, k, b);
printf ("B= "); for (i=0; i<k; printf("%f ",b[i++]));
printf ("\n");
}
}
#include <stdio.h>
#define N 12
main () {
float zaduz, uplata, placeno;
int i, n; FILE *datu, *dati;
datu = fopen ("ulaz.txt", "r");
dati = fopen ("izlaz.txt", "w");
while (fscanf(datu,"%d%f",&n,&zaduz) != EOF) {
placeno=0;
for (i=0; i<n; i++) {
fscanf (datu, "%f", &uplata);
placeno += uplata;
}
zaduz -= placeno;
if (zaduz > 0) zaduz *= 1.05;
fprintf (dati, "%f\n", zaduz);
}
fclose (datu); fclose (dati);
}
SUBROUTINE Izvod (A, n, B, m)
REAL A(0:n), B(0:n-1)
m = n - 1
DO i = 1, n
B(i-1) = i * A(i)
END DO
END
PROGRAM IzvodPoli
PARAMETER (nmax = 20)
REAL A(0:nmax), B(0:nmax-1)
10 CONTINUE
PRINT *, 'n?'
READ *, n
IF(n.LT.0 .OR. n.GT.nmax)GO TO 99
PRINT *, 'A?'
READ *, (A(i), i=n,0,-1)
CALL Izvod (A, n, B, m)
PRINT *, 'B='
PRINT *, (B(i), i=m,0,-1)
GO TO 10
99 CONTINUE
END
(⇒ почетак)
Copyright © 2005, Laslo Kraus
Последња ревизија: 10.3.2005.