Дан одномерный массив. удалить из массива все числа фибоначчи. язык c++ или паскаль
100
446
Ответы на вопрос:
// pascalabc.net 3.0, сборка 1088 const nn=100; var a: array[1..nn] of integer; i,n,k,max,f2,f1,fib: integer; begin write('введите количество элементов в массиве (1-100): '); read(n); randomize; writeln('*** сформированный массив ***'); max: =0; for i: =1 to n do begin a[i]: =random(100)+1; write(a[i],' '); if max< a[i] then max: =a[i] end; writeln; // заменяем элементы, равные числам фибоначчи, на -1 k: =0; f1: =1; fib: =1; while fib< =max do begin for i: =1 to n do if a[i]=fib then begin a[i]: =-1; inc(k) end; f2: =f1; f1: =fib; fib: =f1+f2 end; if k> 0 then begin // удаляем элементы, равные -1 writeln('*** результирующий массив ***'); for i: =n downto 1 do begin if a[i]=-1 then begin if i< > n then for k: =i to n-1 do a[k]: =a[k+1]; dec(n); end; end; for i: =1 to n do write(a[i],' '); writeln end else writeln('числа фибоначчи не обнаружены') end. тестовое решение: введите количество элементов в массиве (1-100): 20 *** сформированный массив *** 21 51 15 38 52 35 42 51 16 53 96 3 53 82 87 12 55 37 93 19 *** результирующий массив *** 51 15 38 52 35 42 51 16 53 96 53 82 87 12 37 93 19
1) при вводе n = 10 будет выведено 2, хотя на самом деле должно быть 4 (1, 2, 5, 10). 2) при n = 4 или n = 9 будет выведен правильный ответ при n = 4, k = 3, при n = 9, к = 3 3) ошибка в строке k : = 0; должно быть k: =2; - для делителей 1 и nошибка в строке k : = k + 3; должно быть k: =k+1, если число n - полный квадрат, то добавляется делитель кор.квадр(n).
Реши свою проблему, спроси otvet5GPT
-
Быстро
Мгновенный ответ на твой вопрос -
Точно
Бот обладает знаниями во всех сферах -
Бесплатно
Задай вопрос и получи ответ бесплатно
Популярно: Информатика
-
8923275218309.02.2022 00:34
-
фейс411.02.2023 00:51
-
zaobogdan02.07.2020 03:31
-
Sasha730129.11.2022 23:49
-
DashkaGamayunova01.02.2021 02:02
-
Kristina1605lps30.12.2021 03:21
-
Olechka7724.10.2020 10:04
-
EZno18.06.2021 10:25
-
kravchenjatkop00zs023.10.2020 06:29
-
toriblinova03.08.2020 20:09
Есть вопросы?
-
Как otvet5GPT работает?
otvet5GPT использует большую языковую модель вместе с базой данных GPT для обеспечения высококачественных образовательных результатов. otvet5GPT действует как доступный академический ресурс вне класса. -
Сколько это стоит?
Проект находиться на стадии тестирования и все услуги бесплатны. -
Могу ли я использовать otvet5GPT в школе?
Конечно! Нейросеть может помочь вам делать конспекты лекций, придумывать идеи в классе и многое другое! -
В чем отличия от ChatGPT?
otvet5GPT черпает академические источники из собственной базы данных и предназначен специально для студентов. otvet5GPT также адаптируется к вашему стилю письма, предоставляя ряд образовательных инструментов, предназначенных для улучшения обучения.