0 / 0 / 0
Регистрация: 23.10.2016
Сообщений: 181
1

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

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

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

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

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

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

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

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

Выполнять эти две операции пока N != 0.
1
4816 / 2276 / 287
Регистрация: 01.03.2013
Сообщений: 5,939
Записей в блоге: 27
07.01.2017, 19:07 3
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
25 / 25 / 5
Регистрация: 04.01.2017
Сообщений: 52
08.01.2017, 15:46 4
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;
}
Вывод
Код
For  1 1
For  2 -1
For  8 0
For 13 1
Для продолжения нажмите любую клавишу . . .
0
0 / 0 / 0
Регистрация: 23.10.2016
Сообщений: 181
09.01.2017, 15:12  [ТС] 5
Мы еще не изучали массивы, они присутствуют тут?
0
Форумчанин
Эксперт CЭксперт С++
8194 / 5044 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
09.01.2017, 16:03 6
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
25 / 25 / 5
Регистрация: 04.01.2017
Сообщений: 52
09.01.2017, 20:02 7
Цитата Сообщение от MrGluck Посмотреть сообщение
bitset появился в С++98
Знаю. Функцию log2 только в C++11 добавили.

Ваш способ изящнее
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
09.01.2017, 20:02
Помогаю со студенческими работами здесь

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

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

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

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

Из массива В удалить числа в двоичном представлении которых единиц больше, чем нулей
Переписать положительные числа из матрицы целых чисел А в массив В. Из массива В удалить числа в...

Определить, каких символов больше: цифр или букв
Помогите пожалуйста с кодом


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru