На главную Наши проекты:
Журнал   ·   Discuz!ML   ·   Wiki   ·   DRKB   ·   Помощь проекту
ПРАВИЛА FAQ Помощь Участники Календарь Избранное RSS
msm.ru
! ПРАВИЛА РАЗДЕЛА · FAQ раздела Delphi · Книги по Delphi
Пожалуйста, выделяйте текст программы тегом [сode=pas] ... [/сode]. Для этого используйте кнопку [code=pas] в форме ответа или комбобокс, если нужно вставить код на языке, отличном от Дельфи/Паскаля.
Следующие вопросы задаются очень часто, подробно разобраны в FAQ и, поэтому, будут безжалостно удаляться:
1. Преобразовать переменную типа String в тип PChar (PAnsiChar)
2. Как "свернуть" программу в трей.
3. Как "скрыться" от Ctrl + Alt + Del (заблокировать их и т.п.)
4. Как прочитать список файлов, поддиректорий в директории?
5. Как запустить программу/файл?
... (продолжение следует) ...

Вопросы, подробно описанные во встроенной справочной системе Delphi, не несут полезной тематической нагрузки, поэтому будут удаляться.
Запрещается создавать темы с просьбой выполнить какую-то работу за автора темы. Форум является средством общения и общего поиска решения. Вашу работу за Вас никто выполнять не будет.


Внимание
Попытки открытия обсуждений реализации вредоносного ПО, включая различные интерпретации спам-ботов, наказывается предупреждением на 30 дней.
Повторная попытка - 60 дней. Последующие попытки бан.
Мат в разделе - бан на три месяца...
Модераторы: jack128, D[u]fa, Shaggy, Rouse_
  
> Посоветуйте алгоритм не случайной генерации чисел на основе исходных данных
    Вобщем нужен алгоритм который на основе входных данных типа TBytes выдавал число в диапазоне от 1 до максимума.

    Мой нубский вариант ниже. Предложите чтонить более интересное ...

    ExpandedWrap disabled
      function GetRoundsFromKey(Key: TBytes; MaxRounds: Integer): Integer;
       
      uses SynCommons;
       
      var
        I: Integer;
        S: string;
        K: Int64;
      begin
        S :=  SynCommons.crc64c( @Key[0], Length(Key) ).ToString ;
        for I := 0 to 40 do
        begin
          K := SynCommons.crc64c( PAnsiChar(S), Length(S) );
          S := K.ToString;
        end;
       
        if K < 0 then
        while K < 0 do
        begin
            K := SynCommons.crc64c( PAnsiChar(S), Length(S) );
            S := K.ToString;
        end;
       
        while MaxRounds < K do K := (K div 3)-MaxRounds;
       
        if K < 0 then  K := K * -1;
       
        Result := K;
      end;


    Добавлено
    Поясню зачем это: кол-во раундов для aes на основе ключа
    Сообщение отредактировано: Jiro -
      Зачем данные копируются? Зачем к результату ещё несколько раз применяется кодирование?

      В общем, любая хэш-функция или функция для контрольной суммы применяется к массиву, потом от результата берется модуль по Max значению
      Сообщение отредактировано: MBo -
        MBo

        RE: Зачем данные копируются?
        это из старых модификаций осталось, пока вы читали я уже поправил.))
        RE: Зачем к результату ещё несколько раз применяется кодирование?
        для загадочности. :P

        RE: потом от результата берется модуль по Max значению

        Хорошая мысля, как-то не подумал про это.
        Сообщение отредактировано: Jiro -
        0 пользователей читают эту тему (0 гостей и 0 скрытых пользователей)
        0 пользователей:


        Рейтинг@Mail.ru
        [ Script execution time: 0,0196 ]   [ 17 queries used ]   [ Generated: 26.04.24, 07:13 GMT ]