Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.65/75: Рейтинг темы: голосов - 75, средняя оценка - 4.65
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61

Определить является ли целое число бинарным (в интерпретаторе)

12.07.2016, 12:30. Показов 14965. Ответов 26
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задано целое число N. Требуется определить, является ли оно бинарным.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.07.2016, 12:30
Ответы с готовыми решениями:

Задано целое число N. Определить, является ли оно бинарным
Здравствуйте, попалась данная задачка: Задано целое число N. Требуется определить, является ли оно бинарным. Не смог найти решение и...

Задано целое число N. Требуется определить, является ли оно бинарным
Бинарные числа Говорят, что плохой программист – это тот, кто считает, что в одном килобайте 1000 байт, а хороший программист – это...

Определить, является ли число бинарным
Говорят, что плохой программист - это тот, кто считает, что в одном килобайте 1000 байт, а хороший программист - это тот, кто полагает, что...

26
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
12.07.2016, 13:17
как уже пробовали?
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
12.07.2016, 13:33  [ТС]
на бумажках раскидал не получается у меня..
0
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
12.07.2016, 13:34
а на словах - в каких случаях число можно считать бинарным?
0
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
12.07.2016, 13:37
ШТААААА? Как это - задано число и является ли оно бинарным? Число - оно и есть число.
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
12.07.2016, 13:41  [ТС]
2^N является бинарным а остальные не бинарные
0
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
12.07.2016, 13:58
Python
1
2
def is_pow2(num):
    return num and not num & (num - 1)
1
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
12.07.2016, 20:02  [ТС]
а можно как то сделать через цикл For ? вот так например, Если 1024 является бинарным, то показать Да, а если не бинарный то НЕТ.
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
12.07.2016, 20:15
sneep, вы должно быть имели ввиду if
Python
1
2
3
4
if if_pow2(1024):
    print('Да')
else:
    print('Нет')
?
Или таки что-то вроде этого
Python
1
2
3
4
nums = [1, 2, 3, 4, 5, 6, 7, 8, 9]
 
for n in nums:
    print('Да' if is_pow2(num) else 'Нет')
?
0
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
13.07.2016, 09:27
Цитата Сообщение от sneep Посмотреть сообщение
2^N является бинарным а остальные не бинарные
Фигасе определение. Я вот слышал про бинарные файлы, в противоположность текстовым. И то, на самом деле под этим словом подразумевается не содержимое файла, а способ чтения. А про бинарные числа не слышал никогда.

Добавлено через 15 минут
Простейший способ:
Python
1
2
3
4
from math import log
def is_pow2(x):
   l = log(x, 2)
   return l == int(l)
1
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
13.07.2016, 12:21  [ТС]
Python
1
2
3
4
5
6
7
8
9
10
11
12
n=float(input('n='))
a=0
for i in [1]:
    i<=n
    i=i*2
    if n==i:
        a=1
    if a==1:
        print('yes')
    else:
        print('no')
input()
что тут не так ? при вводе числа 2 получается yes, а в других всегда no
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
13.07.2016, 13:15
sneep, ваш код эквивалентен следующему
Python
1
2
3
4
5
6
7
n = float(input('n='))
i = 1
i = i*2
if n == i:
    print('yes')
else:
    print('no')
PS Ах, вот что вы имели ввиду...
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
13.07.2016, 16:34  [ТС]
shsv, это не правильно тут только при вводе числа 2 показывать Yes, а в других числах всегда NO. 4 , 8,16,32 и т.д считаются бинарными вот их должно показывать YES, а другие No
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
13.07.2016, 17:12
sneep, я ведь и не говорю, что это правильно. Это ваш код, я только чуток его прилизал. Глядючи на него, легко понять где ошибка. У вас фактически нет никакого цикла, и всё что делает код, проверяет равен ли n двум.
(В скобках: используйте while вместо for)
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
13.07.2016, 17:42  [ТС]
shsv, что то не доходит до меня ) может подсказать еще что нибудь ?
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
13.07.2016, 17:59
Подсказка
Python
1
while i < n:
(Или
Python
1
while n > 1:
)
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
15.07.2016, 19:19  [ТС]
shsv, не понял я, можете отправить полный код ?
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
15.07.2016, 19:31
sneep, ваш подправленный вариант
Python
1
2
3
4
5
6
7
i = 1
while i < n:
    i *= 2
if n == i:
    print('yes')
else:
    print('no')
0
-2 / 0 / 0
Регистрация: 08.12.2015
Сообщений: 61
15.07.2016, 19:46  [ТС]
shsv, а вот так правильно ?
Python
1
2
3
4
5
6
7
8
n=10
i=1
while i<n:
        n=n/2
        if i%n==0:
              print('yes')
        else:
              print('no')
Добавлено через 11 минут
сделал так получилось тоже. Спасибо
Python
1
2
3
4
5
6
7
8
n=float(input('n='))
i=1
while i<n:
    n=n/2
if i%n==0:
    print('yes')
else:
    print('no')
0
757 / 306 / 190
Регистрация: 20.05.2016
Сообщений: 593
15.07.2016, 19:49
Можно обойтись и без i. Впрочем это придирка. И i%n==0 => n==1
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.07.2016, 19:49
Помогаю со студенческими работами здесь

Определить является ли число бинарным
Программа определяет бинарное ли число если да то вывыдит да если нет то выводит нет. на 8 тесте падает.Думаю что ошибка в том когда...

Дано целое число N (> 1). Определить, является ли число N числом Фибоначчи
Дано целое число N (&gt; 1). Определить, является ли число N числом Фибоначчи. Если является, то вывести сообщение: «N — число Фибоначчи»,...

Ввести целое число и определить, является ли данное число простым или нет
Ввести целое число и определить является ли данное число простым или нет. (желательно простым кодом для начинающих). Заранее благодарю.

Определить, является ли целое число N четным двузначным числом, и делится ли оно на число K
Определить, является ли целое число N четным двузначным числом, и делится ли оно на число K ( решите плз с помощью цикла и условия)

Дано элемент файла пятизначное целое число. Подсчитать сумму и произведение цифр, определить - является ли число палиндромом.
дано элемент файла пятищначное целое число. найти а) сложение цифр этого числа б)умножения цифр этого числа в) выяснить что число...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
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 Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru