М
Молодежь
К
Компьютеры-и-электроника
Д
Дом-и-сад
С
Стиль-и-уход-за-собой
П
Праздники-и-традиции
Т
Транспорт
П
Путешествия
С
Семейная-жизнь
Ф
Философия-и-религия
Б
Без категории
М
Мир-работы
Х
Хобби-и-рукоделие
И
Искусство-и-развлечения
В
Взаимоотношения
З
Здоровье
К
Кулинария-и-гостеприимство
Ф
Финансы-и-бизнес
П
Питомцы-и-животные
О
Образование
О
Образование-и-коммуникации
PROvacaTOR1
PROvacaTOR1
26.01.2023 08:23 •  Информатика

Решите Б и Г. (если не сложно попробуйте объяснить как это решается)


Решите Б и Г. (если не сложно попробуйте объяснить как это решается)

👇
Ответ:
vladputilov451
vladputilov451
26.01.2023

ответ: б) ВБГА или 162.168.132.64

г) БГДВА или 104.28.239.65

Объяснение:

Для решения данной задачи следует помнить два правила: IP-адрес состоит из четырех десятичных чисел разделенных точками, интервал каждого десятичного числа от 0 до 255. Нам нужно соединить отрывки адреса(цифры и точки) таким образом, чтобы полученные числа не были больше 255.

Рассмотрим на примере б: у нас есть 4 отрывка, из которых нужно собрать адрес, состоящий из 4 чисел и 3 точек между ними.

Мы понимаем, что отрывок под буквой А(.64) не может быть в начале адреса, так как адрес не может начинаться с точки.

Отрывок под буквой Б(2.16) мог бы идти первым в адресе(т.к. все числа не превосходят 255), однако такое его использование не рационально по отношению к другим отрывкам, таким, как, например, отрывку В(16), который не имеет точек и, следовательно, становится очевидно, что его нужно приставить к какому-то отрывку, чтобы вместе они образовали не большее 255 число.

Давайте найдем пару для отрывка В: простым перебором, смотрим:

пара ВА возможна, но тогда адрес из следующих чисел сложить не получится(16.64 и на выбор остаются либо 2.16, либо 8.132, пробуем подставить первый вариант: 16.642.16 - ошибка, так как число 642>255, со вторым вариантом также) => адрес, начинающийся с ВА - невозможен;

пара ВГ так же невозможна, т.к. следующими возможными адресами будут два: либо 168.1322.16.64 - 1322 > 255 => невозможно, либо 168.132.642.16 - 642 > 255 => невозможно;

остается пара ВБ отходя от которой можно создать существующий адрес IP: 162.168.132.64, где 162 < 255, 168 < 168, 132 < 255, 64 < 255 => возможно;

P.S: если вы умеете мыслить, как программист, попробуйте представлять числа в данных задачах строками, не думайте о том, что числа можно складывать или еще что-то. Эти отрывки - просто набор символов(точек и цифр), из которых операция конкатинации создает адреса, которые уже можно проверять на соответствие условию х =< 255

4,4(24 оценок)
Ответ:
Котя534
Котя534
26.01.2023

а) ГВАБ

б) АБГВ

в) ВАБГ

г) ДАГБВ

4,6(12 оценок)
Открыть все ответы
Ответ:
Alpetrova7
Alpetrova7
26.01.2023
Напишу ответ, потому что:
1) Все же С++ изучают реже, чем Паскаль
2) Чтобы в очередной раз показать преимущества Паскаля над С-подобными языками для школьных задач.
Как говорится, "Имеющий глаза - да увидит!"

// PascalABC.NET 3.3, сборка 1555 от 21.10.2017
// Внимание! Если программа не работает, обновите версию!

begin
  var n:=ReadInteger('N=');
  for var i:=1 to n do begin
    var (flag,j,r):=(True,2,Round(Sqrt(i)));
    while flag and (j<=r) do
      if i mod j = 0 then flag:=false
      else j+=1;
    if flag then Print(i)
    end
end.

Пример
N= 150
1 2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149
4,4(67 оценок)
Ответ:
PomogiSPb
PomogiSPb
26.01.2023
#include <iostream>
#include <algorithm>
#include <vector>using namespace std;bool Has(const vector<int> &primeNumbers, int value)
{
  bool has = false;
  for (int prime_number : primeNumbers)
  {
    if (value % prime_number == 0)
    {
      has = true;
    }
  }
  return has;
}vector<int> GetPrimeNumbers(int i)
{
  vector<int> primeNumbers= { 2, 3 };
  for (int j = 4;j < i;j++)
  {
    if (!Has(primeNumbers, j))
    {
      primeNumbers.push_back(j);
    }
  }
  return primeNumbers;
}int main()
{
  int n;
  cin >> n;
  vector<int> prime_numbers = GetPrimeNumbers(n);
  for (int prime_number : prime_numbers)
  {
    cout << prime_number << endl;
  }
  cin >> n;
  return 0;
}
4,7(29 оценок)
Это интересно:
Новые ответы от MOGZ: Информатика
logo
Вход Регистрация
Что ты хочешь узнать?
Спроси Mozg
Открыть лучший ответ