Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 25.11.2016
Сообщений: 17

Система счисления

20.10.2017, 22:16. Показов 2326. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано N - значное шестнадцатеричное число. Требуется определить количество значащих нулей в двоичной записи этого числа. Основное требование к программе: размер памяти, которую использует Ваша программа, не должен зависеть от длины входных данных (массив размерности N не допустим).
Формат входных данных
Во входном файле input.txt в первой строке записано число N – количество цифр числа (1< N < 100000), а во второй строке само шестнадцатеричное число.
Формат выходных данных
Запишите в выходной файл output.txt число значащих нулей в двоичной записи данного числа.

Примеры входа и выхода
input.txt:
7
DABC901
output.txt:
15
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.10.2017, 22:16
Ответы с готовыми решениями:

Римская система счисления
Помогите с кодом пожалуйста) Дано число X. Требуется перевести это число в римскую систему счисления. Входные данные Дано число X...

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

Система счисления без цифр с нулями
Здравствуйте! Возможно ли в PascalABC.NET запрограммировать например троичную систему счисления без цифр с нулями. Принцип: 1 2 ...

3
Эксперт Pascal/Delphi
6812 / 4568 / 4820
Регистрация: 05.06.2014
Сообщений: 22,433
20.10.2017, 22:48
Функция взята отсюда:
Файл: перевод из шестнадцатиричной системы счисления в двоичную

Pascal
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
const
  s2: string = '0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 1111';
  s3: string = '0123456789ABCDEF';
 
function HexToBin(s: string): string;
var
  i: byte;
  rez: string;
begin
  rez := '';
  for i := 1 to length(s) div 2 do
  begin
    rez := rez + copy(s2, (pos(s[i * 2 - 1], s3) + 1) + (4 * (pos(s[i * 2 - 1], s3) - 1)) - 1, 4);
    rez := rez + copy(s2, (pos(s[i * 2], s3) + 1) + (4 * (pos(s[i * 2], s3) - 1)) - 1, 4);
  end;
  if odd(length(s)) then rez := rez + copy(s2, (pos(s[length(s)], s3) + 1) + (4 * (pos(s[length(s)], s3) - 1)) - 1, 4);
  HexToBin := rez;
end;
 
 
 
function HowManyZeroes(s: string): integer;
var
  k, n, i: integer;
begin
  n := 0;
  for i := 1 to length(s) do
    if s[i] = '1' then
    begin
      k := i;
      break;
    end;
  for i := k to length(s) do
    if s[i] = '0' then
      inc(n);
  HowManyZeroes := n;
end;
 
var
  f1, f2: text;
  s: string;
 
begin
  assign(f1, 'input.txt');
  assign(f2, 'output.txt');
  reset(f1);
  rewrite(f2);
  readln(f1, s);
  readln(f1, s);
  s := hextobin(s);
  writeln(f2, HowManyZeroes(s));
  close(f1);  
  close(f2);
end.
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
21.10.2017, 10:42
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

Здесь перевод из 16 в 2 не нужен.
По моему идея такая.
Pascal
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
26
27
28
29
30
31
32
const size=16;
{тетрады  в программе не нужны, только для себя, чтобы составить массивы
tetr:array[1..size] of string[4]=('0000','0001','0010','0011','0100','0101',
                                  '0110','0111','1000','1001','1010','1011',
                                  '1100','1101','1110','1111'); }
 
//количество значащих нолей если их еще нет
z0:array[1..16] of byte=(0,0,1,0,2,1,1,0,3,2,2,1,2,1,1,0);
// количество значащих нолей если они уже есть
z1:array[1..16] of byte=(4,3,3,2,3,2,2,1,3,2,2,1,2,1,1,0);
cf16:string[size]='0123456789ABCDEF';
var c:array[1..100000] of char;
    n,i,k,f:integer;
begin
readln(n);
for i:=1 to n do
read(c[i]);
f:=0;//пока нет значащих цифр
for i:=1 to n do
 begin
  if f=0 then //если еще нет, то
   begin
    if c[i]>'0' then //если цифра больше 0
     begin
      f:=1;//будут значащие цифры
      inc(k,z0[pos(c[i],cf16)]);
     end
    end
  else inc(k,z1[pos(c[i],cf16)]);
 end;
write('k=',k)
end.
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
23.10.2017, 07:05
Pascal
1
2
3
4
5
6
7
8
9
begin
  var l := ReadLnInteger;
  var s := ReadLnString;
  var c := '0123456789ABCDEF';
  var n := arr(4,3,3,2,3,2,2,1,3,2,2,1,2,1,1,0);
  var v := arr(0,0,1,0,2,1,1,0);
  var i := c.IndexOf(s[1]);
  WriteLn(s.Select(ch->n[c.IndexOf(ch)]).Sum+(i<8?v[i]-n[i]:0));
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.10.2017, 07:05
Помогаю со студенческими работами здесь

Вводится десятичное число и система счисления, вывести это число в данной СС
Вводится десятичное число и система исчесления , вывести это число в данной СС

Перевести число из системы счисления с основанием 19 в десятичную систему счисления
Уважаемые разбирающиеся во всём этом люди, прошу вас помочь мне с этой задачей Примечания 1. Число в заданной системе счисления...

Перевод числа из любой системы счисления в десятичную систему счисления
дано число типа integer, записанное в любой другой системе счисления. перевести это число в 10сс. Очень нужна помощь!!

Нужна программа для перевода из шестнадцатеричной системы счисления в восьмеричную систему счисления или десятичную
Исходный файл содержит числа в шестнадцатеричной системе счисления, отделенные друг от друга запятыми. Составить программу, которая для...

Перевод числа X, заданного в системе счисления с основанием q в систему счисления с основанием p
Помогите, пожалуйста, разработать программу, выполняющую перевод действительного числа X заданного в системе счисления с основанием q в...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при создании или изменении элементов справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи электронной. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru