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

Вывести сообщение о том, что все элементы в массиве равны

08.09.2011, 11:40. Показов 11718. Ответов 29
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте... суть проблемы состоит в том, что я не знаю, как вывести сообщение о том, что все элементы массива равны между собой.
Задача заключается в том, чтобы найти сумму элементов до минимального элемента массива, а в случае, если все элементы равны, то есть все минимальные (например только нули или только единицы) - вывести сообщение об этом. А так же если минимальный элемент стоит первым в массиве. ( например первый элемент 1, а все остальные больше 1) то естественно сумма будет равна 0, поэтому мне нужно и в этом случае вывести на экран сообщение...

вот код:
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
#include <iostream>
using namespace std;
 
void main()
{
    int*arr;
    setlocale (0, "rus");
    int n;
    cout<<"Введите размерность массива: ";
    cin>>n;
    cout<<"\n Введите элементы массива:";
    arr=new int[n];
    for(int i=0; i<n; i++)
    {
        cout<<"\n Элемент № "<<i<<" = ";
        cin>>arr[i];
    }
    int min=arr[0];
    int ind=0;
 
    for(int i=0; i<n; i++)
 
    {
       if(arr[i]<min)
       {
          min=arr[i];
          ind=i;
       }
       
    }
    int sum=0;
    for(int i=0; i<ind; i++)
    {
 
    {
          sum+=arr[i];
    }
    
    }
    cout<<"Min= "<< min <<'\n';
    cout<<"Sum= "<< sum <<'\n';
  system ("pause");
}
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.09.2011, 11:40
Ответы с готовыми решениями:

Нужно вывести сообщение о том, что все элементы массива одинаковые
b:=a; for i:=1 to n do begin for j:=1 to m do if b=a then t3:=true; end; Помогите пожалуйста, уже не знаю, что делать......

Заполнить матрицу следующим образом: элементы побочной диагонали равны 0, все остальные элементы равны 1
Заполнить целочисленную матрицу А размером 10Х10, так чтобы каждый элемент на побочной диагонали равен 0, все остальные элементы равны 1.

Напишите подпрограмму, которая в массиве заменит все элементы, у которых 1-я и последняя цифры равны на 0
Две массив, заполненный случайными натуральными числами в диапазоне от 1 до 30000. Напишите подпрограмму, которая в этом массиве...

29
Кошковед
 Аватар для co6ak
521 / 509 / 63
Регистрация: 12.04.2010
Сообщений: 1,390
08.09.2011, 12:06
самый просто способ - сделай bool check = false;
если твое условие выполняется - делать истиной.
в конце проверки смотреть, true или false
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 12:13
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
#include <iostream>
using namespace std;
 
int main()
{
    int * arr, n;
 
    cout << "Array size:\n>";
    cin >> n;
 
    arr = new int [n];
 
    cout << "Values:\n>";
 
    for( int i = 0; i < n; i++ )
        cin >> arr[i];
 
    cout << "Done. Last accepted element is " << arr[ n-1 ] << "\n\n";
 
    int min = arr[0],
        min_id = 0,
        summ = 0;
 
    bool allEqual = true;
 
    for( int i = 0; i < n; i++ )
    {
        if( arr[i] < min )
        {
            min = arr[i];
            min_id = i;
            allEqual = false;
        }
 
        summ += arr[i];
    }
 
    if( allEqual )
        cout << "All elements are equal";
    else
        cout << "Minimal element is arr[" << min_id << "] == " << min;
 
    cout << "\nSumm = " << summ << '\n';
 
    delete [] arr; // освобождать память не забывайте!
 
    return 0;
}
Вывод
Array size:
>5
Values:
>-1 -1 -1 -1 -1
Done. Last accepted element is -1

All elements are equal
Summ = -5


Добавлено через 33 секунды

Не по теме:

co6ak, мысли читаете? :)

0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
08.09.2011, 12:43
Код и скриншоты работы
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
#include <iostream>
#include <windows.h>//нужен моей студии для подключения system ("pause")
 
using namespace std;
 
//Руссификация
ostream& operator<<(ostream &stream,char* s){
    for(char* ps=s; *ps; ps++){
        if(*ps=='ё')
            stream<<char(241);
        else if(*ps=='Ё')
            stream<<char(240);
        else if(*ps>=-64 && *ps<=-17)           
            stream<<char(*ps+64+128);
        else if(*ps<0)
            stream<<char(*ps+64+176);
        else
            stream<<*ps;
    }
    return stream;
}
 
int GetMin(int n, int * arr);
 
int main()
{
    bool bEqual = true;
    cout<<"Введите размерность массива: ";
    int n;cin>>n;
    cout<<"\tВведите элементы массива:\r\n";
    int * arr = new int[n];
    
    int i = 0,iMin,iSum = 0;
    cout<<"Элемент # "<<i + 1<<" = ";
    cin>>arr[i];
    for(i = 1; i < n; i++)
    {
        cout<<"Элемент # "<<i + 1<<" = ";
        cin>>arr[i];
        //Проверяем одинаковость всех элементов ещё при вводе
        if(arr[i] != arr[i - 1])
            bEqual = false;
    }
    if(bEqual)
        cout<<"Все элементы массива одинаковы\r\n";
    else
    {
        if(arr[0] == (iMin = GetMin(n,arr)))
            cout<<"Первый элемент массива является минимальным элементом\r\n";
        else
        {
            for(i = 0; i < n && arr[i] != iMin; i++)
                iSum += arr[i];
            cout<<"Cумма элементов до минимального элемента массива "<<iSum<<"\r\n";
        }
    }
    system ("pause");
    return 0;
}
 
int GetMin(int n, int * arr)
{
    int iMin = arr[0];
    for(int i = 1; i < n; i++)
        if(arr[i] < iMin)
            iMin = arr[i];
    return iMin;
}
Миниатюры
Вывести сообщение о том, что все элементы в массиве равны   Вывести сообщение о том, что все элементы в массиве равны   Вывести сообщение о том, что все элементы в массиве равны  

0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
08.09.2011, 12:45
talis, проверять одинаковость элементов целесообразней при вводе, экономим как минимум 1 цикл...
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 12:46
-=ЮрА=-, у меня всего один цикл

Добавлено через 20 секунд
впрочем, да, его можно сэкономить
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
08.09.2011, 12:47
Цитата Сообщение от talis Посмотреть сообщение
впрочем, да, его можно сэкономить
- также целесообразней не находить минимальный если все элементы одинаковы - тоже экономия
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 12:48
-=ЮрА=-, у вас у самого три цикла и ненужный вызов
0
ниначмуроФ
 Аватар для PointsEqual
851 / 535 / 110
Регистрация: 12.10.2009
Сообщений: 1,913
08.09.2011, 12:54
а как на счет такого варианта нахождения одинаковы ли все элементы в массиве

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>
#include <vector>
 
using namespace std;
 
int main()
{
    vector<int> v;
 
    v.push_back(1);
    v.push_back(1);
    v.push_back(1);
    v.push_back(1);
    v.push_back(1);
    v.push_back(9);
    v.push_back(1);
 
    if ( 1 == v.size())
        exit(0);
 
    int d = 0;
    for(int i = 0; i < v.size(); ++i)
    {
        d ^= v[i];
    }
 
    if (d == v[0] &&  d == v[1])
        cout << "all equal";
        else cout <<"not all equal";
}
???
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
08.09.2011, 13:42
Цитата Сообщение от PointsEqual Посмотреть сообщение
???
Три ошибки в логике:
1. Для чётного количества одинаковых элементов не работает.
2. Для разных чисел, но записанных парами и первым числом, записанным три раза - не работает.
3. Для любых наборов чисел которые после маскирования совпадут с первыми двумя одинаковыми числами.
Не годится в общем такое решение.
0
Higher
 Аватар для diagon
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
08.09.2011, 14:07
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <vector>
#include <algorithm>
 
template <class C> bool have_only_one_different_element( const std::vector< C >& vec )
{
        return std::min_element( vec.begin(), vec.end() ) == std::max_element( vec.begin(), vec.end() );
}
 
int main()
{
        std::vector<int> arr (5, 0);
        std::cout << std::boolalpha << have_only_one_different_element( arr ) << std::endl;
        
        arr[0] = 1;
        std::cout << std::boolalpha << have_only_one_different_element( arr ) << std::endl;
}
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 14:26
diagon, зачем же два цикла (в min_element и в max_element), когда можно так:

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
#include <iostream>
#include <iterator>
#include <algorithm>
 
using namespace std;
 
int main()
{
    int i = 0,
        summ = 0,
        min;
 
    bool allEqual = true;
 
    for_each( istream_iterator<int>( cin ), istream_iterator<int>(),
             [&]( int el )
             {
                if( i++ == 0 )
                   min = el;
                else if( el < min )
                {
                  min = el;
                  allEqual = false;
                }
                summ += el;
             } );
 
    if( allEqual )
       cout << "All equal.";
    else
       cout << "Min = " << min;
 
    cout << " Summ = " << summ;
 
    return 0;
}
В конце ввода просто делаете format error (буковку там вводите, например).
0
Higher
 Аватар для diagon
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
08.09.2011, 14:47
Цитата Сообщение от talis Посмотреть сообщение
diagon, зачем же два цикла (в min_element и в max_element), когда можно так:
Много букаф
Еще пара вариантов c STL
C++
1
2
3
4
template <class C> bool have_only_one_different_element( std::vector< C > vec )
{
        return std::unique( vec.begin(), vec.end() ) == vec.begin() + 1;
}
C++
1
2
3
4
5
template <class C> bool have_only_one_different_element( std::vector< C > vec )
{
        std::sort( vec.begin(), vec.end() );
        return *vec.begin() == *(vec.end() - 1);
}
C++
1
2
3
4
template <class C> bool have_only_one_different_element( const std::vector< C >& vec )
{
        return std::count( vec.begin(), vec.end(), *vec.begin() ) == (int) vec.size() ;
}
Можно еще кучу алгоритмов STL использовать, но суть не особо поменяется.

Последний вариант самый быстрый из всех возможных вроде. Хотя нет, можно быстрее.

Так побыстрее должно быть =\
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <iostream>
#include <vector>
 
template <class Forward_iterator> bool isnt_unique( Forward_iterator begin, Forward_iterator end )
{
    for ( Forward_iterator it = begin + 1; it != end ; ++it )
        if (*it != *begin)
            return false;
    return true;
}
 
int main()
{
        std::vector<int> arr (5, 0);
        std::cout << std::boolalpha << isnt_unique( arr.begin(), arr.end() ) << std::endl;
        
        arr[0] = 1;
        std::cout << std::boolalpha << isnt_unique( arr.begin(), arr.end() ) << std::endl;
}
2
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 14:50
diagon, а если одновременно с этим считать сумму всех элементов и искать минимальный, как сказано в задании, то вы не далеко уйдёте от других вариантов в этом топике)
0
Higher
 Аватар для diagon
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
08.09.2011, 14:57
Да ну... Это как с задачей про чайник.
1-я задача: Дано - пустой чайник, кран, плита. Как скипятить чайник? Физик:
налить в чайник воду, поставить на плиту. Математик: налить в чайник воду,
поставить на плиту.
2-я задача: Дано - полный чайник, кран, плита. Как скипятить
чайник? Физик: поставить чайник на плиту. Математик: вылить воду из чайника.
Таким образом, задача сводится к предыдущей.
1
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
08.09.2011, 17:07
Цитата Сообщение от talis Посмотреть сообщение
-=ЮрА=-, у вас у самого три цикла и ненужный вызов
- где???
C++
1
2
3
4
5
6
7
8
9
10
for(i = 1; i < n; i++)
    {
                cout<<"Элемент # "<<i + 1<<" = ";
        cin>>arr[i];
                //Проверяем одинаковость всех элементов ещё при вводе
                if(arr[i] != arr[i - 1])
                        bEqual = false;
    }
        if(bEqual)
                cout<<"Все элементы массива одинаковы\r\n";
Ввод и если все одинаковы Мин даже не считаем...
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 17:10
-=ЮрА=-, ваш код:

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
#include <iostream>
#include <windows.h>//нужен моей студии для подключения system ("pause")
 
using namespace std;
 
//Руссификация
ostream& operator<<(ostream &stream,char* s){
        for(char* ps=s; *ps; ps++){
                if(*ps=='ё')
                        stream<<char(241);
                else if(*ps=='Ё')
                        stream<<char(240);
                else if(*ps>=-64 && *ps<=-17)                   
                        stream<<char(*ps+64+128);
                else if(*ps<0)
                        stream<<char(*ps+64+176);
                else
                        stream<<*ps;
        }
        return stream;
}
 
int GetMin(int n, int * arr);
 
int main()
{
        bool bEqual = true;
        cout<<"Введите размерность массива: ";
    int n;cin>>n;
    cout<<"\tВведите элементы массива:\r\n";
        int * arr = new int[n];
        
        int i = 0,iMin,iSum = 0;
        cout<<"Элемент # "<<i + 1<<" = ";
    cin>>arr[i];
    for(i = 1; i < n; i++) /* <--------------------------------------- цикл номер раз */
    {
                cout<<"Элемент # "<<i + 1<<" = ";
        cin>>arr[i];
                //Проверяем одинаковость всех элементов ещё при вводе
                if(arr[i] != arr[i - 1])
                        bEqual = false;
    }
        if(bEqual)
                cout<<"Все элементы массива одинаковы\r\n";
        else
        {
                if(arr[0] == (iMin = GetMin(n,arr)))
                        cout<<"Первый элемент массива является минимальным элементом\r\n";
                else
                {
                        for(i = 0; i < n && arr[i] != iMin; i++)  /* <- цикл номер два */
                                iSum += arr[i];
                        cout<<"Cумма элементов до минимального элемента массива "<<iSum<<"\r\n";
                }
        }
        system ("pause");
        return 0;
}
 
int GetMin(int n, int * arr)
{
        int iMin = arr[0];
        for(int i = 1; i < n; i++) /* <------------------------------- цикл номер три */
                if(arr[i] < iMin)
                        iMin = arr[i];
        return iMin;
}
Вот и три цикла
0
Делаю внезапно и красиво
Эксперт С++
 Аватар для Deviaphan
1313 / 1228 / 72
Регистрация: 22.03.2011
Сообщений: 3,744
08.09.2011, 17:11
Цитата Сообщение от talis Посмотреть сообщение
а если одновременно с этим считать сумму всех элементов и искать минимальный
Нужно считать сумму элементов до минимального, а не сумму всех. За один проход задача не решаема.

И, почему-то, ещё ни одного рекурсивного варианта не было.)
0
 Аватар для talis
794 / 546 / 61
Регистрация: 11.05.2010
Сообщений: 1,298
Записей в блоге: 1
08.09.2011, 17:13
Как всегда, какая-нибудь маааленькая хренушечка, которую ты не заметил, обязательно всё портит.
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
08.09.2011, 17:55
Цитата Сообщение от talis Посмотреть сообщение
/* <------------------------------- цикл номер три */
- вообще читаешь что пишу? циклы не все выполняются а по мере необходимости
Цитата Сообщение от talis Посмотреть сообщение
if(bEqual)
* * * * * * * * cout<<"Все элементы массива одинаковы\r\n";
* * * * else
* * * * {
Цитата Сообщение от talis Посмотреть сообщение
if(arr[0] == (iMin = GetMin(n,arr)))
* * * * * * * * * * * * cout<<"Первый элемент массива является минимальным элементом\r\n";
* * * * * * * * else
* * * * * * * * {
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.09.2011, 17:55
Помогаю со студенческими работами здесь

Вывести сообщение о том что if не сработал
Привет, выходит ошибка, нужно чтоб если нет положительных элементов выводилось сообщение, не могу понять в чем проблема со скобками ...

Верно ли что все элементы последовательности равны между собой
ребят помогите пожалуйста сдать лабу просто очень надо((((( Дана не пустая последовательность целых чисел, заканчивающаяся...

Верно ли, что все элементы последовательности равны между собой?
Дана непустая последовательность целых чисел, оканчивающаяся отрицательным числом. Верно ли, что все элементы последовательности равны...

Вывести номера строк матрицы, все элементы которых равны 2
Здравствуйте. Дан двумерный массив (N=9, M=10). Вывести на экран монитора номера строк, все элементы которых равны 2. ...

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


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru