Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/47: Рейтинг темы: голосов - 47, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 04.11.2010
Сообщений: 11

Найти количество элементов массива, равных 0

13.11.2010, 21:49. Показов 8692. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер всем.
У меня есть задание:
1.Разработать алгоритм программы, которая решает Ваше индивидуальное задание (варианты индивидуальных заданий приведены ниже; номер варианта выбирается в соответствии со своим номером в списке группы).
2.На основе разработанного алгоритма в среде Visual Studio 2005 написать консольную программу на языке C++ с использованием динамических массивов вещественных чисел размера n (n вводит пользователь).

Само задание :
1.найти кол-во элементов массива,равных 0.
2.Найти сумму элементов массива,расположенных после минимального элемента.
3.Упорядочить элементы массива по возрастанию модулей элементов.

 Комментарий модератора 
П.5.16.Правил
Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.

Знаю,что может навязываюсь,но сколько читал,так и не сумел создать код.Буду очень благодарен человеку,кто сможет помочь мне написать код.Спасибо.
Код нужно написать используя либо Cin,cout,либо printF,scanF.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.11.2010, 21:49
Ответы с готовыми решениями:

Одномерные массивы и указатели (найти количество элементов массива, равных 0, сумму элементов массива...)
Помогите пожалуйста разработать программу и реализовать интуитивный понятный интерфейс (используя формы).При написании программы можно...

Найти количество элементов массива, равных среднему арифметическому элементов массива
Найти количество элементов массива, равных среднему арифметическому элементов массива. temp = 10; temp = 15; temp = 20; ...

Найти количество элементов массива, равных 0
1. Знайти кількість елементів масиву, рівних 0. 2. Знайти суму елементів масиву, розташованих після мінімального елемента. 1. Найти...

9
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
13.11.2010, 21:58
могу на C написать
надо?

Добавлено через 2 минуты
1.
C
1
2
3
 
for (int i=0; i<n; i++)
if (massiv[i]==0) kol_vo++;
kol_vo объявишь как инт и обнулишь, т.е.
C
1
int kol_vo=0;
0
0 / 0 / 0
Регистрация: 04.11.2010
Сообщений: 11
13.11.2010, 21:59  [ТС]
Мне нужно на С++
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
13.11.2010, 22:03
2
C
1
2
3
4
5
6
7
8
int min=massiv[0];
int k=0;
int sum=0;
for (int j=1;j<n;j++)
if (min>massiv[j]) { min=massiv(j); k=j;} // ischem min element
 
for (int kk=k+1;kk<n;kk++)
sum+=massiv[kk];

n - длина массива

Цитата Сообщение от alextsi Посмотреть сообщение
Мне нужно на С++

а что с С не подойдет или сам подкорректировать такие лугкие задание не сожешь
0
0 / 0 / 0
Регистрация: 04.11.2010
Сообщений: 11
13.11.2010, 22:06  [ТС]
я дуб в этом...учусь на телекомуникационщика...ты можешь написать мне целый код пожалуйста ?
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
13.11.2010, 22:08
Цитата Сообщение от alextsi Посмотреть сообщение
я дуб в этом...учусь на телекомуникационщика...ты можешь написать мне целый код пожалуйста ?
код с c C подойдет
третью задачу писать на С???
0
0 / 0 / 0
Регистрация: 04.11.2010
Сообщений: 11
13.11.2010, 22:13  [ТС]
с++ все задачи...
0
go
Эксперт С++
3646 / 1378 / 243
Регистрация: 16.04.2009
Сообщений: 4,526
13.11.2010, 22:14
Цитата Сообщение от alextsi Посмотреть сообщение
с++ все задачи...
а сам не пробовал писать???

вставь мой код в студиа и проверь!!! удачи...
1
 Аватар для Raizer
5 / 5 / 4
Регистрация: 11.10.2009
Сообщений: 24
13.11.2010, 22:24
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Вот код на С++

C++
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
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <iostream>
using namespace std;
 
int main()
{
        const int n = 10;
        int mas[n] = {5, -2, 8, 0, 5, -3, 0 , 2, 4, 9};
        
        int null = 0;
        for (int i = 0; i < n; i++)
        {
            if (mas[i] == 0) null++;
        }
        cout <<"Null: " << null <<endl;
 
        int min = mas[0];
        int minIndex = 0;
        for (int i = 0; i < n; i++)
        {
            if (min > mas[i]) 
            {
                min = mas[i];
                minIndex = i;
            }
        }
        
        int sum = 0;
        for (int i = minIndex + 1; i < n; i++)
        {
            sum += mas[i];
        }
        cout <<"Summa: " << sum <<endl;
 
        int temp;
        for (int i = 0; i < n; i++)
        {
            for (int j = 0; j<=n - i ; j++)
            {
                if (abs(mas[j]) > abs(mas[j+1]))
                {
                    temp = mas[j];
                    mas[j] = mas[j+1];
                    mas[j+1] = temp;
                }
            }
        }
        
    
        cout <<"Massiv: \n";
        for (int i = 0; i < n; i++)
        {
             cout <<mas[i] <<" ";
        }
        cin.get();
        return 0;
}
Или необходимо создать три программы
0
Эксперт С++
5058 / 3118 / 271
Регистрация: 11.11.2009
Сообщений: 7,044
13.11.2010, 22:37
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

C++
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <iostream>
#include <cmath>
 
int countNull(double *, int);
double sumAfterMin(double *, int);
void absBubbleSort(double *, int);
 
int main()
{
    double *arr;
    int n;
 
    setlocale(LC_ALL, "Rus"); // Включием русскую локаль
 
    // Вводим количество элементов
    std::cout << "Введите n: ";
    std::cin >> n;
 
    arr = new double [n]; // Выделяем память под массив из n элементов
 
    // Вводим элементы массива
    for (int i = 0; i < n; i++)
    {
        std::cout << "arr[" << i << "] = ";
        std::cin >> arr[i];
    }
 
    std::cout << std::endl << "Количество элементов массива, равных нулю: " << countNull(arr, n);
    std::cout << std::endl << "Сумма элементов массива, расположенных после минимального: " << sumAfterMin(arr, n);
    std::cout << std::endl << "Исходный массив: ";
 
    for (int i = 0; i < n; i++)
        std::cout << arr[i] << "  ";
 
    absBubbleSort(arr, n);
 
    std::cout << std::endl << "Массив, отсортированный по возрастанию модулей элементов: ";
 
    for (int i = 0; i < n; i++)
        std::cout << arr[i] << "  ";
 
    std::cout << std::endl;
 
    delete [] arr; // Очищаем память
 
    std::cin.get();
    return 0;
}
 
// Функция считает количество элементов массива, равных нулю
int countNull(double *arr, int n)
{
    int count = 0; // Счётчик нулевых элементов
 
    // Бежим по массиву
    for (int i = 0; i < n; i++)
        if (arr[i] == 0.0) // Если очередной элемент равен нулю
            count++; // Увеличиваем счётчик
 
    return count; // Возвращаем полученный счётчик
}
 
// Функция вычисляет количество элементов массива, расположенных после минимального элемента
double sumAfterMin(double *arr, int n)
{
    int minIndex = 0;
    double sum = 0.0;
 
    // Ищем индекс минимального элемента
    for (int i = 1; i < n; i++)
        if (arr[minIndex] > arr[i]) // Если очередной элемент с очередным индексом меньше элемента с ранее найденным индексом
            minIndex = i; // Делаем текущий индекс индексом минимального элемента
 
    // Складвыем все элементы, расположенные после минимального
    for (int i = minIndex + 1; i < n; i++)
        sum += arr[i];
 
    return sum; // Возвращаем полученную сумму
}
 
// Сортировка массива по возрастанию модулей элементов
void absBubbleSort(double *arr, int n)
{
    // Бежим по массиву
    for (int i = 0; i < n; i++)
    {
        for (int j = n - 1; j > i; j--)
        {
            // Если модуль левого элемента больше модуля правого элемента
            if (fabs(arr[j - 1]) > fabs(arr[j]))
            {
                // Меняем элементы местами
                double temp = arr[j - 1];
                arr[j - 1] = arr[j];
                arr[j] = temp;
            }
        }
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.11.2010, 22:37
Помогаю со студенческими работами здесь

Найти количество элементов массива, равных 0
В одномерном массиве, состоящем из действительных элементов, вычислить: 1) количество элементов массива, равных 0; 2) сумму частей...

Найти количество элементов массива, равных 0
Хлопцы патрэбна дапамога!Буду вельмі ўдзячны!:) Условие:При написании программ использовать динамические массивы. Размерность массивов...

Найти количество элементов в этих массива равных первому элементу массива S
Даны целочисленные массивы S и T с разным количеством элементов. Найти количество элементов в этих массива равных первому элементу массива...

Найти количество элементов массива равных нулю
С одномерным массивом, состоящим из n вещественных элементов, произвести следующие операции: 1) найти количество элементов массива,...

Найти количество элементов массива, равных нулю
Очень прошу помочь составить код (или направить мысли в правильное русло). Необходимо решить следующую поставленную задачу: В одномерном...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru