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

Определить чего больше в двоичной записи произвольного числа: единиц или нулей?

10.12.2017, 03:14. Показов 5448. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Друзья, помогите пожалуйста. Есть код программки, которая считает количество нулей в двоичной записи произвольного числа.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
using namespace std;
int main(){ 
 int n, c = 0;
cin >> n;
if(n<1000 && n>100){
while (n){
 if (n % 2 == 0)c++;
n /= 2;
 }
cout << c;
}
else cout<<"не удовлетворяет условию.";
return 0;
}
А как сделать так чтобы программа считала чего больше нулей или единиц в двоичной записи произвольного числа? Это надо в цикле сделать чтобы если ноль, то увеличиваем одно число, а если единица, то другое и потом их сравниваем? Или это как-то по другому делается?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.12.2017, 03:14
Ответы с готовыми решениями:

Массив: Определить, чего больше в массиве – нулей или единиц
Одномерный массив из 10 элементов.  Заполнить только нулями и единицами  Вывести сообщение “да”, если они строго чередуются. ...

[NASM] Определить, в каком из трёх чисел единиц больше единиц в двоичной записи
Дано 3 числа в двоичной системе счисления. Определить, в каком числе число единиц больше. NASM Ассемблер

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

8
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,360
10.12.2017, 03:26
Цитата Сообщение от D_Evil Посмотреть сообщение
Это надо в цикле сделать чтобы если ноль, то увеличиваем одно число, а если единица, то другое и потом их сравниваем?
Да. Просто else добавить и увеличивать на один другое число.
0
 Аватар для abit
870 / 529 / 149
Регистрация: 03.02.2013
Сообщений: 1,850
10.12.2017, 04:40
какой-то не оптимальный у вас алгоритм...
вот, набросал вам как быстрее всего посчитать количество единиц в бинарном прдеставлении 99, можно прогрузить туда что хотите
C++
1
2
3
4
5
6
7
    unsigned int c(0), x(99);
    while (x)
    {
      x&=x--;
      c++;
    }
    std::cout<<c;
думаю догадаетесь, что всё что там не единицы - то нули
0
0 / 0 / 0
Регистрация: 10.12.2017
Сообщений: 46
10.12.2017, 04:48  [ТС]
А если вот так написать,это логически правильно? Или можно проще?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
using namespace std;
 
int main()
{
 int n;
 int a[2] = { 0,0 };
 cin >> n;
    if(n<1000 && n>100){
 while (n > 0)
{
 ++a[n%2];
 n /= 2;
 }
 if (a[0]>a[1])
cout << "нулей больше";
 else if (a[1]>a[0])
cout << "единиц больше";
else
cout << "единиц и нулей поровну";
}
0
 Аватар для Новичок
1682 / 1098 / 489
Регистрация: 17.07.2012
Сообщений: 5,360
10.12.2017, 04:59
Цитата Сообщение от abit Посмотреть сообщение
x&=x--;
А не UB ли это случайно?
0
 Аватар для abit
870 / 529 / 149
Регистрация: 03.02.2013
Сообщений: 1,850
10.12.2017, 05:01
Новичок,
в чём? в псевдокоде это
X = X AND X-1
не вижу тут UB даже близко (речь идёт о побитовом and, не логическом)
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.12.2017, 05:09
Цитата Сообщение от abit Посмотреть сообщение
Новичок,
в чём? в псевдокоде это
X = X AND X-1
нет, то что вы написали в псевдокоде это x&=--x; Не врите
0
 Аватар для abit
870 / 529 / 149
Регистрация: 03.02.2013
Сообщений: 1,850
10.12.2017, 05:11
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
Не врите
учите матчасть
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,532
Записей в блоге: 1
10.12.2017, 05:39
Цитата Сообщение от abit Посмотреть сообщение
учите матчасть
аргументируйте, а не посылайте в свою матчасть.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.12.2017, 05:39
Помогаю со студенческими работами здесь

Определить, в двоичной записи какого из заданных чисел больше нулей
Задача: на входе два числа в десятичной системе счисления, узнать в каком из чисел больше 0-ей в их двоичной форме. Ввод исходных данных...

Вывести все десятичные числа, в двоичной записи которых число нулей на 2 превосходит число единиц
Есть вот такая прога на Си, которая выводит все десятичные числа, в двоичной записи которых число нулей на 2 превосходит число единиц. ...

Вывести все десятичные числа, в двоичной записи которых число нулей на 2 превосходит число единиц
Доброго времени суток! Долго уже мучаюсь с задачкой, для которой необходимо написать код на Си, чтобы &quot;вывести все десятичные числа...

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

Дано 3 числа в двоичной системе счисления. Определить, в каком числе число единиц больше
Дано 3 числа в двоичной системе счисления. Определить, в каком числе число единиц больше.


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru