Форум программистов, компьютерный форум, киберфорум
Pascal ABC
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/15: Рейтинг темы: голосов - 15, средняя оценка - 4.73
 Аватар для Дмитрий ДАК
1 / 1 / 0
Регистрация: 07.01.2019
Сообщений: 39

Найти максимальный из двузначных чисел и минимальный из трехзначных.

06.03.2020, 22:30. Показов 3295. Ответов 2

Студворк — интернет-сервис помощи студентам
Дано условие задачи:
{На вход в первой строке подается целое положительное число n,
а во второй строке - массив из n неотрицательных целых чисел.
Выполнив однократный просмотр массива, вывести одно из трёх чисел:
максимальный двухзначный элемент, если двухзначных элементов в массиво больше чем трёхзначных:
минимальный трёхзначный элемент массива, если трехзначных элементов в массиве больше чем двухзначных;
число 0, если массив содержит одинаковое количество двухзначных и трёхзначных элементов}
Можете помочь с написанием/исправлением кода?
Как я написал код:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
program Massiv;
type TDMassiv = record
  intMassiv : array of Integer // Создали тип "динамический массив"
end;
var 
  N, I, K, H, Min : Integer;
A : TDMassiv; // Создали переменную A нового типа TDMassiv
Begin
 Assign(F, input.txt)
 Assign(G, output.txt); Rewrite(G);
 Randomize;
 Read(F, N); // 1 строка файла 999 чисел
 SetLength(A, N) // Определяем, что массив А будет размера N элементов.
 for I=1 to N do
   begin
     A[I] := Random(999); // Заполняем массив случайными числами [0..999]
   end;
 K := 0; // k - счетчик трехзначных чисел
 for I=1 to N do
   begin
     if (A[I] >= 100) AND (A[I] <= 999) AND (I = 100) then
       Min := A[I]
       //K := K+1; // Считаем трехзначные числа
     if Min > A[I] then
       Min := A[I]
   end;
   Write(G,Min);
 H := 0; // h - счетчик двузначных чисел
 for I=1 to N do
   begin
     if (A[I] >= 10) AND (A[I] <= 99) AND (I = 100) then
      Min := A[I]
      //H := H+1; // Считаем двузначные числа
      if Min > A[I] then
       Min := A[I]
   end;
   Write(G, Min);
 if K := H then
   Writeln ('0') 
    else 
   Writeln('Количество чисел ', Min); // Выводим посчитанное количество чисел на экран
   Write(G, 0);
END.
Код не работает.
P.S. На форуме я находил ранее похожие задачи, но там было либо на поиск одного минимального, либо просто на вывод массива. Одну из частей этих ранее написанных задач я и вставил в свой код, но я всё равно не знаю как делать дальше.
Основные вопросы по задаче:
1) Я сделал через считывание 1 строки, в которой находится число 999, но при этом я не написал 2 строку, где написал бы свои рандомные числа из массива 999. Как мне сделать, чтобы массив считывался не рандомно и не просто 999, но приэтом читал конкретные введённые мною числа из 2й строки файла?
2)Как сделать разные циклы с min и max и 0, чтобы в конце во второй файл выводилось только 1 число из этих трёх?
3) Как сделать сравнение количеств элементов min и max, чтобы после сравнения выводилось не количество нужных элементов, а конкретное число?
Заранее спасибо за помощь
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.03.2020, 22:30
Ответы с готовыми решениями:

Дано шесть чисел. Необходимо найти разность суммы трехзначных чисел и суммы двузначных чисел
Дано шесть чисел. Необходимо найти разность суммы трехзначных чисел и суммы двузначных чисел. Пример: input 6 5 10 10 10 100 100 100 ...

Вводится 15 чисел.Найти максимальный элемент среди положительных трехзначных чисел и произведение последних трех
Вводится 15 чисел.Найти максимальный элемент среди положительных трехзначных чисел и произведение последних трех.

найти максимальный элемент среди трехзначных чисел
1. вводится 16 чисел. найти максимальный элемент среди трехзначных чисел и среднее арифметическое четных. 2. вводится текст. конец ввода...

2
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,059
07.03.2020, 10:02
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

А для вашей задачи вообще массив нужен?
Вам только нужны два счётчика и две переменные под максимальное двузначное и минимальное трёхзначное…
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
var
  i, n, count2, max2, count3, min3 : Integer;
begin
  ReadLn(n);
  count2:=0; max2:=0;
  count3:=0; min3:=1000;
  for i:=1 to n do
    begin
      Read(n);
      
      if (n>9) and (n<100) then
        begin
          inc(count2);
          if n>max2 then max2:=n;
        end;
      
      if (n>99) and (n<1000) then
        begin
          inc(count3);
          if n<min3 then min3:=n;
        end;
    end;
    
  if count2=count3 then
    WriteLn(0)
  else if count2>count3 then
    WriteLn(max2)
  else
    WriteLn(min3);
end.
Добавлено через 1 минуту
P.S. Правила форума запрещают создание тем с бессмысленным названием!
1
 Аватар для Дмитрий ДАК
1 / 1 / 0
Регистрация: 07.01.2019
Сообщений: 39
07.03.2020, 10:26  [ТС]
Спасибо.
Я хотел написать заголовок с точным описанием проблемы, но постоянно выскакивало окно: что возникли ошибки и в заголовке используются одновременно и английские и русские буквы, хотя это не так
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.03.2020, 10:26
Помогаю со студенческими работами здесь

Найти максимальный элемент среди положительных трехзначных чисел и произведение последних трех
Вводится не менее 15 чисел. Конец ввода - 0. Найти максимальный элемент среди положительных трехзначных чисел и произведение последних трех

Найти минимальный и максимальный элементы и их координаты, поменять местами минимальный и максимальный элемент
3) В матрице размером n на m (1&lt;n, m&lt;10) (ввод n, m и матрицы с клавиатуры) найти минимальный и максимальный элементы и их координаты,...

В массиве Y(N) вещественных чисел найти найти максимальный и минимальный элементы и их индексы
В массиве Y(N) вещественных чисел найти найти максимальный и минимальный элементы и их индексы. Если индекс максимального элемента больше...

Найти максимальный и минимальный элементы среди неповторяющихся чисел
дан целочисленный массив X=(x1,x2,...xn), в котором могут быть одинаковые числа. Найти максимальный и минимальный элементы среди ...

В матрице вещественных чисел X(n*n) найти максимальный и минимальный элементы
Помогите нужно написать программу, сам не успеваю помогите кто может. В матрице вещественных чисел X(n*n) найти максимальный и ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru