• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о проекте, чтобы узнать больше. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Сдвиг элементов массива, Паскаль

Boshaft_Elfe

Ученик
Почётный участник
Регистрация
28 Мар 2010
Сообщения
477
Реакции
22
Баллы
0
Сдвиг элементов массива, Паскаль

Доброго времени суток, очень прошу помочь с решением следующей задачи:
сдвинуть массив на К элементов влево или вправо в зависимости от знака вводимого К. То есть при входном массиве 12345 и К=2 на выходе должен быть такой массив: 45123, при К=-2 - 34512. Мучаюсь с этой задачей не первый день, перепробовала кучу алгоритмов, не хочет работать и все тут:tehnari_ru_281: Вот последний алгоритм, на котором я остановилась (только для положительного К):
Код:
if k>0
  then
       begin
            for i:=1 to n+k do {n - размер массива}
               a[i+k]:=a[i];
            for i:=1 to k do
               a[i]:=a[i+n];
       end;
Вместо ожидаемого 45123 выводит 21121.
 
Ириша, привет - сейчас разберемся!
 
Ну вот, например - так:
Код:
Const
 N=20;
VAR
 A,B:Array [1..N] of Byte;
 k:ShortInt;
 i,j:Byte;
BEGIN
 Randomize;
 Writeln('Initial array:');
 For i:=1 to N do
  begin
   A[i]:=Random(10);
   Write(A[i]:3);
  end;
 Writeln;
 Writeln;
 Write('k= ');
 Readln(k);
 Writeln;
 Writeln;
 If Abs(k)>=N then
  Writeln('Error: k too big!')
 else
 If k=0 then B:=A
 else
 If (k>0) then
  begin
   for j:=1 to N-k do B[j+k]:=A[j];
   for j:=N-k+1 to N do B[j-N+k]:=A[j];
  end
 else
 begin
  for j:=1-k to N do B[j+k]:=A[j];
  for j:=1 to -k do B[N+k+j]:=A[j];
 end;
 Writeln('New array:');
 For i:=1 to N do Write(B[i]:3);
 Readln;
END.
 
Владимир, спасибо огромное! Тоже была идея использовать второй массив, но попытка ее реализовать потерпела фиаско. Еще раз спасибо!=)
 
Владимир, спасибо огромное! Тоже была идея использовать второй массив, но попытка ее реализовать потерпела фиаско. Еще раз спасибо!=)
Ничего, Ира, всё впереди - освоишь эту нехитрую науку! Успехов!
 
Назад
Сверху