Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.10.24;
Скачать: CL | DM;

Вниз

Задача на общую программистскую логику   Найти похожие ветки 

 
pipll ©   (2004-10-05 00:12) [0]

Недавно услышал от программиста следующую задачу:

Имеется массив (одномерный, но число элементов m стремится к бесконечности). Нужно сделать циклическую перестановку на k элементов, причем не используя дополнительной памяти. Время перестановки не должно зависить от k и от m.

Слабо решить такую задачку?


 
K.o.Z   (2004-10-05 00:15) [1]

Я даже условия толком не понял, а ты про решение. :)
P.S. А самому? ;)


 
pipll ©   (2004-10-05 00:19) [2]

2 K.o.Z: Имеется массив на n элементов. Допустим (a1, a2, a3, a4, a5, ..., an). Нужно сделать циклическую перестановку на k элементов (для простоты k=2 и перестановка назад). Т.е. должно получиться (a3, a4, a5, ..., an, a1, a2), причем не используя дополнительной памяти.

Сам я не представляю как это сделать :(


 
Cobalt ©   (2004-10-05 00:20) [3]

Если требуется такая задача - то используйте связный список.


 
jack128 ©   (2004-10-05 00:24) [4]

pipll ©   (05.10.04 0:12)
причем не используя дополнительной памяти.


невозможно. Ты даже по массиву пробежаться не можешь без даполнительной памяти (нужно же хранить счетчик цикла где то )


 
}{enon ©   (2004-10-05 00:25) [5]

ИМХО можно через указатели, правда немного не соблюдаются условия :(


 
KilkennyCat ©   (2004-10-05 00:25) [6]

машина Поста


 
}{enon ©   (2004-10-05 00:29) [7]

Или еще вариант: вытащить из оперативки сколько-то бит (физически их выломать :), сдвинуть остальные, засунуть эти в освободившееся место.


 
}{enon ©   (2004-10-05 00:30) [8]

Удалено модератором


 
}{enon ©   (2004-10-05 00:31) [9]

Удалено модератором


 
}{enon ©   (2004-10-05 00:32) [10]

Удалено модератором


 
}{enon ©   (2004-10-05 00:32) [11]

Удалено модератором


 
}{enon ©   (2004-10-05 00:33) [12]

Удалено модератором


 
}{enon ©   (2004-10-05 00:33) [13]

Удалено модератором


 
}{enon ©   (2004-10-05 00:36) [14]

Удалено модератором


 
}{enon ©   (2004-10-05 00:37) [15]

Удалено модератором


 
}{enon ©   (2004-10-05 00:42) [16]

Удалено модератором


 
Sha ©   (2004-10-05 00:44) [17]

> pipll ©   (05.10.04 00:19) [2]

Во-первых, нужна переменная для организации цикла.

Если кроме переменных для организации цикла можно использовать переменную того же типа, что элемент массива, то это легко.

Если нельзя, то вспомни про xor.
Сначала научись переставлять с его помощью 2 любых элемента,
а дальше сообразишь сам.


 
}{enon ©   (2004-10-05 01:02) [18]

2 Sha
Цикл видимо не подходит: время выполнения будет зависеть от m и k...


 
jack128 ©   (2004-10-05 01:11) [19]

}{enon ©   (05.10.04 1:02) [18]
от k не будет.. А вот от m - да.  Я вообще не очень преставляю, как можно провести операцию над m элементами, чтобы время выполнения этой операции не зависило от m


 
}{enon ©   (2004-10-05 01:19) [20]

Примерно так:
type
 TValue = record
   v: integer;
   next: PValue;
 end;
 PValue = ^TValue;

Для того, чтобы переставить k элементов их m нужно поменять значение одной-двух переменных. Правда время поиска k-го элемента зависит от k, ну да черт с ним :)


 
Alex Konshin ©   (2004-10-05 01:35) [21]

Циклический двухсвязный список.


 
jack128 ©   (2004-10-05 02:01) [22]

}{enon ©   (05.10.04 1:19) [20]
Alex Konshin ©   (05.10.04 1:35) [21]
Господа, напоминаю, что речь идет не про список, а про массив!!!


 
Fay ©   (2004-10-05 02:29) [23]

Нужно просто пересмотреть своё отношение к индексу массива 8)


 
Ihor Osov'yak ©   (2004-10-05 02:34) [24]

хм..
В конце концов - массив - это некая абстракция, обеспечивающая доступ к элементу по индексу,  детали реализации которой скрываются за особенностями аппаратной платформы, компилятора, синтаксиса..  
Кто сказал, что элементы массива должны идти физически непрырывно и последовательно в памяти? Я имею ввиду общий случай.. И как пример - дос-платформа, модель памяти huge и массив размером больше, чем 64к.

Если принять все это во внимание, как вариант намбер ван -  создаем модель, в которой массив отбражается на кольцефой буфер. Собственно, в такой модели ничего и решать не нужно - сдвигаем только указатедь на первый элемент на нужное число позиций.  Время выполнения не будет зависить ни от n, ни от м...


 
Ihor Osov'yak ©   (2004-10-05 02:36) [25]

2 [23] Fay ©   (05.10.04 02:29)

Когда я писал свой опус, я Вашего сообщения еще не видел.


 
Fay ©   (2004-10-05 03:18) [26]

Ну что Вы, очень интересно было прочесть!
Приятно посмотреть, как когда человек так чётко и понятно выражает мысль - вещь эфемерную и стремительную.


 
Cobalt ©   (2004-10-05 08:48) [27]

Действительно, независимо от k - вряд ли получится.


 
Zlod3y ©   (2004-10-05 08:55) [28]

jack128 ©   (05.10.04 02:01) [22]

}{enon ©   (05.10.04 1:19) [20]
Alex Konshin ©   (05.10.04 1:35) [21]
Господа, напоминаю, что речь идет не про список, а про массив!!!


Какая разница? Посмотри на память и ты поймёшь, что это массив байтов! Пусть хоть список, хоть массив, хоть массив записей, строка, ну или просто куча переменных....всё-равно это массив! можно на асме реализовать это, не используя памяти, для этого есть регистры и работают они быстрее...в памяти только массив хранить, разумеется

Ihor Osov"yak ©   (05.10.04 02:34) [24]
Полностью согласен


 
Zlod3y ©   (2004-10-05 08:59) [29]

надо просто у каждого элемента поменять индекс? я прав?


 
Fay ©   (2004-10-05 09:11) [30]

2 Zlod3y ©   (05.10.04 08:59) [29]

Индекс существует только в голове программиста. Там и меняй - оставь массив в покое.


 
Igorek ©   (2004-10-05 13:35) [31]


> KilkennyCat ©   (05.10.04 00:25) [6]
> машина Поста

Можно поподробнее, что имелось ввиду?


> Ihor Osov"yak ©   (05.10.04 02:34) [24]
> хм..
> В конце концов - массив - это некая абстракция, обеспечивающая
> доступ к элементу по индексу,

Ты говоришь про список с индексированым доступом. А в таких задачах массив - это конкретная вещь. Блок памяти с элементами одинакового размера. Доступ по индексу осуществляется вычислением смещения от начала. Т.е. алгоритмические задачи решаются независимо от апаратной/операц. платформы с применением алгоритмического языка.
Соотв. народ немного путается. Можно реализовать на основе массива произвольные структуры данных - стеки, очереди, кольцевые буферы, связные списки, етс. но не наоборот.


 
KSergey ©   (2004-10-05 13:55) [32]

> [24] Ihor Osov"yak ©   (05.10.04 02:34)

Тут, видимо, надо определиться с термином "массив". Все же на мой взгляд - это

> [31] Igorek ©   (05.10.04 13:35)
> Доступ по индексу осуществляется вычислением смещения от начала.

Хотя я и безусловно согласен, что это лишь реализация, от которой легко абстрагироваться "вообще", однако если речь вести о некоем реально существующем компиляторе, то получается, что

1) либо надо менять его логику по доступу к элементу массива (т.е. по сути менять компилятор с учетом указанных требований: внешне здаваемое смещение первого элемета и реализация "цикличности")

2) либо менять циклы обхода массива (или, того хуже, методов доступа в конкретному элементу; фактически то же, что и 1, только реализация не внутри компилятора)

В принципе, вероятно вариант 2 и имелся в виду в плане "изменения взгляда" на проблему, однако можно ли это считать ответом на поставленный вопрос в том смысле, что мы рассматриваем не только саму по себе задачу "перестановки", а еще и полезное использование такого "иного взгляда" на мир (массив)?


 
Nikolay M. ©   (2004-10-05 13:59) [33]

Обращение к элементу массива путем Array[(m + k) mod m] спасет гиганта мысли?


 
TUser ©   (2004-10-05 14:01) [34]

Перестановку - перевораяиванием. Время = два эм, а чтобы от m не зависело, это я вообще не понимаю.

----->---------------------------------->

<-----<----------------------------------

---------------------------------->----->


 
Vitaly ©   (2004-10-05 14:06) [35]


> Обращение к элементу массива путем Array[(m + k) mod m]
> спасет гиганта мысли?

Это ОЧЕНЬ ДОЛГО (:о)), хотя от м точно не зависит.
Как и от ж.


 
DiamondShark ©   (2004-10-05 14:10) [36]

Вместо перестановки использовать функцию преобразования индекса.


 
KSergey ©   (2004-10-05 14:20) [37]

> [36] DiamondShark ©   (05.10.04 14:10)
> Вместо перестановки использовать функцию преобразования
> индекса.

Но будет ли это хорошо, кроме формального удовлетворения условиям задачи? Вот что мне не понятно во всем этом...


 
Igorek ©   (2004-10-05 14:33) [38]

Фактически надо обменять два блока памяти. Это можно сделать при помощи xor. xor доступна на двумя элементами. И если рассматривать условие формально, то можно просто изменить размер элемента до необходимого. Тогда xor над целыми блоками будет считаться одной операцией. И мы получим скорость O(1).


 
default ©   (2004-10-05 14:53) [39]

pipll ©   (05.10.04 00:19) [2]
я делал раньше без дополнительного массива
надо на бумажке поколдовать...
ничего особенного задачка


 
DiamondShark ©   (2004-10-05 14:54) [40]


> KSergey ©   (05.10.04 14:20) [37]
> > [36] DiamondShark ©   (05.10.04 14:10)
> > Вместо перестановки использовать функцию преобразования
> > индекса.
>
> Но будет ли это хорошо, кроме формального удовлетворения
> условиям задачи? Вот что мне не понятно во всем этом...


А "хорошо" -- это как?



Страницы: 1 2 вся ветка

Текущий архив: 2004.10.24;
Скачать: CL | DM;

Наверх




Память: 0.54 MB
Время: 0.073 c
1-1097500966
3J106UH
2004-10-11 17:22
2004.10.24
Помощь по по listbox и memo


1-1097152225
Strimer
2004-10-07 16:30
2004.10.24
TToolBar


1-1097330713
zep
2004-10-09 18:05
2004.10.24
image


1-1097073036
Programmer
2004-10-06 18:30
2004.10.24
Как трассировать dll?


4-1095444827
Antonmm2
2004-09-17 22:13
2004.10.24
Нажатие кнопок другого приложения





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский