[namespace hdk] string
#include<bits/stdc++.h>
using namespace std;
namespace hdk{
const int siz=100001;
class string{
private:
char s[siz];
int lengtht=0;
int start=0;
public:
void operator =(const std::string x){
memset(s,0,sizeof s);
for(int i=0;i<=x.length()-1;++i){
s[i]=x[i];
}
lengtht=x.length();
}
void operator =(const string x){
memset(s,0,sizeof s);
for(int i=0;i<=x.start+x.lengtht-1;++i){
s[i]=x.s[i];
}
start=x.start;
lengtht=x.lengtht;
}
inline int length(){
return lengtht;
}
void check_start(){
for(int i=0;i<=siz;++i){
if(s[i]){
start=i;
break;
}
}
}
void print(char ending=0){
std::cout<<s+start;
if(ending!=0) std::cout<<ending;
}
void input(int start_pos=0){
std::cin>>s+start_pos;
start=start_pos;
lengtht=strlen(s+start_pos);
}
inline void push_back(char x){
s[start+lengtht]=x;
lengtht++;
}
string operator +(char x){
string ans=*this;
ans.push_back(x);
return ans;
}
string operator +(string &x){
string ans=*this;
for(int i=x.start;i<=x.start+x.length()-1;++i){
ans.push_back(x.s[i]);
}
return ans;
}
void operator +=(string &x){
*this=*this+x;
}
void operator +=(char x){
push_back(x);
}
char* begin(){
return &s[start];
}
char* end(){
return &s[start+lengtht];
}
char operator[](int x){
return s[x];
}
string substr(int substart,int sublength=siz){
string ans;
for(int i=start+substart;i<=start+substart+sublength-1;++i){
if(i>=start+lengtht) break;
ans.push_back(s[i]);
}
return ans;
}
string operator *(int x){
string ans;
while(x--) ans+=*this;
return ans;
}
void operator *=(int x){
*this=(*this)*x;
}
unsigned long long hash(int l,int r,int num=233,unsigned long long mod=0){
unsigned long long ans=0;
for(int i=l;i<=r;++i){
ans=ans*num+s[i];
if(mod) ans%=mod;
}
return ans;
}
unsigned long long hashall(int num=233,unsigned long long mod=0){
unsigned long long ans=0;
for(int i=start;i<=start+lengtht-1;++i){
ans=ans*num+s[i];
if(mod) ans%=mod;
}
return ans;
}
inline bool empty(){
if(s[start]) return false;
return true;
}
inline void pop_back(){
if(!empty()){
s[start+lengtht-1]=0;
lengtht--;
}
}
inline void clear(){
memset(s,0,sizeof s);
start=0;
lengtht=0;
}
string reverse(string x){
string ans;
for(int i=x.start+x.length()-1;i>=x.start;--i){
ans.push_back(x[i]);
}
return ans;
}
void reverse(){
*this=reverse(*this);
}
friend std::ostream& operator<<(std::ostream& output,string& inx){
inx.print();
return output;
}
friend std::istream& operator>>(std::istream& input,string& inx){
inx.input();
inx.check_start();
return input;
}
bool check_mir(){
int i=start,j=start+lengtht-1;
while(i<=j){
if(s[i]!=s[j]) return false;
i++;j--;
}
return true;
}
int count(char x){
int ans=0;
for(int i=start;i<=start+lengtht-1;++i){
if(s[i]==x) ans++;
}
return ans;
}
bool operator ==(string x){
if(x.length()!=length()) return false;
for(int i=0;i<=x.length()-1;++i){
if(x[x.start+i]!=s[start+i]) return false;
}
return true;
}
bool operator <(string x){
if(x.length()!=length()){
return x.length()>length();
}
for(int i=0;i<=x.length()-1;++i){
if(x[x.start+i]!=s[start+i]){
return s[start+i]<x[x.start+i];
}
}
return false;
}
bool operator >(string x){
return ((!(*this==x)) and (!(*this<x)));
}
bool operator <=(string x){
return ((*this<x) or (*this==x));
}
bool operator >=(string x){
return ((*this>x) or (*this==x));
}
inline int size(){
return length();
}
inline int start_pos(){
return start;
}
inline void insert(int pos,string x){
for(int i=start+length()-1;i>=start+pos;--i){
s[i+x.length()]=s[i];
}
for(int i=start+pos;i<=start+pos+x.length()-1;++i){
s[i]=x[x.start+i-start-pos];
}
lengtht+=x.lengtht;
}
inline void insert(int pos,std::string x){
for(int i=start+length()-1;i>=start+pos;--i){
s[i+x.length()]=s[i];
}
for(int i=start+pos;i<=start+pos+x.length()-1;++i){
s[i]=x[i-start-pos];
}
lengtht+=x.length();
}
inline void insert(int pos,char x){
for(int i=start+length()-1;i>=start+pos;--i){
s[i+1]=s[i];
}
s[start+pos]=x;
lengtht++;
}
inline void erase(int pos){
for(int i=start+pos;i<=start+length()-2;++i){
s[i]=s[i+1];
}
s[start+length()-1]=0;
lengtht--;
}
inline void erase(int l,int r){
for(int i=start+l;i<=start+length()-1-(r-l+1);++i){
s[i]=s[i+r-l+1];
}
for(int i=start+length()-(r-l+1);i<=start+length()-1;++i){
s[i]=0;
}
lengtht-=(r-l+1);
}
inline bool find(string x){
int ppos=0;
for(int i=start;i<=start+length()-1;++i){
if(s[i]==x[x.start+ppos]){
ppos++;
if(ppos==x.length()){
return true;
}
}
else{
ppos=0;
}
}
return false;
}
inline bool find(std::string x){
int ppos=0;
for(int i=start;i<=start+length()-1;++i){
if(s[i]==x[ppos]){
ppos++;
if(ppos==x.length()){
return true;
}
}
else{
ppos=0;
}
}
return false;
}
void lowercase(){
for(int i=start;i<=start+length()-1;++i){
if(s[i]>='A' and s[i]<='Z'){
s[i]-=('A'-'a');
}
}
}
void lowercase(int l,int r){
for(int i=start+l;i<=start+r;++i){
if(s[i]>='A' and s[i]<='Z'){
s[i]-=('A'-'a');
}
}
}
void uppercase(){
for(int i=start;i<=start+length()-1;++i){
if(s[i]>='a' and s[i]<='z'){
s[i]+=('A'-'a');
}
}
}
void uppercase(int l,int r){
for(int i=start+l;i<=start+r;++i){
if(s[i]>='a' and s[i]<='z'){
s[i]+=('A'-'a');
}
}
}
void map_replace(map<char,char> mp){
for(int i=start;i<=start+length()-1;++i){
if(mp.count(s[i])){
s[i]=mp[s[i]];
}
}
}
void map_replace(map<char,char> mp,int l,int r){
for(int i=start+l;i<=start+r;++i){
if(mp.count(s[i])){
s[i]=mp[s[i]];
}
}
}
};
}
using namespace hdk;
[namespace hdk] string的更多相关文章
- 未定义标识符string
“未定义标识符string” 解决方法: 头文件加上 #include <iostream>using namespace std; string是标准库的,要加std::string, ...
- const char* && string && String^ 类型转换
const char* && string && String^ 类型转换 const char* ---> string const char * cw= &q ...
- String类实现
String类是应用框架中不可或缺的类 重载运算符实现字符串的操作 #idndef IOTECK_STRING_H_#define IOTECK_STRING_H_namespace iotek{ c ...
- namespace的用法
C++中采用的是单一的全局变量命名空间.在这单一的空间中,如果有两个变量或函数的名字完全相同,就会出现冲突.当然,你也可以使用不同的名字,但有时我们并不知道另一个变量也使用完全相同的名字:有时为了程序 ...
- HDU 1247 Hat’s Words(map,STL,字符处理,string运用)
题目 用map写超便捷 也可以用字典树来写 我以前是用map的: #include<stdio.h> #include<string.h> #include<algori ...
- c++中string类的详解
,<时返回-1,==时返回0 string的子串:string substr(int pos = 0,int n = npos) const;//返回pos开始的n个字符组成的字符串strin ...
- vector、string实现大数加法乘法
理解 vector 是一个容器,是一个数据集,里边装了很多个元素.与数组最大的不同是 vector 可以动态增长. 用 vector 实现大数运算的关键是,以 string 的方式读入一个大数,然后将 ...
- string中c_str()、data()、copy(p,n)函数的用法
标准库的string类提供了3个成员函数来从一个string得到c类型的字符数组:c_str().data().copy(p,n). 1. c_str():生成一个const char*指针,指向以空 ...
- ZOJ 1151 Word Reversal反转单词 (string字符串处理)
链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=151 For each list of words, output a l ...
- 浅谈string
#include <string>// 注意是<string>,不是<string.h>,带.h的是C语言中的头文件 using std::string;using ...
随机推荐
- ASP.NET Core 程序集注入(二)
public void ConfigureServices(IServiceCollection services) { string strValue = Configuration.GetSect ...
- XR实时云渲染:助力虚拟仿真实训教学呈现
近年来以5G.云计算.大数据.物联网.人工智能.虚拟现实/增强现实为代表的新兴技术迅速发展加速创新,日益融入经济社会发展各领域全过程,世界主要国家和地区纷纷加快数字化转型战略布局. 虚拟仿真系统是一种 ...
- 【Java】Excel 读写图片工具类
一.需求背景: 做一个大屏管理系统,基础信息包括管理的应用名称,大屏的截图,通过一个excel批量导入 excel的单元格里要插入图片,对应一个大屏应用的信息 导入需要读取到大屏截图,至于存哪还没说. ...
- L-BFGS-B(Limited-memory Broyden–Fletcher–Goldfarb–Shanno )算法理解 —— 内存受限的拟牛顿法 —— 数值优化算法
本文主要讲下个人对数值优化算法中几种常见算法的理解. 什么是优化算法? 给出函数f(X),现在要求 min f(X) 时的X值,这就是最优化问题. 1. 共轭梯度法 方程:A*x=b,A矩阵为对称正定 ...
- 特朗普开始在YouTube上打竞选广告了 —— 美国总统的竞选广告已经开始媒体投放了
相关: 拜登开始在YouTube上打竞选广告了 -- 美国总统的竞选广告已经开始媒体投放了 PS. 又多了一个猴上台,哈哈哈. 特朗普的竞选资金筹集网站:
- openAI的比赛retro contest的一些细节设置(Detail)
2018年openAI公司搞了一个比赛retro contest,该比赛目的是为了在自家的库retro上测试迁移强化学习的性能,虽然这个比赛已经结束多年但是现在了解一些也是有一定益处的. 比赛细节介绍 ...
- 强化学习分布式经验回放框架(experience replay)reverb的安装
框架reverb的相关介绍: https://www.cnblogs.com/devilmaycry812839668/p/16260799.html ======================== ...
- springmvc配置文件中配置mybatis-plus日志输出
1.背景 2.配置方式 如果application.properties文件格式: #sql日志logging.level.com.XX.XXX.mapper=debug如果是application. ...
- StarNet:关于 Element-wise Multiplication 的高性能解释研究 | CVPR 2024
论文揭示了star operation(元素乘法)在无需加宽网络下,将输入映射到高维非线性特征空间的能力.基于此提出了StarNet,在紧凑的网络结构和较低的能耗下展示了令人印象深刻的性能和低延迟 来 ...
- 高级工程师面试大全- java基础篇
1.什么是java虚拟机 JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功 ...