Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 14.03.2008, 12:56
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию Вопрос по массиву чисел.

Подскажите пожалуйста, как мне реализовать следующее:

1) Объявляем числовой массив A[i].
2) Производим перебор от i=1 до n и сравниваем с произвольным числом k. В случае, когда i совпадет с k, значение i добавляем в массив.
3) Снова производим перебор i (от первого до n, но исключая число, что уже добавили в массив), сравниваем с другим произвольным числом l.
В случае, когда i совпадет с l, значение i добавляем в массив.
В массиве теперь два значения.
4)
И т.д.

Это не задачка из учебника, просто нужно для моего проекта.
Заранее спасибо.
Ответить с цитированием
  #2  
Старый 14.03.2008, 13:16
Rosenkrantz Rosenkrantz вне форума
Активный
 
Регистрация: 04.12.2007
Адрес: Москва
Сообщения: 234
Версия Delphi: Delphi 7
Репутация: 40
По умолчанию

Я правильно понял, что добавление в массив происходит когда i = k? Вопрос - зачем перебор нужен? Почему сразу не добавлять k на нужное место в массиве?
Ответить с цитированием
  #3  
Старый 14.03.2008, 14:42
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию

k заранее неизвестно, поэтому сразу добавить в массив нельзя.
Да не в этом суть. Допустим я выяснил чему равна k, как добавить ее в массив? и как сделать следующий цикл уже исключая это значение?
Ответить с цитированием
  #4  
Старый 14.03.2008, 15:05
Аватар для The Shadow
The Shadow The Shadow вне форума
Продвинутый
 
Регистрация: 11.06.2007
Адрес: Уфа, Россия
Сообщения: 793
Репутация: 35
По умолчанию

Если я правильно понял:
Код:
var
Result: Array of Integer;
procedure GetNumbers(A: Array of Integer; Numbers: Array of Integer);
var
i, j: Integer;
begin
SetLength(Result, 0);
for i:=0 to Length(Numbers) - 1 do
for j:=0 to Length(A) - 1 do
if A[j] = Numbers[i] then
begin
SetLength(Result, Length(Result) + 1);
Result[Length(Result) - 1]:=j;
end;
end;
__________________
Что делать, когда сломался комп:
1. Если вы юзер - делать ноги.
2. Если ремонтник - делать деньги.
3. Если вы программист - делать вид, что так было задумано.
Ответить с цитированием
  #5  
Старый 14.03.2008, 15:51
Terio Terio вне форума
Новичок
 
Регистрация: 16.01.2008
Сообщения: 56
Репутация: 10
По умолчанию

Спасибо! буду пробовать.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 04:43.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter