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

Разработайте программу, которая вводит из файла, имя которого определяется в командной строке, слова и помещает их в два линейных односвязных списка : в первой - четные по порядку слова, во второй - нечетные. Затем находит в этих списках одинаковые слова и, если такие есть, удаляет их из списков. Слова из первого списка вывести в стандартный поток вывода, из второго - в файл, имя которого также определяется в командной строке. Решать на паскале решить подробно расписать весь ход решения

Показать ответ
Ответ:
foxi22
foxi22
24.08.2022 20:59
Function BigNum(n: integer): string;
{Генератор случайного числа из n цифр}
var
  c, s: string;
  i, k: integer;
begin
  Randomize;
  k := Random(9) + 1;
  Str(k, c);
  s := c;
  for i := 1 to n - 1 do
  begin
    k := Random(10);
    Str(k, c);
    s := s + c
  end;
  BigNum := s
end;

function SumDig(s: string): integer;
{Сумма цифр в числе}
var
  i, n, sum, err: integer;
begin
  sum := 0;
  for i := 1 to length(s) do
  begin
    Val(s[i], n, err);
    sum := sum + n
  end;
  SumDig := sum
end;

function Residue(s: string): integer;
{Возвращает остаток от деления числа в s на 18}
var
  n, sd, res9, res2, err: integer;
  odd1, odd2: Boolean;
begin
  sd := SumDig(s);
  res9 := sd mod 9;
  Val(s[length(s)], n, err);
  res2 := n mod 2;
  odd1 := (res9 mod 2) <> 0;
  odd2 := (res2 <> 0);
  if (odd1 and not odd2) or (not odd1 and odd2) then Residue := res9 + 9
  else Residue := res9
end;

var
  c: string;

begin
  c := BigNum(1000);
  writeln(c,#13#10,'Остаток от деления на 18 равен ', Residue(c))
end.

Тестовое решение:

3221915424975322923399502460812524529225375712837996380372955560234189270702379062282513315737071547764862568890398237871186353362182139742995552543884367658741829560716949497663481958872557099007598172783497999536087178826984948006420926538455756301942035589845898211516063937013863606448533769355643489588909747508128286297239467146038312854988616013646629224854150056080633230962334349031818700972765003200339826241970102416293235810632014869208245809165359601700391661996623220804842575428230306880758380343212880696782613365631634904645222111534961009813502561157888605055040272066063419013375096375636695376322940418437858178995380732947703268032557794787741637094210757062359003544768695429616517382280063142873709333561422845574162136379545354590728371075722857860156305301616725485589016055779858443331207045899737128103925063276738104327107115503162033931614476906153279190680955900379416370372010844088284335066847563774690881756900181208508120442555717049830267806565535426556043820118314
Остаток от деления на 18 равен 2
0,0(0 оценок)
Ответ:
SanyaLuckYouTube
SanyaLuckYouTube
03.09.2021 13:51
Function f(x: real): real;
begin
  f := 3 * sin(sqrt(x)) + 0.35 * x - 3.8
end;

var
  n: integer;
  a, b, c, fc, eps: real;

begin
  writeln('Введите границы интервала (a,b) и точность решения: ');
  readln(a, b, eps);
  n := 0;
  repeat
    c := (a + b) / 2;
    fc := f(c);
    if sign(fc) = sign(f(b)) then b := c
    else a := c;
    n := n + 1;
  until abs(a - b) <= eps;
  writeln('Найден корень уравнения х=', c, ' за ', n, ' итераций')
end.

Тестовое решение:

Введите границы интервала (a,b) и точность решения:
2 3 0.001
Найден корень уравнения х=2.2978515625 за 10 итераций
0,0(0 оценок)
Популярные вопросы: Информатика
Полный доступ
Позволит учиться лучше и быстрее. Неограниченный доступ к базе и ответам от экспертов и ai-bota Оформи подписку
logo
Начни делиться знаниями
Вход Регистрация
Что ты хочешь узнать?
Спроси ai-бота