1 / 1 / 0
Регистрация: 18.01.2015
Сообщений: 57
1

Написать функцию поиска минимального числа только при условии отсутствия бита

16.02.2025, 22:44. Показов 1065. Ответов 7
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте.
Задание: Написать функцию поиска минимального числа только при условии отсутствия бита. Функция действует всегда, т.е. если поменялись числа переменных Nar или появился Alm, то и номер элемента должен быть выведен другой.

Nar[0..3] - Целое число
Found_Min_Nar - Получившийся номер элемента
Alm[0..3] - Булево число

Вот код:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
// Для первого захода в проверки
Min_el := Nar[0];
 
// Цикл поиска минимального числа
FOR i := 0 TO 3 DO
    
    // Наработка меньше Минимальной и Нет аварий
    IF (Nar[i] < Min_el) AND NOT Alm[i] THEN
            
        // Присвоить наработку как минимальную
        Min_el := Nar[i];
            
        // Сохранить номер элемента
        elem := i;
                    
    END_IF
 
END_FOR
 
// Вывод номера с минимальной наработкой
Found_Min_Nar := elem;
Программа работает, но с ошибкой: если возникла ситуация: (Nar[i] < Min_el) AND Alm[i], то не выводится другой номер элемента с минимальным Nar при отсутствии Alm. Не очень понимаю, как правильнее будет это прописать.
Помогите, пожалуйста.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.02.2025, 22:44
Ответы с готовыми решениями:

Написать функцию поиска максимального и минимального элементов одномерного массива
Не сочтите за наглость ребята, но заставили на старость лет учиться, вообше то по профессии электронщик и ремонтирую железо компов много...

Написать функцию поиска максимального и минимального элементов одномерного массива
Задание: Написать функцию поиска максимального и минимального элементов одномерного массива. В основной программе вызвать эту функцию для...

Написать функцию поиска максимального и минимального элементов одномерного массива
Задание:Написать функцию поиска максимального и минимального элементов одномерного массива. В основной программе вызвать эту функцию для...

7
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8584 / 4431 / 1657
Регистрация: 01.02.2015
Сообщений: 13,746
Записей в блоге: 9
16.02.2025, 22:53 2
У Вас инициализация Min_el без проверки достоверности (Alm) элемента с индексом 0.
Сделайте сначала поиск начального элемента для инициализации с учётом этого Alm.
1
1 / 1 / 0
Регистрация: 18.01.2015
Сообщений: 57
16.02.2025, 23:11  [ТС] 3
ФедосеевПавел, типа такого? Извините, у меня уже глаз замылился и плохо соображаю.
При таком условии тоже не работает момент, когда Nar > Min_el, а аварий нет.

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// Цикл поиска минимального числа
FOR i := 0 TO 3 DO
    IF NOT Alm[0] THEN
 
        Min_el := Nar[0];
 
    END_IF
    
    // Наработка меньше Минимальной и Нет аварий
    IF (Nar[i] < Min_el) AND NOT Alm[i] THEN
            
        // Присвоить наработку как минимальную
        Min_el := Nar[i];
            
        // Сохранить номер элемента
        elem := i;
                    
    END_IF
 
END_FOR
 
// Вывод номера с минимальной наработкой
Found_Min_Nar := elem;
0
Модератор
Эксперт по электронике
 Аватар для ФедосеевПавел
8584 / 4431 / 1657
Регистрация: 01.02.2015
Сообщений: 13,746
Записей в блоге: 9
16.02.2025, 23:36 4
Только не Alm[0] в первом цикле.
И предусмотреть вариант, что все Alm не позволяют выбрать.
1
1 / 1 / 0
Регистрация: 18.01.2015
Сообщений: 57
18.02.2025, 16:31  [ТС] 5
ФедосеевПавел, спасибо за объяснение, но не очень понятно, как реализовать.
0
111 / 107 / 12
Регистрация: 30.10.2014
Сообщений: 305
18.02.2025, 18:52 6
Лучший ответ Сообщение было отмечено Nakahara как решение

Решение

// Для первого захода в проверки
Min_el := Nar[0]+1;

или

// Наработка меньше Минимальной и Нет аварий
IF (Nar[i] <= Min_el) AND NOT Alm[i] THEN
1
Эксперт JavaЭксперт по электронике
 Аватар для wizard41
3211 / 2369 / 558
Регистрация: 04.09.2018
Сообщений: 7,762
Записей в блоге: 3
18.02.2025, 19:21 7
Nakahara, видимо, компилятор как-то странно воспринимает скобки в условии. Пробуй так:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
Min_el := 100_000;
elem := -1;
 
FOR i := 0 TO 3 DO
    IF NOT Alm[i] THEN
        IF (Nar[i] < Min_el) THEN
            Min_el := Nar[i];
            elem := i;
        END_IF
    END_IF
END_FOR
 
Found_Min_Nar := elem;
1
1 / 1 / 0
Регистрация: 18.01.2015
Сообщений: 57
18.02.2025, 19:29  [ТС] 8
Олег_ и wizard41, большое спасибо вам!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.02.2025, 19:29
Помогаю со студенческими работами здесь

Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве
Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве.

Написать функцию поиска минимального элемента списка по одному из выбранных полей
FindMin – функция поиска минимального элемента списка по одному из выбранных полей. написать функцию

Написать рекурсивную функцию поиска минимального элемента одномерного вещественного массива
Написать рекурсивную функцию поиска минимального элемента одномерного вещественного массива. #include &lt;stdio.h&gt; #include...

Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве
Написать рекурсивную функцию для поиска минимального элемента в одномерном массиве

Создать задачу в crontab при условии её отсутствия
как можно реализовать вот эту мысль? : if &lt;нет задачи в crontab'е&gt;; then &lt;создаем ее&gt; else &lt;если есть, то не трогать эту...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

Новые блоги и статьи
Циклы for в Python
py-thonny 17.03.2025
Существует множество ситуаций, когда нам нужно выполнить одно и то же действие несколько раз. Цикл for в Python — настоящий рабочий конь для большинства программистов. Если вам нужно пройтись по всем. . .
Предсказание ветвлений - путь к высокопроизводи­тельному C++
NullReferenced 17.03.2025
В высокопроизводительном программировании на C++ каждый такт процессора на счету. Когда речь заходит о разработке систем с низкой задержкой — будь то высокочастотная торговля, обработка потоковых. . .
Паттерн CQRS в C#
UnmanagedCoder 17.03.2025
Создание сложных корпоративных приложений часто требует нестандартных подходов к архитектуре. Один из таких подходов — паттерн CQRS (Command Query Responsibility Segregation), предлагающий простую,. . .
Паттерн Цепочка ответственности в C#
UnmanagedCoder 17.03.2025
Цепочка ответственности — это поведенческий паттерн проектирования, который позволяет передавать запросы последовательно по цепочке потенциальных обработчиков, пока один из них не обработает запрос. . . .
Создаем микросервисы с NestJS, TCP и Typescript
run.dev 17.03.2025
NestJS — фреймворк, который значительно упрощает создание серверных приложений на Node. js. Его прелесть в том, что он комбинирует концепции ООП, функционального программирования и предлагает. . .
Гексагональная архитектура со Spring Boot
Javaican 17.03.2025
Если вы когда-нибудь сталкивались с ситуацией, когда внесение простых изменений в базу данных или пользовательский интерфейс заставляло вас переписывать весь код, то вы точно оцените элегантность. . .
Позиционировани­е Kafka Consumer и Seek-операции
Javaican 17.03.2025
Что же такое Consumer Seek в Kafka? По сути, это API-метод, который позволяет программно указать, с какой позиции (offset) Consumer должен начать или продолжить чтение данных из партиции. Без этого. . .
Python NumPy: Лучшие практики и примеры
py-thonny 17.03.2025
NumPy (Numerical Python) — одна из ключевых библиотек для научных вычислений в Python. Она превращает Python из просто удобного языка общего назначения в среду для проведения сложных математических. . .
Java Micronaut в Docker: контейнеризация с Maven и Jib
Javaican 16.03.2025
Когда речь заходит о микросервисной архитектуре на Java, фреймворк Micronaut выделяется среди конкурентов. Он создан с учётом особенностей облачных сред и контейнеров, что делает его идеальным. . .
Управление зависимостями в Java: Сравнение Spring, Guice и Dagger 2
Javaican 16.03.2025
Инъекция зависимостей (Dependency Injection, DI) — один из фундаментальных паттернов проектирования, который радикально меняет подход к созданию гибких и тестируемых Java-приложений. Суть этого. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru