1. Заголовок темы должен быть информативным. В противном случае тема удаляется ... 2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения. 3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали! 4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора). 5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM! 6. Одна тема - один вопрос (задача) 7.Проверяйте программы перед тем, как разместить их на форуме!!! 8.Спрашивайте и отвечайте четко и по существу!!!
Составить программу, которая вводит натуральное число N и основание системы счисления p, а затем выводит цифры Aк представления N в p – ричной системе. Вот нашел функцию. Можете подробно прокоментировать каждую строчку плииз?
function _10toR(x:longint;R:word):string; var x,ost:longint; s,st,chislo:string; begin repeat ost:=x mod R; x:=x div R; if ost>9 then st:=chr(ord('A')-10+ost) else str(ost,st); s:=s+st; until x=0; for i:=1 to length(s) do chislo:=chislo+s[length(s)-i+1]; _10toR:=chislo; end;
function FromDec(n, radix:longint):string; var s: String; const digit: string[16]='0123456789ABCDEF'; begin s:=''; repeat s:=digit[(n mod radix)+1]+s; n:=n div radix; until n=0; FromDec:=s; end;
тут я так понял максимальная система счисления 16-ричная, а в задаче в любую надо. и еще не понятны вот эти строки
{ Сначала получаем остаток от деления числа на основание С/С, а потом дописываем к строке-результату _спереди_ символ, который в выбранной системе счисления (radix) соответствует полученному остатку. Вот и все, никаких преобразований число->строка, никаких условий, остаток больше или меньше 10... Все просто. (+1) - потому, что символы в строке индексируются с 1 } s:=digit[(n mod radix)+1]+s; { Ну, остаток мы записали в результат, теперь осталось обработать остальное: получаем целую часть от деления на основание, и продолжаем по тому же алгоритму. } n:=n div radix;