|
22 / 9 / 2
Регистрация: 16.10.2010
Сообщений: 115
|
|
Ранжирование по приоритету24.03.2012, 14:57. Показов 1736. Ответов 3
Метки нет (Все метки)
Здравствуйте, уважаемые пользователи форума..
Подскажите, пожалуйста, как получше проранжировать строки DBGrid'a, (с условием того, что максимизируется по первым трем столбцам-ОВ,В,С, и минимизируется по столбцу Н). Т.е. ранжирование будет выглядеть примерно так, как показано на рисунке. Не знаю, как реализовать это программно, разве что описывая каждую ситуацию болоком if-then-else. Может есть какой нибудь более простой и лаконичный способ, подскажите, пожалуйста.
0
|
|
| 24.03.2012, 14:57 | |
|
Ответы с готовыми решениями:
3
рандом по приоритету Выполнение по приоритету на МКУ
|
|
22 / 9 / 2
Регистрация: 16.10.2010
Сообщений: 115
|
|
| 26.03.2012, 17:37 [ТС] | |
|
Ранжирование - это фактически сортировка, но записи не должны переставляться, а вместо этого каждой записи присваивается ранг по возрастанию например.
Вот я не знаю как сделать это хорошо.. т.к., если брать полный перебор, т.е. 4 цикла по 15 элементов в каждом, то прога "встанет". ибо обработать 50 с лишним тысяч записей почти что нереально. а как обойтись без перебора не знаю, т.к. программа должна быть фактически универсальной. т.е. любой набор чисел в строке по столбцам ОВ,В,С,Н в сумме должен быть =15. Добавлено через 49 секунд Подскажите плиз, как это сделать
0
|
|
|
87 / 87 / 1
Регистрация: 30.06.2011
Сообщений: 123
|
|
| 26.03.2012, 19:21 | |
|
Думаю возможно как-то так....
void __fastcall TForm1::Button4Click(TObject *Sender) { ADOQuery1->SQL->Clear(); ADOQuery1->SQL->Text = "select *from BazaDanih order by OB,B,C,H"; ADOQuery1->Open(); DataSource1->DataSet = ADOQuery1; int i = 0; ADOTable1->First(); for (i=ADOQuery1->RecordCount; i>=1; i--) { if ((ADOQuery1OB->Value+ ADOQuery1B->Value+ADOQuery1C->Value+ADOQuery1H->Value)==StrToInT(Edit1->Text)) { //Edit1 - Максимальный Ранг при сложении DataSource1->DataSet->Edit(); DataSource1->DataSet->FieldByName("Sort1")->Value = IntToStr(i); DataSource1->DataSet->Post(); ADOQuery1->Next(); } else Label1->Caption ="Введите правильные значения"; } } Добавлено через 2 минуты то-есть В Sort1 выводиться сам ранг. в убывающем порядке
1
|
|
| 26.03.2012, 19:21 | |
|
Помогаю со студенческими работами здесь
4
GPSS выход из очереди по приоритету Удалить дубликаты с условием по приоритету Надо сделать новый список с выборкой из существующего списка listCounter по приоритету Определить строку, в которой правильно записан порядок операций по приоритету от высшего к низшему Ранжирование Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. .
Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
|
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла:
Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
|
|
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-text-sdl3-c. zip
finish-text-sdl3-cpp. zip
|
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
|
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo
Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло.
Но на выплатах по больничным это. . .
|
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2. Данные берутся из. . .
|