【查找指定字符串首位置与数量不区分大小写完整匹配】2025-5-3

缘由2019北京海淀(小学)选拔 义卖(sale)_编程语言-CSDN问答

不调用系统函数,自己写实现;不开数组,直接输入字符串;判断处理大小写、空格、结尾,主循环O(N),完全匹配查找字符串数量,若用数组存储位置下标,可迅速定位。

实现方法:第一字符匹配后,启动完全匹配配对循环,到结束或空格的处理;若第一字符不匹配则主循环到空格布尔状态切换或结束止。

cpp 复制代码
void 查找指定字符串首位置与数量不区分大小写完整匹配()
{
	std::string a = "to be or not to be is a question Ottoman TO TOTO to", c = "To";
	//std::cin >> c >> a;
	int n = 0, d = 0, x = 0, j = 0, s = 0;
	bool k = 1;
js:if (a[x] != '\0')
{
	   if (k && (a[x + j] == c[j] || abs(a[x + j] - c[j])==32))
	   {
		   if (c[j] != '\0')
			   ++j;
		   else if (a[x + j] == ' ' || a[x + j] == '\0')
		   {

			   if (++d == 1)
				   s = x;
			   x += j, j = 0;
			   if (a[x + j] == ' ')++x;
		   }
		   else
			   ;
	   }
	   else
	   {
		   j = k = 0;
		   ++x;
		   if (a[x] == ' ')
			   k = 1, ++x;
	   }
	   goto js;
}
   if(d)std::cout << d << " " << s << "\n";
   else std::cout << "-1\n";
}
相关推荐
BothSavage14 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn14 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽15 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
郝学胜_神的一滴15 小时前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天1 天前
C++ 基础入门完全指南
c++
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构