В
Все
М
Математика
А
Английский язык
Х
Химия
Э
Экономика
П
Право
И
Информатика
У
Українська мова
Қ
Қазақ тiлi
О
ОБЖ
Н
Немецкий язык
Б
Беларуская мова
У
Українська література
М
Музыка
П
Психология
А
Алгебра
Л
Литература
Б
Биология
М
МХК
О
Окружающий мир
О
Обществознание
И
История
Г
Геометрия
Ф
Французский язык
Ф
Физика
Д
Другие предметы
Р
Русский язык
Г
География
ildarka34
ildarka34
27.04.2022 14:33 •  Информатика

Сдав доклад по географии на отлично ученик перенес папку полный путь до которой был /школа/ география/ Египет/ в папку Сданные расположенные в корне диска C Укажите полный путь к файлу пирамиды.txt расположены в папке Египет ​

Показать ответ
Ответ:
arseny666
arseny666
05.04.2023 17:21

(см. объяснение)

Объяснение:

Странно вы как-то пишете. Во-первых, где randomize; Во-вторых, зачем в паскале писать random(33)-14, если можно и нужно random(-14; 18) (обратите внимание, что в этом случае второе число включается, то есть 18 будет тоже допустимо). В-третьих, Вы используете динамические массивы вместо обычных, что странно, учитывая, что свойства, которые они дают Вы полноценно не используете (никак кроме setLength, а ведь с ними задача решается в пару строк кода). В четвертых, заглавными буквами принято обозначать константы, а не переменные. В пятых... Короче говоря, вопросов много.

Судя по коду, Вы создаете массив случайных чисел, выводите его, затем пытаетесь в массив B положить положительные элементы, а в C неположительные. После этого выводите массивы C и B. При этом у Вас есть зачем-то J (которую вы то большой, то маленькой пишете, что очень грубо). То есть, сказав, что Ваш код генерирует случайные числа и распределяет по массивам, в массив B-положительные, а в массив С-отрицательные, Вы говорите неверно. У Вас еще есть ноль. И вы тоже его куда-то да распределяете (подсказка: в массив C). Будем считать, что Вы просто неверно выразились и примем, что в C ноль класть нужно.

У Вас возникает проблема в том, что Вы сталкиваетесь с лишними нулями. Но где у Вас гарантия, что в массиве a не будет естественного нуля? Ее нет. Тогда как вы хотите отличить нули естественные, от появившихся по ошибке? Значит Ваша мысль неверна, то есть убрать нули нельзя. То есть такой мысли по идеи не должно было быть вообще. Сейчас не важно, что в коде написан бред и даже неважно то, что Ваша проблема может возникнуть только у того, кто вообще в паскале не разбирается. Просто задумайтесь, почему одна j? Не лучше ли просто ввести два счетчика для массивов B и C по отдельности и как только вы добавили один элемент соответствующий счетчик увеличить? Это единственно правильный случай, если принимать Ваш код за основу и стараться внести в него минимальные правки.

Не буду больше тянуть и приведу поправленный код.

const N = 10;

var i, j, k, p:integer;

   a, b, c: array [1..N] of integer;

begin

 k:= 1;

 p:= 1;

 randomize;

 print('Массив a:');

 for i:= 1 to N do

 begin

   a[i]:= random(-14, 18);

   print(a[i]);

 end;

 writeln;

 for i:= 1 to N do

 begin

   if(a[i] > 0) then

   begin

     b[k]:= a[i];

     k:= k + 1;

   end else

   begin

     c[p]:= a[i];

     p:= p + 1;

   end;

 end;

 k:= k - 1;

 p:= p - 1;

 writeln;

 print('Массив c:');

 for i:= 1 to p do

 begin

   print(c[i]);

 end;

 writeln;

 print('Массив b:');

 for i:= 1 to k do

   print(b[i]);

 readln;

end.

Еще раз подчеркну, что задачу нужно решать так:

##

'Введите N:'.Print;

var a:= ArrRandom(ReadInteger, -14, 18);

var b:= a.Where(x->x>0);

var c:= a.Where(x->x<=0);

'Массив a:'.Print; a.Println;

'Массив b:'.Print; b.Println;

'Массив c:'.Print; c.Println;

Теперь можно с чистой совестью сказать, что...

Задание выполнено!

0,0(0 оценок)
Ответ:
kuprianova24012
kuprianova24012
23.05.2020 11:26
Выполняя алгоритм, получаем следующий результат (15 итераций)

1. 0..65534 -> 32767
2. 0..32766 -> 16383
3. 0..16382 -> 8191
4. 0..8190  -> 4095
5. 0..4094  -> 2047
6. 2048..4094 -> 3071
7. 2048..3070 -> 2559
8. 2560..3070 -> 2815
9. 2816..3070 -> 2943
10. 2944..3070 -> 3007
11. 2944..3006 -> 2975
12. 2976..3006 -> 2991
13. 2992..3006 -> 2999
14. 3000..3006 -> 3003
15. 3000..3002 -> 3001

Если лень перебирать вручную, можно воспользоваться программой

var k,l,r,x,f:integer;
begin
f := 3001;
l := 0;
r := 65534;
x := (l + r) div 2;
k := 1;
while (x <> f) and (l < r) do
  begin
  writeln(k,' ',l,' ',r,' ',x);
  k := k + 1;
  if f < x then r := x - 1
    else l := x + 1;
  x := (l + r) div 2
  end;
writeln(k,' ',l,' ',r,' ',x);
end.
0,0(0 оценок)
Популярные вопросы: Информатика
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота