IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Цифры числа в том же порядке
Ozzя
сообщение 10.02.2010 15:49
Сообщение #1


Гуру
*****

Группа: Пользователи
Сообщений: 1 220
Пол: Мужской

Репутация: -  16  +


Студентка одна попросила о помощи. Задача
Цитата
ДАНО нат. число. Поместить его цифры в массив в том же порядке, в каком они были записаны.

Склеил из форумовских

program forforum;
var
a, b : LongInt;
q : Array [1..16] of Integer;
i, n : Integer;

begin
readLn(a);
b:=0;
while a<>0 do
begin
b:=b*10+a mod 10;
a:=a div 10;
end;
i:=1;
while b<>0 do
begin
n:=i;
a:= b mod 10;
b:= b div 10;
q[i]:=a;
i:=i+1;
end;
for i:=1 to n do
writeLn(q[i]);
readln;
end.

Ан нет, преподу не понравилось. Нужно оптимизировать, обойдясь одним циклом. И что-то я тут задумался sad.gif

Сообщение отредактировано: Ozzя - 10.02.2010 15:50
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Unconnected
сообщение 10.02.2010 16:12
Сообщение #2


mea culpa
*****

Группа: Пользователи
Сообщений: 1 372
Пол: Мужской
Реальное имя: Николай

Репутация: -  24  +


Может, препод это имел в виду?smile.gif

var a:string;
m:array[1..16] of byte;
i:byte;
code:integer;
begin
readln(a);
for i:=1 to length(a) do begin
val(a[i],m[i],code);
writeln(m[i]);
end;
end.


--------------------
"Знаешь, стыдно - когда не видно, что услышал всё, что слушал.."
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Ozzя
сообщение 10.02.2010 16:38
Сообщение #3


Гуру
*****

Группа: Пользователи
Сообщений: 1 220
Пол: Мужской

Репутация: -  16  +


Нет. Строки использовать нельзя.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 10.02.2010 17:18
Сообщение #4


Гость






Оззя, ты чего? blink.gif

program forforum;
var
a, b : LongInt;
q : Array [1..16] of Integer;
i, n : Integer;
begin
readLn(a);

i := 0;
b := 1000000000; n := 10;
while a > 0 do
begin
if b > a then begin
b := b div 10; dec(n);
end
else begin
q[n - i] := a mod 10; inc(i);
a := a div 10;
b := b div 10;
end;
end;

for i := 1 to n do
writeLn(q[i]);
readln;
end.
 К началу страницы 
+ Ответить 
Ozzя
сообщение 10.02.2010 17:22
Сообщение #5


Гуру
*****

Группа: Пользователи
Сообщений: 1 220
Пол: Мужской

Репутация: -  16  +


 while a > 0 do
begin
if b > a then begin
b := b div 10; dec(n);

Ведь шла мысль в этом направлении...
Блин
Цитата
Оззя, ты чего?

Я лох mega_chok.gif
Уволюсь в управдомы

Добавлено через 15 мин.
Вольво, выручай!
Препод поменял
строки
  a, b  : LongInt;
q : Array [1..16] of Integer;

на
  a, b  : Int64;
q : Array [1..64] of Integer;

ввел 1234567890123456
Программа виснет
И заявил: "Ваш код машинно-зависим. Требуется общее решение". norespect.gif
Оно вообще возможно?

Добавлено через 13 мин.
Что-то типа такого
if sizeof(b)=4 // longint (dword)
then
b := 1000000000;

if sizeof(b)=8 // int64
then
b := 1000000000000000000;


не покатит?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 10.02.2010 18:04
Сообщение #6


Гость






Цитата
Оно вообще возможно?
Возможно, возможно... Все возможно... Блин, времени тестировать как следует нет - погоняй вот это:
program forforum;
uses math;

type
MyInt = Int64;
var
a, b : MyInt;
q : Array [1 .. 8 * sizeof(MyInt)] of Integer;
i, n, start : Integer;
begin
// readLn(a);
a := 1234567890123456;
// a := 45887;

i := 0;

n := trunc(log10(High(MyInt)));
start := n + 1;

while a > 0 do
begin
if n > log10(a) then begin
dec(n); dec(start);
end
else begin
q[start - i] := a mod 10; inc(i);
a := a div 10;
dec(n);
end;
end;

for i := 1 to start do
writeLn(q[i]);
readln;
end.
(отмазка со стороны преподавателя, что Log10 нет в Turbo Pascal-е не принимается, ибо во-первых, ее очень просто написать самому, а во-вторых, Int64 там тоже нет...)
 К началу страницы 
+ Ответить 
klem4
сообщение 16.02.2010 22:02
Сообщение #7


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

Репутация: -  44  +


вот мой вариант, не знаю на сколько проактит у препода, log10 и power можно заменить как ужы было сказано, + если a = 0, надо отдельную ветку сделать. А так работает rolleyes.gif

uses math;
var
a : Int64;
i : integer;
q : Array [1..64] of Integer;
begin
a := 9223372036854775807;
for i :=trunc( log10(a) ) downto 0 do q[i+1] := (a div trunc( power(10, i) ) mod 10);
for i := trunc( log10(a) ) + 1 downto 1 do write(q[i]);
end.


ps вариант с минимальным кол-вом переменных, trunc( log10(a) ) можно запомнить при желании.

Сообщение отредактировано: klem4 - 16.02.2010 22:03


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 26.04.2024 13:54
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"