• 大小: 6.52 KB
    文件类型: .rar
    金币: 1
    下载: 0 次
    发布日期: 2024-10-08
  • 语言: C/C++
  • 标签:

资源简介

提供了源码和编译好的dll,可供其他平台直接调用。
void revstr(char *str) //字符串反转
int substring(char *res,int pos,int len,char *substr)//从pos开始取len个字符到substr中,返回1成功,0失败
int strindex(char *res,int pos,char *substr) //返回substr在resource中在pos后出现的位置,返回0表示没找到
int del_substr(char *res,int pos,int len)//从res的pos位置开始删除len个字符,1成功,0失败
int insert_substr(char *res,char pos,char const *substr)//在res的pos前插入substr,1成功,0失败
int strreplace(char *res,char *substr,char *desstr)//替换res中的substr为desstr,1成功,0失败
int str_count(char *res,char *substr)//统计res中的substr出现的次数
int cut

_str(char *res,char *mark,int pos,char *substr) //取res中第pos个用mark分隔的串存入sunstr,1成功,0失败
int str_cat(char *str,const char *args,...) //拼接多个字符串常量存入str,1成功,0失败
int strarray_cat(char (*arr)[str_max_len],int i,char *str) //把二维arr字符串数组拼接成一个串,i是第一维的长度,存入str
int replacate(char *res,int n,char const *str) //产生n个重复的str(串或者字符)存入res

资源截图

代码片段和文件信息

#include 
#include 
#include 
#define str_max_len 100

char mark[10]; //cut_str中分隔符的长度

/*函数列表(兼容字符和串)
void revstr(char *str) //字符串反转
int substring(char *resint posint lenchar *substr)//从pos开始取len个字符到substr中返回1成功0失败
int strindex(char *resint poschar *substr)  //返回substr在resource中在pos后出现的位置返回0表示没找到
int del_substr(char *resint posint len)//从res的pos位置开始删除len个字符1成功0失败
int insert_substr(char *reschar poschar const *substr)//在res的pos前插入substr1成功0失败
int strreplace(char *reschar *substrchar *desstr)//替换res中的substr为desstr1成功0失败
int str_count(char *reschar  *substr)//统计res中的substr出现的次数
int cut_str(char *reschar *markint poschar *substr) //取res中第pos个用mark分隔的串存入sunstr1成功0失败
int str_cat(char *strconst char *args...) //拼接多个字符串常量存入str1成功0失败
int strarray_cat(char (*arr)[str_max_len]int ichar *str) //把二维arr字符串数组拼接成一个串i是第一维的长度存入str
int replacate(char *resint nchar const *str) //产生n个重复的str(串或者字符)存入res
*/
 
void revstr(char *str) //字符串反转
{
int i=0hj;
h=j=strlen(str)-1;
char *p=strc;
while(i<=h/2)
{
c=*(p+i);
*(p+i)=*(p+j);
*(p+j)=c;
i++;j--;
    }
}

int substring(char *resint posint lenchar *substr)//从pos开始取len个字符到substr中
{
char *p=res;
int i=0;
if(pos>strlen(res))
return 0;
pos--;
while(i{
substr[i++]=res[pos++];
if(pos>strlen(res))
{
substr[i]=‘\0‘;
break;
}
}
substr[i]=‘\0‘;
return 1;
}

int strindex(char *resint poschar *substr)  //返回substr在resource中在pos后出现的第一个位置
{
int i=posc=0;
char *p=res+(i-1)*q=substr;
while(*p!=‘\0‘)
{
  q=substr;
  while(1)
  {
     if(*p==*q)
     {
     if(*(q+1)==‘\0‘)
 {
     i=i-strlen(substr);
 return i+1;
 }
 p++;
     q++;
     ++i;
 c++;
 continue;
     }
   else
     {
   if(c>0)
   {
     p=p-c+1;
     i=i-c+1;
     c=0;
     break;
   }
   else
   {
     p++;
     i++;
 break;
   }
     }
  }
 }
return 0;
}

int del_substr(char *resint posint len)//从res的pos位置开始删除len个字符
{
int i=0;
if(pos>strlen(res))
return 0;
char *p=res+(pos-1)*q=res+(pos+len-1);
do
{
*p++=*q++;
}while(*q!=‘\0‘);
*p=‘\0‘;
return 1;
}

int insert_substr(char *reschar poschar const *substr)//在res的pos前插入substr
{
char *p=res+(pos-1)*q=res+(strlen(res)+strlen(substr));//p指示待插入位置q指示移动的位置
char *e=res+strlen(res);//已经包含结束符
if(pos>strlen(res)+1||pos<0||(strlen(res)+strlen(substr))>str_max_len)
return 0;
for(;q>=p;q--) //藤出空间
{
*q=*e--;
}
//插入
while(*substr!=‘\0‘)
{
*p++=*substr++;

return 1;
}

int strreplace(char *reschar *substrchar *desstr)//替换res中的substr为desstr
{
int lj=1kdi;
l=strlen(substr);
do
{
j=strindex(resjsubstr);
if(j==0)
break;
d=del_substr(resjl);
i=insert_substr(resjdesstr);
j+=strlen(desstr);
}while(j!=0);
return 1;


int str_count(char *reschar  *substr)//统计res中的substr出现的次数
{
int lj=1c=0;
l=strlen(substr);
do
{
j=strindex(resjsubstr);
if(j==0)
return c;
c++;
j+=l;//后移l个长度
 }while(j!=0);
}  

int  cut_str(char *reschar *markint poschar *substr) //取res中第pos个mark前的串
{
int pos

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----

     文件       5087  2014-01-11 21:49  string.c

     文件      16329  2013-01-15 22:32  string.dll

----------- ---------  ---------- -----  ----

                21416                    2


评论

共有 条评论

相关资源