 
C++. Есть ли в одномерном массиве три подряд идущих одинаковых элемента
 0
        0
         0
        0
    Ответы на вопрос
 
        Изи задача)
Исправлено:
#include <iostream>
using namespace std;
int main()
{
cout << "Task 30257728!" << endl;
const int N = 10;
// создаем массив
int m[N] = {1,1,1,4,5,6,7,8,9,3};
// пробегаемся по массиву
for (int i = 0; i < N; i++) {
// смотрим только те, что идут до mLength - 2
if (i < N - 2) {
// если m[i] и + 1 и + 2 равны, то переключаем выходим из программы
if (m[i] == m[i + 1] && m[i + 1] == m[i + 2]) {
cout << "Array have dupes" << endl;
return 0;
}
}
}
return 0;
}
старое--------------------------
Как-то так:
#include <iostream>
using namespace std;
int main()
{
cout << "Task 30257728!" << endl;
// созданем массив
int m[] = {1,1,1,4,5,6,7,8,9,3,3,4,2,3,3};
// считаем его размер
int mLength = (sizeof(m)/sizeof(*m));
// делаем переключатель
bool haveDupes = false;
// пробегаемся по массиву
for (int i = 0; i < mLength; i++) {
// смотрим только те, что идут до mLength - 2
if (i < mLength - 2) {
// если m[i] и + 1 и + 2 равны, то переключаем haveDupes
if (m[i] == m[i + 1] && m[i + 1] == m[i + 2]) {
haveDupes = true;
}
}
}
// если переключен haveDupes
if (haveDupes) {
cout << "Array have dupes" << endl;
} else {
cout << "Array haven't dupes" << endl;
}
return 0;
}
 0
                    0
                     0
                    0
                 
            Да, в одномерном массиве можно проверить, есть ли три подряд идущих одинаковых элемента. Для этого можно пройтись по массиву и сравнивать каждый элемент с предыдущим и следующим. Если три подряд идущих элемента будут равны, то условие выполнено.
Ниже приведен пример кода на C++, который реализует данную проверку:
cpp#include <iostream>
bool hasThreeConsecutiveSameElements(int arr[], int size) {
    if (size < 3) {
        return false; // Если в массиве меньше трех элементов, то точно нет триплета
    }
    for (int i = 2; i < size; ++i) {
        if (arr[i] == arr[i - 1] && arr[i] == arr[i - 2]) {
            return true; // Нашли триплет
        }
    }
    return false; // Не нашли триплет
}
int main() {
    int arr[] = {1, 2, 2, 2, 3, 4, 5}; // Пример массива
    int size = sizeof(arr) / sizeof(arr[0]);
    if (hasThreeConsecutiveSameElements(arr, size)) {
        std::cout << "В массиве есть три подряд идущих одинаковых элемента." << std::endl;
    } else {
        std::cout << "В массиве нет триплета из одинаковых элементов." << std::endl;
    }
    return 0;
}
Обратите внимание, что в данном примере функция hasThreeConsecutiveSameElements принимает массив и его размер. Она проходится по массиву с индекса 2 до конца и проверяет условие триплета. Если условие выполняется, то функция возвращает true, в противном случае - false. В main функции просто происходит вызов этой функции и вывод результата на экран.
 0
                    0
                     0
                    0
                Похожие вопросы
Топ вопросов за вчера в категории Информатика
Последние заданные вопросы в категории Информатика
- 
			Математика 
- 
			Литература 
- 
			Алгебра 
- 
			Русский язык 
- 
			Геометрия 
- 
			Английский язык 
- 
			Химия 
- 
			Физика 
- 
			Биология 
- 
			Другие предметы 
- 
			История 
- 
			Обществознание 
- 
			Окружающий мир 
- 
			География 
- 
			Українська мова 
- 
			Информатика 
- 
			Українська література 
- 
			Қазақ тiлi 
- 
			Экономика 
- 
			Музыка 
- 
			Право 
- 
			Беларуская мова 
- 
			Французский язык 
- 
			Немецкий язык 
- 
			МХК 
- 
			ОБЖ 
- 
			Психология 
- 
			Физкультура и спорт 
- 
			Астрономия 
- 
			Кыргыз тили 
- 
			Оʻzbek tili 
 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			 
			