leetcode:438. 找到字符串中所有字母异位词

给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。

异位词 指由相同字母重排列形成的字符串(包括相同的字符串)。

示例 1:

输入: s = "cbaebabacd", p = "abc"
输出: [0,6]
解释:
起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。
起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。

 示例 2:

输入: s = "abab", p = "ab"
输出: [0,1,2]
解释:
起始索引等于 0 的子串是 "ab", 它是 "ab" 的异位词。
起始索引等于 1 的子串是 "ba", 它是 "ab" 的异位词。
起始索引等于 2 的子串是 "ab", 它是 "ab" 的异位词。

提示:

  • 1 <= s.length, p.length <= 3 * 104
  • s 和 p 仅包含小写字母

一开始我仍采用之前哈希使用的累加和的办法,但是出现了一些问题:

会有不同的字符串加起来和相同。

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* findAnagrams(char * s, char * p, int* returnSize){int len=strlen(p);int lens=strlen(s);int tar=0;*returnSize=0;int* result=(int*)malloc(lens*sizeof(int));for(int i=0;i<len;i++){tar+=(int)p[i];}for(int j=0;j<=lens-len;j++){int tars=0;for(int i=0;i<len;i++){tars+=(int)s[j+i];}if(tars==tar){result[*returnSize]=j;(*returnSize)++;}}return result;
}

改进:

引入一个单词表来记录:

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* findAnagrams(char * s, char * p, int* returnSize){int len = strlen(p);int lens = strlen(s);*returnSize = 0;int* result = (int*)malloc(lens * sizeof(int));int tar = 0;int p_count[256] = {0};int s_count[256] = {0};for(int i = 0; i < len; i++){p_count[(int)p[i]]++;tar += (int)p[i];}for(int j = 0; j <= lens - len; j++){int tars = 0;memset(s_count, 0, sizeof(s_count));for(int i = 0; i < len; i++){s_count[(int)s[j + i]]++;tars += (int)s[j + i];}if(tars == tar && memcmp(p_count, s_count, sizeof(p_count)) == 0) {result[*returnSize] = j;(*returnSize)++;}}// Reallocate memory to fit the actual size of the result arrayresult = (int*)realloc(result, (*returnSize) * sizeof(int));return result;
}

使用滑动窗口和计数排序

写的时候一直报错,后来发现,居然有lens<len的情况,直接无效没有考虑到!!!!!!!

/*** Note: The returned array must be malloced, assume caller calls free().*/
int* findAnagrams(char * s, char * p, int* returnSize){int len = strlen(p);int lens = strlen(s);*returnSize = 0;int* result = (int*)malloc(lens * sizeof(int));if (len > lens) {return result;}// Initialize character count arraysint p_count[26] = {0};int s_count[26] = {0};for(int i = 0; i < len; i++){p_count[p[i] - 'a']++;s_count[s[i] - 'a']++;}for(int j = 0; j <= lens - len; j++){if(memcmp(p_count, s_count, sizeof(p_count)) == 0) {result[*returnSize] = j;(*returnSize)++;}// Slide the windowif(j + len < lens){s_count[s[j] - 'a']--;s_count[s[j + len] - 'a']++;}}// Reallocate memory to fit the actual size of the result arrayresult = (int*)realloc(result, (*returnSize) * sizeof(int));return result;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/636320.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用Python爬取易车网汽车信息(含x-sign参数逆向分析)

文章目录 1. 写在前面2. 接口分析3. 断点分析3. 算法还原 【&#x1f3e0;作者主页】&#xff1a;吴秋霖 【&#x1f4bc;作者介绍】&#xff1a;擅长爬虫与JS加密逆向分析&#xff01;Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路走来长期坚守并致…

Java如何实现List的反转

hi&#xff0c;我是程序员王也&#xff0c;一个资深Java开发工程师&#xff0c;平时十分热衷于技术副业变现和各种搞钱项目的程序员~&#xff0c;如果你也是&#xff0c;可以一起交流交流。 今天我们来聊聊Java中实现List反转~ List反转的基本概念 在Java中&#xff0c;反转一…

RK3568 学习笔记 : u-boot 通过 tftp 网络更新 u-boot自身

前言 开发板型号&#xff1a; 【正点原子】 的 RK3568 开发板 AtomPi-CA1 使用 虚拟机 ubuntu 20.04 收到单独 编译 RK3568 u-boot 使用 rockchip Linux 内核的设备树 【替换】 u-boot 下的 rk3568 开发板设备树文件&#xff0c;解决 u-boot 下千兆网卡设备能识别但是无法 Pi…

B树(B-tree)

B树(B-tree) B树(B-tree)是一种自平衡的多路查找树&#xff0c;主要用于磁盘或其他直接存取的辅助存储设备 B树能够保持数据有序&#xff0c;并允许在对数时间内完成查找、插入及删除等操作 这种数据结构常被应用在数据库和文件系统的实现上 B树的特点包括&#xff1a; B树为…

AD设置覆铜与板子边缘间隔

1、设置板子边缘与覆铜间隔原因 在单个制板或者批量制板时&#xff0c;有时由于机器切割不稳定&#xff0c;造成切到覆铜&#xff0c;板子容易不稳定。为了保证机器切割不切到覆铜&#xff0c;我们可以设置覆铜到板子边缘的间隔。 2、设置方式 打开Design--->Rules&#…

pycharm创建的项目

pycharm生成django templates删出 settings.py

Vue 指令、计算属性、侦听器

目录 指令 指令修饰符 按键修饰符 ​编辑 v-model修饰符 事件修饰符 v-bind对于样式操作的增强 操作class 对象 数组 操作style v-model应用于其他表单元素 computed计算属性 概念 基础语法 ​编辑 计算属性vs方法 computed计算属性 作用 语法 缓存特性 m…

Java Web 网页设计

不要让追求之舟停泊在幻想的港湾 而应扬起奋斗的风帆 驶向现实生活的大海 网页设计 1.首先 添加框架支持 找到目录右键添加 找到Web Application选中 点击OK 然后 编辑设置 找到Tomcat--local 选中 点击OK 名称可以自己设置 找到对应文件夹路径 把Tomcat添加到项目里面 因为…

一次Redis访问超时的“捉虫”之旅

01 引言 作为后端开发人员&#xff0c;对Redis肯定不陌生&#xff0c;它是一款基于内存的数据库&#xff0c;读写速度非常快。在爱奇艺海外后端的项目中&#xff0c;我们也广泛使用Redis&#xff0c;主要用于缓存、消息队列和分布式锁等场景。最近在对一个老项目使用的docker镜…

Java——数组

数组是一块连续的内存&#xff0c;用来存储相同类型的数据 一、数组的定义 数组的创建 T[] 数组名 new T[N]; T&#xff1a;表示数组中存放元素的类型 T[]&#xff1a;表示数组的类型 N&#xff1a;表示数组的长度 数组的初始化 数组的初始化主要分为动态初始化和静态初始…

链表基础4——带头双向循环链表

什么是带头双向循环链表 我们直接看图片 定义结点类型 typedef int LTDataType;//存储的数据类型typedef struct ListNode {LTDataType data;//数据域struct ListNode* prev;//前驱指针struct ListNode* next;//后继指针 }ListNode;链表的初始化 //创建一个新结点 ListNod…

社交媒体数据恢复:Dust

社交媒体数据恢复&#xff1a;Dust/CYBER DUST 网络灰尘&#xff1a;更安全的发短信场所 概述 CYBER DUST 让您掌控自己的数字生活。我们相信网络生活就是现实生活&#xff0c;因此只有您应该控制有关您的信息。我们的用户受到保护——不用担心被窥探、数据挖掘、粗略的黑客&…