С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 23.10.2016
Сообщений: 249

Определить каких цифр больше в двоичном представлении

07.01.2017, 18:45. Показов 1124. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Определить каких цифр больше в двоичном представлении натурального числа N - нулей и единиц.
Ввод натуральное число 13
Вывод "0" - если больше нулей, "1" - если больше единиц, "-1" - если одинаковое количество. (Из примера - 1)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.01.2017, 18:45
Ответы с готовыми решениями:

Определить, каких цифр больше в двоичном представлении натурального числа N-нулей и единиц
Определить, каких цифр больше в двоичном представлении натурального числа N-нулей и единиц. Циклический алгоритм. Код не надо, только...

Определить, каких цифр больше в двоичном представлении натурального числа N – нулей или единиц
Определить, каких цифр больше в двоичном представлении натурального числа N – нулей или единиц.

Определить, каких бит (0 или 1) больше в двоичном представлении числа
Напишите программу, в которой необходимо определить, каких бит (0 или 1) больше в двоичном представлении определенного целого значения А.

6
1272 / 1029 / 470
Регистрация: 25.12.2016
Сообщений: 3,333
07.01.2017, 19:05
Для решения задачи нужны две операции:
1. Нахождение младшего (крайнего правого) бита числа. Это делается так: N % 2 (или N & 1).
2. Отбрасывание младшего бита: N /= 2 (или N >>= 1).

Выполнять эти две операции пока N != 0.
1
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,989
Записей в блоге: 32
07.01.2017, 19:07
C++
1
2
3
int f(int n, int z, int o) { return n ? f(n/2, z-n%2+1, o+n%2) : z>o ? 0 : z<o ? 1 : -1; }
 
int main() { int n; std::cin >> n; std::cout << f(n,0,0); }
0
 Аватар для FHelio
25 / 25 / 5
Регистрация: 04.01.2017
Сообщений: 52
08.01.2017, 15:46
Neiten, все что для решения этой задачи нужно уже существует в стандартной библиотеке C++11.
Код
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
#include <iostream>
#include <bitset>
#include <cmath>
 
int func(int number)
{
    std::bitset<8*sizeof(int)> Bits(number);
    auto ones = Bits.count();
    auto zeros = int(log2(number))+1-ones;
    if(ones<zeros)
        return 0;
    else if(ones>zeros)
        return 1;
    else
        return -1;
}
 
int main ()
{
  std::cout<<"For  1 "<<func(1)<<" \n";
  std::cout<<"For  2 "<<func(2)<<" \n";
  std::cout<<"For  8 "<<func(8)<<" \n";
  std::cout<<"For 13 "<<func(13)<<"\n";
  return 0;
}
Вывод
Code
1
2
3
4
5
For  1 1
For  2 -1
For  8 0
For 13 1
Для продолжения нажмите любую клавишу . . .
0
1 / 1 / 0
Регистрация: 23.10.2016
Сообщений: 249
09.01.2017, 15:12  [ТС]
Мы еще не изучали массивы, они присутствуют тут?
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
09.01.2017, 16:03
C++
1
2
3
4
5
6
7
8
9
10
#include <iostream>
 
int main()
{
    int x, cnt1 = 0, cnt2 = 0;
    std::cin >> x;
    for (int i = x; i; i >>= 1)
        i & 1 ? cnt1++ : cnt2++;
    std::cout << (cnt1 == cnt2 ? -1 : cnt2 < cnt1);
}
Добавлено через 1 минуту
Цитата Сообщение от FHelio Посмотреть сообщение
уже существует в стандартной библиотеке C++11
bitset появился в С++98
1
 Аватар для FHelio
25 / 25 / 5
Регистрация: 04.01.2017
Сообщений: 52
09.01.2017, 20:02
Цитата Сообщение от MrGluck Посмотреть сообщение
bitset появился в С++98
Знаю. Функцию log2 только в C++11 добавили.

Ваш способ изящнее
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.01.2017, 20:02
Помогаю со студенческими работами здесь

Написать программу в которой необходимо определить каких битов больше в двоичном представлении целого значения
Написать програму в которой необходимо определить каких битов (0 или 1) больше в двоичном представлении определенного целого значения А. ...

Определить каких цифр в числе больше
Дано натуральное число.(ввод с клавиатуры) Нужно подсчитать каких чисел в нем больше четных или не четных.

определить каких цифр больше в двоичном представлени
Определить каких цифр больше в двоичном представлении натурального числа N - нулей и единиц. Ввод натуральное число 13 Вывод...

Посчитать количество цифр в двоичном представлении числа
Помогите написать программу по PASCALABC.NET. Пожалуйста! Срочно! Необходимо написать программу по информатике. До вечера 24.04, то есть,...

Найти в матрице число, в двоичном представлении которого больше всего единиц
Условие. Размерности массивов вводить с клавиатуры. Исходные данные и результаты выводить на экран дисплея в табличном виде. Задача. ...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru