29.05.2017, 21:59 [+3 UTC]
в нашей команде: 1 987 чел. | участники онлайн: 5 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: консультации

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.41 (25.02.2017)

Общие новости:
23.02.2017, 09:51

Форум:
29.05.2017, 18:14

Последний вопрос:
29.05.2017, 21:26

Последний ответ:
29.05.2017, 09:18

Последняя рассылка:
29.05.2017, 18:15

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
07.02.2010, 19:16 »
Калимуллин Дамир Рустамович
Второй способ действительно помог, спасибо [вопрос № 176541, ответ № 259279]
27.12.2010, 01:03 »
Дмитрий Олегович
И вновь качественный ответ! Большое спасибо! Очень рад что на форуме есть такие люди как вы! [вопрос № 181620, ответ № 265113]
16.12.2009, 15:44 »
jeck26
Спасибо, присмотрюсь к WD, хотя пользуюсь исключительно Samsung. [вопрос № 175209, ответ № 257672]

РАЗДЕЛ • Pascal / Delphi / Lazarus

Создание программ на языках Pascal, Delphi и Lazarus.

[администратор рассылки: Зенченко Константин Николаевич (Модератор)]

Лучшие эксперты в этом разделе

Зенченко Константин Николаевич
Статус: Модератор
Рейтинг: 131
mklokov
Статус: 5-й класс
Рейтинг: 104
Ксюша
Статус: 1-й класс
Рейтинг: 2

Перейти к консультации №:
 

Консультация онлайн # 137684
Раздел: • Pascal / Delphi / Lazarus
Автор вопроса: Бесчастнов егор Алекандрович
Отправлена: 20.05.2008, 23:56
Поступило ответов: 2

Вводится число от 1 до 15. Вывести данное число, записанное в двоичной системе счисления (1, 10, 11, 100, 101, …., 1111);

использовать Pascal turbo 7.0

Состояние: Консультация закрыта

Ответ # 224271 от Verena

Здравствуйте, Бесчастнов егор Алекандрович!
Перевод числа в двоичную систему счисления (как и в любую другую, впрочем) производится постепенным делением на основание системы, т.е. на 2. Число формируется из остатков от этого деления в обратном порядке. Подробнее о системах счисления можно почитать в Википедии.
Программно реализуем так: сохраняем остаток от деления введённого числа на два в строку, после чего обрезаем число на сохранённый разряд (целочисленно делим на 2). Когда число обнулится, мы можем либо инвертировать строку, чтобы получить двоичное представление, либо, если необходимо получить число в виде числа, с конца перевести его в число. Это возможно не всегда, поскольку полученное двоичное число может не поместиться в стандартный тип, но в данной задаче размерность строго ограничена, поэьтому привожу такой вариант. Решение в приложении.
Удачи!

Приложение:


Консультировал: Verena
Дата отправки: 21.05.2008, 00:51

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Ответ # 224335 от Denisss


Здравствуйте, Бесчастнов егор Алекандрович!

В приложении находится пример вывода десятичного числа в двоичной системе счисления.

Как Вы знаете, компьютер хранит числа в двоичной системе счисления. Именно на этом факте и основан пример.

Функция shr выполняет сдвиг двоичного числа на указанное число разрядов вправо, выкидывая сдвинутые разряды и заполняя нулями указанное количество старших разрядов.

Пример сдвига:
1011 -> (shr 1) -> 0101

Сдвиг числа на единицу вправо (shr 1) соответствует делению этого числа на 2 (div 2).

Функция and выполняет побитовую логическую операцию И. Т.о., (and 1) дает, как результат, младший разряд числа.

Пример:
1011 -> (and 1) -> 0001
1010 -> (and 1) -> 0000

Операция И в данном случае (and 1) равна остатку от деления числа на 2 (mod 2).

Успехов!

Приложение:


Консультировал: Denisss
Дата отправки: 21.05.2008, 19:30

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Возможность оставлять сообщения в мини-форумах консультаций доступна только после входа в систему.
Воспользуйтесь кнопкой входа вверху страницы, если Вы зарегистрированы или пройдите простую процедуру регистрации на Портале.

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.13783 сек.

© 2001-2017, Портал RFPRO.RU, Россия
Авторское право: ООО "Мастер-Эксперт Про"
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.41 от 25.02.2017
Бесплатные консультации онлайн