当前位置: 首页 > news >正文

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

tips:

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

如何变环+拆环为链:

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

寻找最大公共子串:

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()函数做一个简单的介绍

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初始化为无穷大

memset(a , 0x3f , sizeof a);

相关文章:

  • c语言修炼秘籍 - - 禁(进)忌(阶)秘(技)术(巧)【第六式】文件操作
  • 聚宽策略----国九条后中小板微盘小改,年化135.40%
  • HttpClient
  • Vue3集成Element Plus完整指南:从安装到主题定制上
  • 【深度学习入门_NLP自然语言处理】序章
  • C++初阶-类和对象(中)
  • Scratch——第18课 列表接龙问题
  • deep-share开源浏览器扩展,用于分享 DeepSeek 对话,使用户能够将对话内容保存为图片或文本以便轻松分享
  • 2025第十六届蓝桥杯python B组满分题解(详细)
  • chmod,chown命令
  • 【Linux】vim配置----超详细
  • CTGAN 合成数据生成与验证脚本学习笔记
  • 从巅峰到谷底:搜狐的27年沉浮启示录
  • 清醒思考的艺术
  • 算法导论思考题
  • (二)mac中Grafana监控Linux上的MySQL(Mysqld_exporter)
  • 人机共跑,马拉松人型机器人同跑
  • 通信信号分类识别
  • ARM裸机开发——I.MX6U_汇编LED灯驱动
  • 数据分析师-Part1-职业介绍
  • 中小企业收款难何解?快速认定企业身份并理顺付款责任链条
  • 江西农商联合银行正式挂牌开业
  • 生于1984年,郭宝任湖北黄石市副市长
  • 秦洪看盘|量能虽萎缩,但交易情绪尚可
  • 又一上海出品力作开播!孙俪再演职场丽人
  • 长三角议事厅|解码中国产业转移新范式:特征识别与韧性构建