String +memset字符串类题型【C++】

tips:

1、寻找最大公共子串时,如果字符串可以旋转但是不能反转,考虑在每个字符串后重复一次自身,如 "abcd" 变为 "abcdabcd",这样在用dp就可以了。

如何变环+拆环为链:

cpp 复制代码
 cin>>n>>m;
    //拆环为链,复制一遍字符串串 
    for(int i = 1; i <= n;++i){
        cin>>s[i];
        s[i]+=s[i];
    }

寻找最大公共子串:

cpp 复制代码
int cal_lcs(string a,string b)
{
    a = " "+ a, b =" "+b;
    memset(f,0,sizeof f);//对f初始化
    int cnt = 0;
    for(int i = 1;i<=a.size();++i)
    {
        for(int j = 1;j<=b.size();++j)
        {
            if(a[i] == b[j]) f[i][j] = max(f[i][j],f[i-1][j-1]+1);
            cnt = max(cnt,f[i][j]);
        }
    }
    return cnt;
}

menset()

针对menset()函数做一个简单的介绍

cpp 复制代码
void *memset(void *str, int c, size_t n)
  • 解释:复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符。
  • 作用:是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
  • 头文件:C中#include<string.h>,C++中#include<cstring>

注意!menset()赋值一般用于初始化,其按照字节进行复制,将参数转化为二进制再填入!(int有四个字节,在转成二进制再赋值的情况下可能会出问题)

因此在int类型的赋值中一般只能赋值为0或-1,不推荐其他值。

为地址str开始的n个字节赋值c,注意:是逐个字节赋值,str开始的n个字节中的每个字节都赋值为c。
(1) 若str指向char型地址,value可为任意字符值;
(2) 若str指向非char型,如int型地址,value的值只能是-1或0,因为-1和0转化成二进制后每一位都是一样的,设int型占4个字节,则-1=0XFFFFFFFF, 0=0X00000000。

memset初始化为无穷大

cpp 复制代码
memset(a , 0x3f , sizeof a);
相关推荐
Highcharts.js3 小时前
倒置百分比堆叠面积图表示列详解|Highcharts大气成分图表代码
开发语言·信息可视化·highcharts·图表开发·面积图·图表示例·推叠图
csdn_aspnet3 小时前
C语言 Lomuto分区算法(Lomuto Partition Algorithm)
c语言·开发语言·算法
晨曦中的暮雨3 小时前
4.15腾讯 CSIG云服务产线 一面
java·开发语言
存在morning3 小时前
【GO语言开发实践】二 GO 并发快速上手
大数据·开发语言·golang
xiaoerbuyu12334 小时前
开源Java 邮箱 基于SpringBoot+Vue前后端分离的电子邮件
java·开发语言
C+++Python5 小时前
C++ 进阶学习完整指南
java·c++·学习
sparEE5 小时前
c++值类别、右值引用和移动语义
开发语言·c++
zhangjw345 小时前
第11篇:Java Map集合详解,HashMap底层原理、哈希冲突、JDK1.8优化、遍历方式彻底吃透
java·开发语言·哈希算法
jrrz08286 小时前
Apollo MPC Controller
c++·自动驾驶·apollo·mpc·横向控制·lateral control
benpaodeDD7 小时前
视频10,11,12,13——java程序的加载与执行,安装jdk
java·开发语言