chudaevavera29
25.02.2023 07:00

с тестом по программированию 8. Переменные имеют следующие значения: int a = 3, b = 4, c = 0, d = '1'.
Какой результат получится после использования выражения: c = a < b ;
9. Переменные имеют следующие значения: int a = 3, b = 4, c = 0, d = '1'.
Какой результат получится после использования выражения: c < b && a > 3
10. Переменные имеют следующие значения: int x=0, a = 3, b = 4, c = 0, d = '1'.
Какой результат получится после использования выражения: x= c < b && a > 3 ;
11. Переменные имеют следующие значения: int a = 3, b = 4, c = 0, d = '1'.
Какой результат получится после использования выражения: c = a++
12. Переменные имеют следующие значения: int x=0, a = 1, b = 2, c = 3;
Какой результат получится после использования выражения: x = a - b * c;
13. Переменные имеют следующие значения: int x=0, a = 1, b = 2, c = 3;
Какой результат получится после использования выражения: x=c / a * b;
14. Переменные имеют следующие значения: int x=0, a = 1, b = 2, c = 3;
Какой результат получится после использования выражения: x= a++ + --b;
15. Переменные имеют следующие значения: int i = 0, j = 1, k = 2;
Какой результат получится после использования выражения: k= i && j;т
16. Переменные имеют следующие значения: int i = 0, j = 1, k = 2;
Какой результат получится после использования выражения: k = !!i;
17. Переменные имеют следующие значения: int i = 0, j = 1, k = 2;
Какой результат получится после использования выражения: j= i || !k;

Нажмите на рекламу ниже и сразу увидите ответ
Популярные вопросы:
Ответ:
луч16
23.05.2023 18:15

Переводим третий байт IP и адреса сети в двоичную систему

50 - 110010

48 - 110000

Так как это байт (а в байте 8 бит), допишем два незначащих нуля к получившимся числам:

00110010 - IP

00110000 - адрес сети

Адрес сети получается с применения поразрядной конъюнкции к маске и IP, проще говоря, при перемножении разрядов маски и IP-адреса. И в маске всегда сначала идут только единицы, а потом только нули. То есть можно записать так:

- маска

00110010 - IP

00110000 - адрес сети

где иксы в маске и цифры в IP-адресе - множители, а разряды адреса сети - произведение.

На 3 и 4 месте в маске однозначно должны быть единицы, т.к. если там будут нули, то и в адресе сети будут нули. Плюс к этому, в маске всегда сначала идут только единицы, а потом только нули, то есть можно записать так:

1111 - маска

00110010 - IP

00110000 - адрес сети

Второй справа разряд IP-адреса - единица, а адреса сети - ноль, значит в маске может быть только ноль:

1111хх00 - маска

00110010 - IP

00110000 - адрес сети

Оставшиеся два икса могут быть и единицами, и нулями. Нужно наименьшее возможное значение, значит поставим на их место нули:

11110000 - маска

00110010 - IP

00110000 - адрес сети

То есть третий байт маски 11110000, переведём в десятичную - получим 240.

0,0(0 оценок)
Ответ:
Sergei74
16.12.2022 06:58
Задача, аналогичная той, которую публиковали вчера. Только цикл repeat заменяем на while.

Сначала немного математики.
\displaystyle a_n= \frac{n!}{(2n)!}=\frac{\prod_{i=1}^ni}{\prod_{i=1}^{2n}i}=\frac{\prod_{i=1}^ni}{\prod_{i=1}^{n}i\times\prod_{i=n+1}^{2n}i}=\frac{1}{\prod_{i=n+1}^{2n}i}; \quad n\in\mathbb N
О модуле тут смысла нет говорить, поскольку все an - суть положительные величины на интервале (0;1).

uses Crt;

function ai(n:integer):real;
var
  i:integer;
  p:real;
begin
  p:=1;
  for i:=n+1 to 2*n do p:=p*i;
  ai:=1/p
end;

var
  i:integer;
  eps,s,an:real;
begin
  ClrScr;
  Write('eps='); Read(eps);
  s:=0; i:=1; an:=eps+1;
  while an>=eps do begin
     an:=ai(i);
     if an>=eps then begin s:=s+an; Inc(i) end
  end;
  Writeln('s=',s);
  ReadKey
end.

Тестовые решения:
eps=0.07
s= 5.8333333333E-01

eps=0.000001
s= 5.9229647667E-01

eps=1e-8
s= 5.9229653448E-01

Для контроля результата можно отметить, что сумма первых 1000 членов ряда равна приблизительно 5.922965365Е-01

Если раздражает наличие функции, можно и без нее:
uses Crt;

var
  i,j:integer;
  eps,s,an,p:real;
begin
  ClrScr;
  Write('eps='); Read(eps);
  s:=0; i:=1; an:=eps+1;
  while an>=eps do begin
    p:=1;
    for j:=i+1 to 2*i do p:=p*j;
    an:=1/p;
    if an>=eps then begin s:=s+an; Inc(i) end
  end;
  Writeln('s=',s);
  ReadKey
end.
0,0(0 оценок)
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота