1)字符串操作 
strcpy(p, p1) 复制字符串 
strncpy(p, p1, n) 复制指定长度字符串 
strcat(p, p1) 附加字符串 
strncat(p, p1, n) 附加指定长度字符串 
strlen(p) 取字符串长度 
strcmp(p, p1) 比较字符串 
strcasecmp忽略大小写比较字符串
strncmp(p, p1, n) 比较指定长度字符串 
strchr(p, c) 在字符串中查找指定字符 
strrchr(p, c) 在字符串中反向查找 
strstr(p, p1) 查找字符串 
strpbrk(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找该集合的任一元素 
strspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找不属于该集合的任一元素的偏移 
strcspn(p, p1) 以目标字符串的所有字符作为集合,在当前字符串查找属于该集合的任一元素的偏移  
* 具有指定长度的字符串处理函数在已处理的字符串之后填补零结尾符 

2)字符串到数值类型的转换 
strtod(p, ppend) 从字符串 p 中转换 double 类型数值,并将后续的字符串指针存储到 ppend 指向的 char* 类型存储。
strtol(p, ppend, base) 从字符串 p 中转换 long 类型整型数值,base 显式设置转换的整型进制,设置为 0 以根据特定格式判断所用进制,0x, 0X 前缀以解释为十六进制格式整型,0    前缀以解释为八进制格式整型
atoi(p) 字符串转换到 int 整型 
atof(p) 字符串转换到 double 符点数 
atol(p) 字符串转换到 long 整型 

3)字符检查 
isalpha() 检查是否为字母字符 
isupper() 检查是否为大写字母字符 
islower() 检查是否为小写字母字符 
isdigit() 检查是否为数字 
isxdigit() 检查是否为十六进制数字表示的有效字符 
isspace() 检查是否为空格类型字符 
iscntrl() 检查是否为控制字符 
ispunct() 检查是否为标点符号 
isalnum() 检查是否为字母和数字 
isprint() 检查是否是可打印字符 
isgraph() 检查是否是图形字符,等效于 isalnum() | ispunct() 
//abcde 2 -> cdeab
//暴力循环O(n*len) 的复杂度
void left(char str[], int len, int n)
{
    for(int i=0;i<n;i++) {
        char tmp=str[0];
        int j=0;
        for(;j<len-1;j++) {
            str[j]=str[j+1];
        }
        str[j]=tmp;
    }
}

void right(char str[], int len, int n)
{
	for(int i=0;i<n;i++) {
		char tmp=str[len-1];
		int j=len-1;
		for(;j>0;j--) {
			str[j]=str[j-1];
		}
		str[j]=tmp;
	}
}

//1234 2 -> 3412
//先对0~n-1进行反转     21
//再对n~len-1进行反转  43
//得到了    2143
//再对2143进行反转得到最终结果  3412

void Reverse(char *str, int st, int ed){//字符串反转
    while(st < ed){
        char tmp = str[st];
        str[st++] = str[ed];
        str[ed--] = tmp;
    }
}
//n表示循环左移的位数
void LeftRotateString(char *str, int n){
    int len = strlen(str);
    Reverse(str, 0, n-1);
    Reverse(str, n, len-1);
    Reverse(str, 0, len-1);
}
//String类