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

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

04.06.2023, 10:06. Показов 12149. Ответов 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
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,822
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
Ответ Создать тему
Новые блоги и статьи
Хитросплетение родственных связей пантеона греческих богов.
russiannick 14.05.2026
Однооконник, позволяющий узреть и изучить отдельных героев древней Греции. <!DOCTYPE html> <html lang="ru"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible". . .
[golang] Угол между стрелками часов
alhaos 12.05.2026
По заданным значениям часа и минуты необходимо определить значение меньшего угла между стрелками аналогового циферблата часов. import "math" func angleClock(hour int, minutes int) float64 { . . .
Debian 13: Установка Lazarus QT5
ВитГо 09.05.2026
Эта инструкция моя компиляция инструкций volvo https:/ / www. cyberforum. ru/ blogs/ 203668/ 10753. html и его же старой инструкции по установке Lazarus с gtk2. . .
Нейросеть на алгоритме "эстафета хвоста" как перспектива.
Hrethgir 06.05.2026
На десерт, когда запущу сервер. Статья тут https:/ / habr. com/ ru/ articles/ 1030914/ . Автор я сам, нейросеть только помогает в вопросах которые мне не известны - не знаю людей которые знали-бы. . .
Асинхронный приём данных из COM-порта
Argus19 01.05.2026
Асинхронный приём данных из COM-порта Купил на aliexpress термопринтер QR701. Он оказался странным. Поключил к Arduino Nano. Был очень удивлён. Наотрез отказывается печатать русские буквы. Чтобы. . .
попытка написать игровой сервер на C++
pyirrlicht 29.04.2026
попытка написать игровой сервер на плюсах с открытым бесконечным миром. возможно получится прикрутить интерпретатор питон для кастомизации игровой логики. что есть на текущий момент:. . .
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru