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

Вниз

Вопрос только для Мастеров/прикладных программистов.   Найти похожие ветки 

 
Evgeniy K   (2003-01-19 14:50) [0]

Вопросик не для глупых.

Предпложим у меня есть матрица n*n, где n<251
Матрица заполнена числами.
1 3 4 10 15 ..
2 5 9 14 ..
4 8 13 ..
7 12 ..
11 ..

и т.д.
Мне дано какое-то число k. Как мне найти "координаты" этого числа в таблице?
Желательно чтобы на проверку 250^2 (250*250) чисел (k) уходило не более 1 сек.
Заранее все спасибо, кто хоть чем-то поможет.

PS Перебирать все числа нет смысла - времени не хватит, а как проще пока не догадался, поэтому и прошу вашей помощи, Мастера.
PSS Может формулу кто-нибудь знает?


 
Reindeer Moss Eater   (2003-01-19 14:53) [1]

С помощью чего реализована матрица?


 
Романов Р.В.   (2003-01-19 15:13) [2]

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


 
NailS   (2003-01-19 16:19) [3]

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


 
Reindeer Moss Eater   (2003-01-19 16:25) [4]

Матрица заполнена по тому же принципу, что в исходном сообщении или произвольно?
Да никакой разницы нет, как она на самом деле заполнена.
Важнее то, как её элементы расположены в памяти. Непрерывным блоком или нет. Если непрерывным, то перебора элементов по индексам можно избежать.


 
Sha   (2003-01-19 17:05) [5]

> Evgeniy K (19.01.03 14:50)
> Вопросик не для глупых.

Начал неправильно. Сам-то к каким относишься?
Если не глуп, то легко найдешь ответ.



 
Mystic   (2003-01-19 17:08) [6]

Наверняка не самое оптимальное, но работает быстрее 1 мин ;)

I := 2;
Step := 2;
while I <= N do
begin
I := I + Step;
Step := Step + 1;
end;
X := N + Step - I;
Y := Step - X;


 
MBo   (2003-01-19 17:17) [7]

j:=1;
while a[1,j]<k do
inc(j);
i:=j-(a[1,j]-k);

i,j - строка, столбец.


 
gsu   (2003-01-19 18:00) [8]

Забежал на сек, интересно !
Вот, те прикладная рекурсия (-:|~
x ={0,n} - столбцы
y={0,n} - строки
diag(0)=1
diag(m)=diag(m-1)+m, m={1..n-1}
pair(x,y)=diag(x+y)+y
Вот и все, например: pair(1,2)=diag(3)+2=9


 
gsu   (2003-01-19 18:01) [9]

И причем здесь глупость ?
Глупых не бывает, бывают ленивые и/или упертые


 
Sha   (2003-01-19 18:19) [10]

2 MBo © (19.01.03 17:17)
2 gsu © (19.01.03 18:00)

есть способ проще:

procedure TForm1.Button2Click(Sender: TObject);
var
k, n, m: integer;
begin;
k:=14;
n:=0; m:=0;
repeat;
inc(n); inc(m,n);
until m>=k;
m:=m-k+1;
n:=n-m+1;
ShowMessage(Format("%d находится в строке %d колонке %d",[k,m,n]));
end;



2 Evgeniy K (19.01.03 14:50)
А вообще-то нехорошо начинать ветку так Вопрос только для Мастеров.
Остальным типа не соваться в мою ветку. Хочу с Мастерами говорить.


 
Sha   (2003-01-19 18:24) [11]

2 Mystic © (19.01.03 17:08)

Извини, у нас совпало :)


 
gsu   (2003-01-19 18:40) [12]

Что может быть проще рукурсии ? (-:|~
Говорят, что все создано из пяти основных эл-тов и рекурсии, н-р, у человека 5 пальцев, 5 ...
Но я в этом не уверен, так как не создатель (-:|~


 
gsu   (2003-01-19 18:42) [13]

>> Хочу с Мастерами говорить.
типа, у мя проездной (-:|~


 
Sha   (2003-01-19 18:52) [14]

> gsu © (19.01.03 18:40)
> Что может быть проще рукурсии ? (-:|~

Не лукавишь? Для меня цикл намного проще. Когда в задаче встречается рекурсия приходится как-то непроизвольно собираться. Затянувшееся последействие института. :(


 
gsu   (2003-01-19 19:29) [15]

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


 
Sha   (2003-01-19 22:14) [16]

> gsu © (19.01.03 19:29)
> но благодаря супер учителям (подготовка) и опосля, реализациям
> всяких мат. методов меня рекурсия начала радовать

даже по нескольким переменным идет без напряга?


 
gsu   (2003-01-19 23:08) [17]

>> даже по нескольким переменным идет без напряга?
Если б слушал все, чему учили (-:|~
Конечно нет. Я и не говорил, что это легко и я мастер рекурсии, так ..., ничего особого


 
Sha   (2003-01-19 23:54) [18]

2 gsu © (19.01.03 23:08)

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


 
gsu   (2003-01-20 00:27) [19]

Раз поучительно, то я готов ее обозреть, если те не трудно


 
atmamont   (2003-01-20 01:06) [20]

а что, матрица вообще никаким законам распределения не поддается?


 
NailS   (2003-01-20 10:06) [21]


> Reindeer Moss Eater (19.01.03 16:25)
> Матрица заполнена по тому же принципу, что в исходном сообщении
> или произвольно?
> Да никакой разницы нет, как она на самом деле заполнена.

Честно?
А мне казалось, что если известен алгоритм заполнения матрицы то искомый элемент можно просто вычислить.


> MBo © (19.01.03 17:17)
> j:=1;
> while a[1,j]<k do
> inc(j);
> i:=j-(a[1,j]-k);

А если использовать метод деления попалам, то еще быстрее будет ;))


 
MBo   (2003-01-20 10:32) [22]

>NailS
Да можно сразу решить уравнение n(n+1)/2<=k
;)



 
Sha   (2003-01-20 11:09) [23]

> gsu © (20.01.03 00:27)
> Раз поучительно, то я готов ее обозреть, если те не трудно

ветка была такая http: //delphi.mastak.ru/cgi-bin/forum.pl?look=1&id=1040816965&n=3
но вроде умерла.

Называлась Задача для разминки мозгов

> Сатир © (25.12.02 14:49)
> есть ряд натуральных чисел от 1 до N
> есть число K
> Определить число комбинаций членов ряда, которые в сумме дадут K.
> Рассмотреть все варианты.




 
gsu   (2003-01-20 11:16) [24]

>> но вроде умерла.
умёрла ? жаль.

>> Сатир © (25.12.02 14:49)
но это ж комбинаторика.

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


 
Думкин   (2003-01-20 11:45) [25]


> Sha © (20.01.03 11:09)
> Называлась Задача для разминки мозгов


> gsu © (20.01.03 11:16)
> >> Сатир © (25.12.02 14:49)
> но это ж комбинаторика.

Эта задача еще у Кнута упоминается, в самом первом томе в самом начале.


 
gsu   (2003-01-20 12:05) [26]

>> Думкин ©
Может Сатир"у в институте такое задание дали(-:|~


 
Evgeniy_k   (2003-01-20 13:34) [27]

Большое спасибо. Посмотрю, попробую. Потом сообщу что получилось ;)


 
Evgeniy_k   (2003-01-20 13:51) [28]

Я маленько описался, когда писал матрицу. Вот вам пример матрици, где n=5:
1 3 6 10 15
2 5 9 14 19
4 8 13 18 22
7 12 17 21 24
11 16 20 23 25

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

> Желательно чтобы на проверку 250^2 (250*250) чисел (k) уходило не более 1 сек.
Это значит, что координаты числа k будет искаться в матрице 62500 раз (на это должно уйти не более 1 сек).

> Начал неправильно. Сам-то к каким относишься?
> Если не глуп, то легко найдешь ответ.
Уже вроде нашел, но пока только в теории.


 
Sha   (2003-01-20 13:58) [29]

> gsu © (20.01.03 11:16)
> умёрла ? жаль.
Ничто не мешает тебе ее решить.

> gsu © (20.01.03 11:16)
> Кстати у рекурсии и циклов разные области применения ...
Так говорят твои учителя?

> Думкин © (20.01.03 11:45)
> Эта задача еще у Кнута упоминается, в самом первом томе в самом начале.
Кнута читал давно, задачу эту не решал, наверное, посчитал очевидной. А когда недавно решил и рекурсией и циклом, получил глубокое удовлетворение. :)



 
Думкин   (2003-01-20 14:17) [30]


> > Думкин © (20.01.03 11:45)
> > Эта задача еще у Кнута упоминается, в самом первом томе
> в самом начале.
> Кнута читал давно, задачу эту не решал, наверное, посчитал
> очевидной. А когда недавно решил и рекурсией и циклом, получил
> глубокое удовлетворение. :)

У Кнута она не в плане нахождения решения приводится - запрограммировать ее - два пальца об асфальт. Эффективность только может сильно варьировать.
Там про что-то другое он писал - там в этой связи и Рамануджан упоминается.


 
gsu   (2003-01-20 15:05) [31]

>> Sha ©
>> Ничто не мешает тебе ее решить
и еще миллион задач из учебника, нет спасибо

>> Так говорят твои учителя?
хм, каждому свое, ...


 
Sha   (2003-01-21 00:35) [32]

> Думкин © (20.01.03 14:17)
> Эффективность только может сильно варьировать.

О том и речь. У меня получилось штук 5 вариантов с разной эффективностью.


> gsu © (20.01.03 00:27)
> Раз поучительно, то я готов ее обозреть, если те не трудно
> gsu © (20.01.03 15:05)
> ..и еще миллион задач из учебника, нет спасибо

Зачем обозревал-то? :)))



 
gsu   (2003-01-21 02:15) [33]

>> Sha ©
Из уважения к вам, да и только, хоть вы и без медали (-:|~


 
Думкин   (2003-01-21 06:46) [34]

Если матрица фиксирована и имеет всего 250 значений - зачем по ней лазить 65000 раз? В самом начале заполняем массив из 250 элементов соответствующими координатами - потом 65000 раз считываем значения этого массива - это уж точно в 1 сек уложится, если конечно у вас не арифмометр.

Про Кнута - он на примере этой задачи дает пример неверного индукционного предположения.

> и еще миллион задач из учебника, нет спасибо
А другого пути просто нет.


 
Robin Bobin   (2003-01-21 09:55) [35]

Сдедай проще, знаешь как старая добрая игра "УГАДАЙ ЧИСЛО" ,делишь на 2, если больше, то делишь правую, если меньше, левую, итого, колличество проверок уменьшается в геометрической прогресиии. Дерзай мастер, можеш учебник по теории вероятности почитать...


 
MBo   (2003-01-21 10:33) [36]

>Evgeniy_k
До чего же ты ленив ;(


procedure TForm1.Button1Click(Sender: TObject);
var
n, k, kk, x, y, d, diff: integer;
procedure Calc;
begin
d := Ceil((Sqrt(1 + 8 * k) - 1) / 2);
diff := (d * (d + 1) div 2) - k;
y := diff + 1;
x := d - diff;
end;
begin
n := updown2.position;
kk := updown1.position;
if (kk <= 0) or (kk > n * n) then
begin
label1.caption := format("%d: Не входит в таблицу!", [kk]);
Exit;
end;
k := kk;
if k <= n * (n + 1) div 2 then
Calc
else
begin
k := n * n + 1 - k;
Calc;
x := n + 1 - x;
y := n + 1 - y;
end;
label1.caption := format("%d: %d строка %d столбец", [kk, y, x]);
end;




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

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

Наверх




Память: 0.53 MB
Время: 0.01 c
8-96885
psv
2002-10-15 15:33
2003.01.30
Движение лоттотрона


14-97028
blackman
2003-01-13 22:38
2003.01.30
Цивилизованный рынок ПО с советским лицом


14-97032
Alexsys
2003-01-12 11:30
2003.01.30
Как посмотреть Video CD для PlayStacion на компьютере?


7-97062
kloksus
2002-11-17 15:42
2003.01.30
Работа с реестром


1-96684
BofA
2003-01-21 19:16
2003.01.30
Как правильно рисовать на Canvas е у TImage?





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский