Так, можем найти общие данные, которые нам в любом случае понадобятся для обоих пунктов:
I = 128 Кбайт = 1048576 бит
x = 640 * 320
Всё, теперь начинаем пункт а):
N = 16
N =
i = 4
Рассчитаем объем одной страницы:
I(1) = x * i = 640 * 320 * 4 = 819200 бит (объем 1 страницы)
Посмотрим сколько страниц влезет:
1048576 / 819200 = 1.28 = 1 страница (округляем в меньшую сторону, так как у нас тупо не хватит места, если мы округлим в большую)
Пункт б):
N = 256
i = 8
I(1) = x * i = 640 * 320 * 8 = 1638400 бит (объём 1 страницы)
1048576 / 1638400 = 0.64 = 0 страниц (опять же, не хватит нашего объема для хранения даже 1 страницы)
Так, можем найти общие данные, которые нам в любом случае понадобятся для обоих пунктов:
I = 128 Кбайт = 1048576 бит
x = 640 * 320
Всё, теперь начинаем пункт а):
N = 16
N =
i = 4
Рассчитаем объем одной страницы:
I(1) = x * i = 640 * 320 * 4 = 819200 бит (объем 1 страницы)
Посмотрим сколько страниц влезет:
1048576 / 819200 = 1.28 = 1 страница (округляем в меньшую сторону, так как у нас тупо не хватит места, если мы округлим в большую)
Пункт б):
N = 256
i = 8
I(1) = x * i = 640 * 320 * 8 = 1638400 бит (объём 1 страницы)
1048576 / 1638400 = 0.64 = 0 страниц (опять же, не хватит нашего объема для хранения даже 1 страницы)
public static void main(String[] args) throws java.io.IOException{
int c, n = 0, array[];
while((c = System.in.read())==13 || (47<c && c<58 && (n = n*10+c-48)>-1));
if(25<n || c!=10)return;
array = new int[n];
for(c = 0; c<n; c++){
int d = 0; boolean negative = false;
while((d = System.in.read())!=10)
if(47<d && d<58)array[c] = array[c]*10+d-48;
else if(d==45)negative = true;
if(negative)array[c]*=-1;
}
sortArray(array);
for(c = 0; c<n; c++)System.out.print(array[c]+" ");
}
private static void sortArray(int[] array){
for(int c = 0; c<array.length-1; c++){
int b = c, e;
for(int d = c+1; d<array.length; d++)
if(array[d]>array[b])b=d;
e = array[c];
array[c] = array[b];
array[b] = e;
}
}
}