1. Заголовок темы должен быть информативным. В противном случае тема удаляется ... 2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения. 3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали! 4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора). 5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM! 6. Одна тема - один вопрос (задача) 7.Проверяйте программы перед тем, как разместить их на форуме!!! 8.Спрашивайте и отвечайте четко и по существу!!!
Так стоп. Нам нужно найти последотельность _перестановок_ для первой последовательности такую, чтобы из нее получилась вторая последовательность или что ? Я не пойму, причем тут умножение ?
--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
объясняю подругому забей на все что было раньше есть два массива элементов теперь надо вывести такую последовательность пар соседних индексов массива, чтесли к первому массиву провести последовательно операцию"ы" для каждой пары чисел. arr - наш массив операция ы (a,b : integer) var tmp : integer; begin tmp:=arr[a]; arr[a]:=arr[b]; arr[b]:=tmp; end;
пример входных данных (2 3 1 4) (1 3 2 4 Выходные данные : (1 2) (2 3) (1 2) этот пример показан на картинке
--------------------
Нам не дано предугадать как наше слово отзовется...
Тебе нужно сделать обычный пузырек с выводом промежуточных результатов (откуда/куда), только сортировку делать не по значению в массиве, а по его индексу в результирующем. Объясним я похлеще тебя
На пальцах: было (1,2,3,4,5) -надо (3,4,2,1,5) Индексируем первый массив (добавлением еще одного или с использованием record- не важно): значения 1,2,3,4,5 Индексы 4,3,1,2,5 Теперь обычный пузырек если индекс[i]<индекс[i+1] то выводим результат и меняем местами индексы и значения.
const n=4;
type tt=record x,ind:byte; end;
const
x:array [1..n] of byte=(2,3,1,4); {было}
y:array [1..n] of byte=(1,3,2,4); {стало}var z:array [1..n] of tt;
i,j,k:integer;
l:tt;
beginfor i:=1to n dofor j:=1to n doif x[i]=y[j] thenbegin z[i].x:=x[i]; z[i].ind:=j; end; {Индексируем}for k:=1to n dofor i:=1to n-1doif z[i].ind> z[i+1].ind thenbegin
write ('(',i,',',i+1,') ');
l:=z[i]; z[i]:=z[i+1]; z[i+1]:=l;
end;
end.
Проверку на возможность перестановки не делал, считается, что ты его не обманул. Но проверка нужна, ее проще всего добавить в цикл индексирования массива.