Форум программистов, компьютерный форум, киберфорум
C/C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
 Аватар для bedvit
1210 / 261 / 22
Регистрация: 20.05.2016
Сообщений: 1,147
Записей в блоге: 22

Реализация LIKE как в VB или SQL на С++ или Си

04.06.2023, 10:06. Показов 12794. Ответов 62
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Мое почтение, джентльмены.
Нужна быстрая реализация LIKE как в VB или SQL (алгоритм аналогичный) на С++ или Си.

Из вменяемого нашел только часть алгоритма (ссылка не вставляется, напишу ниже). А так же в Win32 SymMatchString(), которая на порядок медленее чем моя текущая реализация.

Не хочу колхозить свой велосипед, возможно кто-то сможет поделится проверенным алгоритмом.

Добавлено через 11 минут
Из stackoverflow: Как-проверить-соответствие-имени-файла-маске
Маска может содержать:
? - означает 1 любой символ
* - означает 0 или более любых символов
любые другие символы означают сами себя
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
bool check(char *s, char *p)
{
char *rs=0, *rp;
while(1)
  if(*p=='*')
    rs=s, rp=++p;
  else if(!*s)
    return !*p;
  else if(*s==*p || *p=='?')
    ++s, ++p;
  else if(rs)
    s=++rs, p=rp;
  else
    return false;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.06.2023, 10:06
Ответы с готовыми решениями:

Реализация Round Robin Algoritm, данные должны храниться или в памяти, или на внешнем SQL хранилище
Добрый день Уважаемое сообщество! Порекомендуйте аналог RRDLib на C#. NHawk и другие врапперы к RRDTool не предлагать по причине...

Есть ли в VB или в ADO, DAO или RDO функция преобразования MS SQL типов данных в MS Access?
Существует ли встроенная функция перевода типов данных SQL в Access, Paradox, Dbase и пр.?

Создайте приложение с SQL Server 2012 (или более поздней версии), .NET 4.8 и Entity Framework 6.2 (или 6.4) с по
Привет, мне дали такую задачу и у меня достаточно мало времени, 3-4 дня. Нужно его сделать и одновременно разобраться как это сделать...

62
 Аватар для bedvit
1210 / 261 / 22
Регистрация: 20.05.2016
Сообщений: 1,147
Записей в блоге: 22
10.05.2025, 11:55  [ТС]
Студворк — интернет-сервис помощи студентам
DrOffset, я больше к Си-строкам акцентировал свое внимание (что в Си-коде не обязательно Си строки можно обрабатывать), а с выбросом исключений у меня как раз сейчас и вопрос - нужны ли они? Можно оформить код в стиле C++, а исключения, к примеру std::regex_error (можно и любые другие: std::runtime_error и т.д., просто у меня есть и регулярки, это в общей обвязке будет органичнее смотреться), тогда к платформе не привязываемся или вообще отключить исключения и возвращать false, чисто в Си парадигме (мне не принципиально чисто в Си или нет, у меня С/С++ по большей части).

Собственно в этом и вопрос к форуму (с которого я и вернулся в эту тему), какой вариант и с каким обоснованием считаете правильным?
0
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
10.05.2025, 17:33
Цитата Сообщение от bedvit Посмотреть сообщение
что в Си-коде не обязательно Си строки можно обрабатывать
Речь шла про то, что ваш код работает с диапазоном, а не с нуль-терминатором? Ну тогда да, согласен, что это недостаток того кода. А я сперва-то подумал, что у вас в целом к массивам char\wchar вопрос. А ничего кроме них в Си и недоступно.

Цитата Сообщение от bedvit Посмотреть сообщение
Можно оформить код в стиле C++, а исключения, к примеру std::regex_error (можно и любые другие: std::runtime_error и т.д., просто у меня есть и регулярки, это в общей обвязке будет органичнее смотреться), тогда к платформе не привязываемся или вообще отключить исключения и возвращать false, чисто в Си парадигме (мне не принципиально чисто в Си или нет, у меня С/С++ по большей части).
В современном C++ можно std::expected использовать.
https://en.cppreference.com/w/cpp/utility/expected
0
 Аватар для bedvit
1210 / 261 / 22
Регистрация: 20.05.2016
Сообщений: 1,147
Записей в блоге: 22
12.05.2025, 22:08  [ТС]
Цитата Сообщение от DrOffset Посмотреть сообщение
std::expected
не знал, что за зверь. Прочитал. Интересный подход. Под определенные задачи или определенного рода проекты, требует С++23. Я пока на С++20.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.05.2025, 22:08

SQL или Visual Basic? Или Макросы?
Здравствуйте. Делая проект по заданию базы для избирательного, столкнулась с такой проблемой - в мою готовую базу данных Access...

Как получить индекс элемента (или его позицию или количество элементов до него) в set или multiset от lower_bound?
не работающий код((( #include<bits/stdc++.h> #define ff first #define ss second #define ll long long // #define int long...

Есть ли такая функция даты SQL которая позволяет вытащить записи по опред году, или месяцу или дню
не используя оператор like

Как лучше и быстрее из SQL в QVector и в GUI или сразу из SQL в GUI
Доброе время суток! Ну собственно вопрос в теме, как лучше сделать. Сначала прочитать SQLite в вектор и работать с ним и оставить файл...

Что лучше, учить команды CMD или BASH или PowerShell или все они важны или лучше язык программирования?
В заголовке имел в виду, что если изучаю распространенный язык программирования, например Python, то команды из этих сред командных...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
63
Ответ Создать тему
Новые блоги и статьи
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы ### Аннотация Представлено исследование по разработке агентной модели микоризной. . .
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru