Я предполагаю, что предлагаемое вами решение - проверить, все ли буквенно-цифровые символы находятся внутри строки. Этот метод не будет работать, потому что вы также должны учитывать длину строки, потому что можно получить строку, которая содержит все буквенно-цифровые символы плюс один специальный символ.
Если не считать вложенных тысяч операторов if для обнаружения не алфавитно-цифровых символов, это решение работает:
(я предполагаю, что Text
может быть повторен по , используя циклы for на основе диапазона)
Вы можете использовать std::find_if
#include <algorithm>
#include <iterator>
#include <cctype>
#include <iostream>
auto it = std::find_if(std::begin(Text), std::end(Text), [](const char c) {
return std::isalnum(c) == 0; // Not alphanumeric
});
if (it == std::end(Text)) {
std::cout << "Text is fine!";
} else {
std::cout << "Text contains non-alphanumeric character: '" << *it << "'";
}
std::cout << std::endl;