Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
katafot
0 / 0 / 3
Регистрация: 16.07.2016
Сообщений: 47
#1

В массиве найти максимальный элемент и заменить им все нулевые элементы, с вызовом функции - C++

22.07.2016, 13:47. Просмотров 206. Ответов 8
Метки нет (Все метки)

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
#include <iostream>
using namespace std;
void Zamena(double a[], int n, double max)
{
    for (int i = 0; i < n; i++)
        
        if (a[i] > max)
        {
            a[i] = max;
        }
            
    for (int i = 0; i < n; i++)
        if (a[i] = 0)
            a[i] = max;
 
}
int main()
{
    double a[7],max=a[0];
    cout << "Vvedite massiv" << endl;
    for (int i = 0; i < 7; i++)
        cin >> a[i];
    Zamena(a, 7, max);
    cout << "Massiv:" << endl;
    for (int i = 0; i < 7; i++)
        cout << a[i] << endl;
    return 0;
 
 
}
Выдает одни нули
http://www.cyberforum.ru/cpp-beginners/thread731065.html
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.07.2016, 13:47
Я подобрал для вас темы с готовыми решениями и ответами на вопрос В массиве найти максимальный элемент и заменить им все нулевые элементы, с вызовом функции (C++):

В массиве заменить все отрицательные элементы на минимальный элемент, а все положительные – на максимальный
В массиве из 10 целых чисел заменить все отрицательные элементы на минимальный...

Одномерный массив. Найти наименьший элемент, все нулевые элементы заменить значением этого элемента
Ребят,помогите,пожалуйста, с массивом,вот задание: В массиве найти...

Найти в массиве максимальный элемент и заменить все вышестоящие на минимальный из последней строки
1. В массиве все элементы, стоящие выше максимального элемента, заменить на...

В массиве X(N) найти максимальный элемент массива и упорядочить по возрастанию все элементы
В массиве X(N) найти максимальный элемент массива и упорядочить по возрастанию...

В массиве Х (N) найти максимальный элемент массива и упорядочить по возрастанию все элементы
написать программу на языке С++. Задание: В массиве Х (N) найти максимальный...

8
zss
Модератор
Эксперт С++
6953 / 6515 / 4136
Регистрация: 18.12.2011
Сообщений: 17,193
Завершенные тесты: 1
22.07.2016, 14:01 #2
Цитата Сообщение от katafot Посмотреть сообщение
if (a[i] = 0)
Это присвоение нуля
C++
1
if (a[i] == 0)
0
katafot
0 / 0 / 3
Регистрация: 16.07.2016
Сообщений: 47
22.07.2016, 14:06  [ТС] #3
Тоже не правильный ответ выдает, числа ооочень большие
0
hoggy
Заблокирован
22.07.2016, 14:13 #4
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
#include <iostream>
#include <cassert>
 
using namespace std;
 
 
 
double FindMax(double a[], size_t n)
{
    assert(n!=0);
 
    double max_ = a[0];
    for (size_t i = 1; i < n; ++i)
        if (a[i] > max_)
            max_ = a[i];
    return max_;
}
 
 
void Zamena(double a[], int n, double what, double target)
{
    assert(n!=0);
    
    for (size_t i = 0; i < n; ++i)
        if (a[i] == what)
            a[i] = target;
 
}
int main()
{
    double a[7];
    cout << "Vvedite massiv" << endl;
    for (size_t i = 0; i < 7; ++i)
        cin >> a[i];
    
    const double max_ = FindMax(a, 7);
    
    Zamena(a, 7, 0, max_);
    cout << "Massiv:" << endl;
    for (size_t i = 0; i < 7; i++)
        cout << a[i] << endl;
}
1
zss
Модератор
Эксперт С++
6953 / 6515 / 4136
Регистрация: 18.12.2011
Сообщений: 17,193
Завершенные тесты: 1
22.07.2016, 14:17 #5
В будущем для экономии времени настоятельно советую освоить
http://www.cyberforum.ru/visual-studio/thread1262479.html
1
Peoples
1269 / 774 / 730
Регистрация: 06.02.2016
Сообщений: 2,082
Записей в блоге: 15
Завершенные тесты: 4
22.07.2016, 14:26 #6
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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <algorithm>
using namespace std;
void changer(int *a, int n) {
    int*  m=max_element(a,a+n);
    replace_copy(a,a+n,a,0,*m);
}
int main() {
    srand(time(NULL));
    const int n=7;
    int *a=new int[n];
    for(size_t i=0; i!=n; i++) {
        cin>>a[i];
    }
    cout<<endl;
    changer(a,n);
    for(size_t i=0; i!=n; i++) {
        cout<<a[i]<<" ";
    }
delete[]a;
    return 0;
}
0
JIawliet
78 / 78 / 31
Регистрация: 20.07.2016
Сообщений: 327
Завершенные тесты: 2
22.07.2016, 16:52 #7
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
#include <iostream>
#include <algorithm>
 
//================================================================
const unsigned SZ = 7;
 
//================================================================
template <typename T, unsigned N>
void changeElements (T (&arr)[N], const T& max)
{
    auto it = std::begin(arr);
 
    while (true)
    {
        it = std::find(it, std::end(arr), 0);
 
        if (it != std::end(arr))
            *it = max;
        else 
            break;
    }
}
 
 
//================================================================
int main ()
{
    double arr[SZ];
 
    std::cout << "Please enter " << SZ << " numbers: ";
    for (auto& j : arr)
        if (!(std::cin >> j))
        {
            std::cerr << "Input Error!" << std::endl;
            return -1;
        }
 
    changeElements(arr,
                   *std::max_element(std::begin(arr), std::end(arr)));
 
    for (const auto& j : arr)
        std::cout << j << " ";
    std::cout << std::endl;
 
    return 0;
}
0
katafot
0 / 0 / 3
Регистрация: 16.07.2016
Сообщений: 47
22.07.2016, 17:50  [ТС] #8
У меня возник вопрос, в этой строке

C++
1
a[i] = target;
чем отличается от
C++
1
target = a[i];
??
0
Peoples
1269 / 774 / 730
Регистрация: 06.02.2016
Сообщений: 2,082
Записей в блоге: 15
Завершенные тесты: 4
22.07.2016, 17:56 #9
katafot, значение присваивается левому операнду, то есть элементу массива
1
22.07.2016, 17:56
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.07.2016, 17:56
Привет! Вот еще темы с решениями:

Найти сумму элементов, кратных заданному; найти минимальный элемент; все чётные элементы заменить на максимальный (STL)
Используя контейнеры и алгоритмы стандартной библиотеки шаблонов, решить...

Найти максимальный элемент массива, заменить все положительные элементы массива максимальным
Создать одномерный массив из 10 случайных целых чисел из интервала от -10 до...

Найти максимальный элемент массива, заменить все положительные элементы массива максимальным
Создать одномерный массив из 10 случайных целых чисел из интервала от -10 до...

Найти максимальный элемент и заменить им первый элемент строки в двумерном массиве
В матрице X(4,5) в каждой строке найти максимальный элемент и заменить им...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru