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

Определить число соседних двух элементов с разными знаками

16.06.2014, 16:02. Показов 2860. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан одномерный массив a из n элементов, элементы отличны от нуля. Определить число соседних двух элементов с разными знаками
Написать код с комментариями
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.06.2014, 16:02
Ответы с готовыми решениями:

Определить, есть ли в заданном массиве два соседних элемента с разными знаками
Дан массив из n элементов. Необходимо определить, есть ли в данном массиве два соседних элемента с разными знаками, и, если есть, вывести...

Дан одномерный массив. Определить, если 2 пары соседних элементов с одинаковыми знаками
Определить, есть ли в одномерном массиве 2 пары чисел с одинаковыми знаками.

Определить максимальную сумму двух соседних элементов
Пусть пользователь вводит динамическую матрицу размером NxN. Определить максимальную сумму двух соседних элементов диагонали. Помогите...

7
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
16.06.2014, 16:17
Минутку

Добавлено через 9 минут
Ответ си подобным псевдокодом.
C++
1
2
3
for(int i = 0; i < n; i++)
if((abs(a[i]) != a[i]) && abs(a[i+1] == abs[i+1])) || if((abs(a[i]) == a[i]) && abs(a[i+1] != abs[i+1]))
schet++;
Идея такая, если первое число не равняется своему модулю,а следующее равняется(тобишь положительное) ИЛИ если первое число положительное, а второе нет, то счетчик увеличивается. вам надо сделать массив, проверить синтаксиси того что я написал и объявить переменные
1
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
16.06.2014, 16:22
delete
1
4 / 4 / 1
Регистрация: 17.09.2013
Сообщений: 179
16.06.2014, 16:38
C++
1
if((abs(a[i]) != a[i]) && abs(a[i+1] == a[i+1])) || if((abs(a[i]) == a[i]) && abs(a[i+1] != a[i+1]))
вот, вернее
1
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
16.06.2014, 20:14
Как вариант. Использование деления дорого конечно, но по крайней мере не переполнит. Может кто-то подскажет как легче сделать.
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
#include <iostream>
 
using namespace std ;
 
const int n = 10 ;
int a[n]={ -1, 2, 3, -4, 5, -6, 7, 8, 9, -10 } ;
int main()
{
    int sign_firstly_canged = 0 ;
    int counter = 0 ;
    for ( int i = 0 ; i < n - 1 ; ++i ){
if( a[i]/abs(a[i]) != a[i+1]/abs(a[i+1]) )//знак изменился
{
sign_firstly_canged ++ ;
if(sign_firstly_canged == 1)//по крайней мере единожды
{
counter += 2 ;//их по крайней мере двое)
}else{
counter++ ;//в группу ещё один добавился
}
}else{
sign_firstly_canged=0 ;
}
    }
cout << counter << endl ;//9 штук)
 
system("pause") ;
return 0 ;
}
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
16.06.2014, 20:31
Цитата Сообщение от IGPIGP Посмотреть сообщение
9 штук)
Почему 9?
-1, 2
3, -4
-4, 5
5, -6
-6, 7
9, -10
2
 Аватар для RaiaNKnight
97 / 71 / 12
Регистрация: 29.06.2011
Сообщений: 465
Записей в блоге: 1
16.06.2014, 20:43
Лучший ответ Сообщение было отмечено IGPIGP как решение

Решение

Можно так:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
using namespace std;
 
int main() {
    int a[4] = {-1, 2, -3, -4};
    int n = 4;
    int answer = 0;
    
    for( int i = 1; i < n; ++i ) {
        if( (a[i] & (1 << 31)) != (a[i-1] & (1 << 31)) ) {
            ++answer;
        }
    }
    cout << answer; //2
    return 0;
}
Warning: только с int.
2
Комп_Оратор)
Эксперт по математике/физике
 Аватар для IGPIGP
9007 / 4708 / 630
Регистрация: 04.12.2011
Сообщений: 14,003
Записей в блоге: 16
16.06.2014, 21:37
Цитата Сообщение от Croessmah Посмотреть сообщение
Почему 9?
только 8-ка не входит в:
Цитата Сообщение от flusha Посмотреть сообщение
число соседних двух элементов с разными знаками
то есть 9 из 10-ти. Впрочем, может я снова как-то по своему увидел?
Интересно, что ТС скажет.
зы. если понимать <<число пар>> , то мой код не годится, но "великим и могучим русским языка" (A. Иванов) в условиях задач требующих точности...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.06.2014, 21:37
Помогаю со студенческими работами здесь

Подсчитать количество пар соседних элементов с одинаковыми знаками
Дан линейный массив из 11 целых чисел. Подсчитать количество пар соседних элементов, которые имеют одинаковые знаки. Спасибо за ранние.

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

Найти номера двух соседних чисел из данного набора, произведение которых является минимальным
Дано целое число N (&gt; 1). Задать N элементов одномерного массива. Найти номера двух соседних чисел из данного набора, произведение которых...

Подсчитать количество соседей с разными знаками
Подсчитать количество пар соседних элементов имеющих разные знаки что надо сделать?

Содержит ли последовательность хотя бы два соседних числа с одинаковыми знаками?
Вводится последовательность ненулевых чисел, 0 — конец последовательности. Определить содержит ли последовательность хотя бы два соседних...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru