Недавно добавленные исходники

•  TDictionary Custom Sort  1 861

•  Fast Watermark Sources  1 885

•  3D Designer  3 315

•  Sik Screen Capture  2 304

•  Patch Maker  2 479

•  Айболит (remote control)  2 303

•  ListBox Drag & Drop  1 906

•  Доска для игры Реверси  69 747

•  Графические эффекты  2 501

•  Рисование по маске  2 035

•  Перетаскивание изображений  1 594

•  Canvas Drawing  1 595

•  Рисование Луны  1 611

•  Поворот изображения  1 230

•  Рисование стержней  1 277

•  Paint on Shape  914

•  Генератор кроссвордов  1 427

•  Головоломка Paletto  1 110

•  Теорема Монжа об окружностях  1 454

•  Пазл Numbrix  1 029

•  Заборы и коммивояжеры  1 304

•  Игра HIP  870

•  Игра Go (Го)  830

•  Симулятор лифта  969

•  Программа укладки плитки  806

•  Генератор лабиринта  967

•  Проверка числового ввода  869

•  HEX View  1 001

•  Физический маятник  872

•  Задача коммивояжера  921

 
скрыть


Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Функция для разворачивания строк



Автор: DiVo

{ **** UBPFD *********** by delphibase.endimus.com ****
>> Функция для "разворачивания" строк

Входные параметры:
Input - входная строка, которую необходимо представить в "развернутом виде"

Зависимости: стандартный набор включаемых модулей
Автор:       Ru, DiVo_Ru@rambler.ru, Одесса
Copyright:   DiVo 2002, creator Ru
Дата:        12 ноября 2002 г.
***************************************************** }

function DecStr(Input: string): string;
var
  i, j, t: integer;
  s: string;
begin
  if pos('-', Input) <> 0 then
  begin
    while length(Input) <> 0 do
    begin
      if Input[1] = ',' then
      begin
        i := strtoint(s);
        delete(Input, 1, 1);
        result := result + s + ',';
        s := '';
      end
      else
      begin
        if Input[1] = '-' then
        begin
          i := strtoint(s);
          delete(Input, 1, 1);
          t := pos(',', Input);
          result := result + s + ',';
          s := '';
          if t = 0 then
          begin
            j := strtoint(Input);
            Input := '';
          end
          else
          begin
            j := strtoint(copy(Input, 1, t - 1));
            delete(Input, 1, t);
          end;
          inc(i);
          while i < j + 1 do
          begin
            result := result + inttostr(i) + ',';
            inc(i);
          end;
        end
        else
        begin
          s := s + Input[1];
          delete(Input, 1, 1);
        end;
      end;
    end;
  end
  else
    result := Input;
  if s <> '' then
    result := result + s;
end;
на входе: 1,3,5-10,15
на выходе: 1,3,5,6,7,8,9,10,15 




Похожие по теме исходники

Нейросеть для распознавания образов

Механизм станка качалки для нефти

Весы для взвешивания

Кувшины для воды

 

Доска для игры Реверси




Copyright © 2004-2023 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте   Facebook   Ссылка на Twitter   Ссылка на Telegram