几个字符串简单操作函数
2013-03-01 14:57
232 查看
char *myitoa(int num,char *str,int radix) //把整数转换成字符串
{
/* 索引表 */
char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
unsigned unum; /* 中间变量 */
int i=0,j,k;
/* 确定unum的值 */
if(radix==10&&num<0) /* 十进制负数 */
{
num=(unsigned)-num;
str[i++]='-';
}else
unum=(unsigned)num; /* 其他情况 */
/* 逆序 */
do{
str[i++]=index[unum%(unsigned)radix];
unum/=radix;
}while(unum);
str[i]='\0';
/* 转换 */
if(str[0]=='-') k=1; /* 十进制负数 */
else k=0;
/* 将原来的“/2”改为“/2.0”,保证当num在16~255之间,radix等于16时,也能得到正确结果 */
for(j=k;j<=(i-1)/2.0+k;j++){
num=str[j];
str[j]=str[i-j-1+k];
str[i-j-1+k]=num;
}
return str;
}
DWORD CtoX(char* colour)//字符串转换成16进制
{
// char a[] = "0xAbcd1234";
int cnt, tmp;
DWORD ret = 0;
int i = 0;
int colour_num = 2;
// cnt = strlen(colour) - 1; /* 获取长度 */
if(strlen(colour)==8)
colour_num = 2;
else if(strlen(colour)==6)
colour_num = 0;
else if(strlen(colour)==7)
colour_num = 1;
//pt(1,"colour = %d",strlen(colour));
for (cnt=strlen(colour)-1; cnt>=colour_num; cnt--, i++) {
tmp = ctox(colour[cnt]); /* 获取数字 */
// printf("cnt = 0x%x\n", tmp);
ret |= (tmp << i * 4); /* 左移相应位数后赋值 */
}
//pt(1,"ret = 0x%x", ret);
return ret;
}
char** cSplit(char *string, char spliter)
{
//分割后字符串数量
int num = 0;
//计算数量
int i = 0;
int size = strlen(string);
for(; i < size; i++)
{
//
if((string[i] != spliter) && (string[i + 1] == spliter || string[i + 1] == '\0')) num++;
}
//分配空间
char **cStrings = (char**)malloc(sizeof(char*) * (num + 1));
int j = 0;
for(; j <= num; j++)
{
//初始化指针数组
cStrings[j] = 0;
}
//保存分割后字符串
char *buffer = (char*)malloc(sizeof(char) * (size + 1));
int l = 0;
for(; l < size + 1; l++)
{
buffer[l] = 0;
}
int counter = 0;
int k = 0;
for(; k < size; k++)
{
if(string[k] != spliter)
{
int i = 0;
int j = k;
while(string[j] != spliter && string[j] != '\0')
{
buffer[i++] = string[j++];
}
buffer[i] = '\0';
cStrings[counter] = (char*)malloc(sizeof(char) * i);
strcpy(cStrings[counter++],buffer);
k = k + i;
}
}
free(buffer);
return cStrings;
}
/**
*调用此方法释放cSplit分配的内存空间
*/
void freeStringsMemory(char **strings)
{
//
int k = 0;
for(; ; k++)
{
//
if(strings[k] != 0) free(strings[k]);
else break;
}
free(strings);
}
{
/* 索引表 */
char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
unsigned unum; /* 中间变量 */
int i=0,j,k;
/* 确定unum的值 */
if(radix==10&&num<0) /* 十进制负数 */
{
num=(unsigned)-num;
str[i++]='-';
}else
unum=(unsigned)num; /* 其他情况 */
/* 逆序 */
do{
str[i++]=index[unum%(unsigned)radix];
unum/=radix;
}while(unum);
str[i]='\0';
/* 转换 */
if(str[0]=='-') k=1; /* 十进制负数 */
else k=0;
/* 将原来的“/2”改为“/2.0”,保证当num在16~255之间,radix等于16时,也能得到正确结果 */
for(j=k;j<=(i-1)/2.0+k;j++){
num=str[j];
str[j]=str[i-j-1+k];
str[i-j-1+k]=num;
}
return str;
}
DWORD CtoX(char* colour)//字符串转换成16进制
{
// char a[] = "0xAbcd1234";
int cnt, tmp;
DWORD ret = 0;
int i = 0;
int colour_num = 2;
// cnt = strlen(colour) - 1; /* 获取长度 */
if(strlen(colour)==8)
colour_num = 2;
else if(strlen(colour)==6)
colour_num = 0;
else if(strlen(colour)==7)
colour_num = 1;
//pt(1,"colour = %d",strlen(colour));
for (cnt=strlen(colour)-1; cnt>=colour_num; cnt--, i++) {
tmp = ctox(colour[cnt]); /* 获取数字 */
// printf("cnt = 0x%x\n", tmp);
ret |= (tmp << i * 4); /* 左移相应位数后赋值 */
}
//pt(1,"ret = 0x%x", ret);
return ret;
}
char** cSplit(char *string, char spliter)
{
//分割后字符串数量
int num = 0;
//计算数量
int i = 0;
int size = strlen(string);
for(; i < size; i++)
{
//
if((string[i] != spliter) && (string[i + 1] == spliter || string[i + 1] == '\0')) num++;
}
//分配空间
char **cStrings = (char**)malloc(sizeof(char*) * (num + 1));
int j = 0;
for(; j <= num; j++)
{
//初始化指针数组
cStrings[j] = 0;
}
//保存分割后字符串
char *buffer = (char*)malloc(sizeof(char) * (size + 1));
int l = 0;
for(; l < size + 1; l++)
{
buffer[l] = 0;
}
int counter = 0;
int k = 0;
for(; k < size; k++)
{
if(string[k] != spliter)
{
int i = 0;
int j = k;
while(string[j] != spliter && string[j] != '\0')
{
buffer[i++] = string[j++];
}
buffer[i] = '\0';
cStrings[counter] = (char*)malloc(sizeof(char) * i);
strcpy(cStrings[counter++],buffer);
k = k + i;
}
}
free(buffer);
return cStrings;
}
/**
*调用此方法释放cSplit分配的内存空间
*/
void freeStringsMemory(char **strings)
{
//
int k = 0;
for(; ; k++)
{
//
if(strings[k] != 0) free(strings[k]);
else break;
}
free(strings);
}
相关文章推荐
- 字符串操作函数的几个基本函数
- 关于C语言中字符串操作的几个函数的总结
- 几个操作字符串的函数
- 几个字符串操作的汇编函数
- 字符串和文件操作函数(简单)
- php中的几个字符串操作函数strtoupper strtolower ucwords ucfirst lcfirst函数
- 自己的几个字符串操作函数,上次用库函数吃亏了,在老师指导下,写几个
- 关于字符串操作的一些函数简单说明与应用
- 几个字符串和内存操作函数
- 几个对字符串进行操作的函数
- 关于几个字符串操作的函数
- MFC中几个有用的字符串操作函数
- 关于字符串和文件操作的几个函数
- 几个简单的文件&目录操作函数
- 字符串操作函数的几个基本函数
- C语言面试必须会的几个字符串操作函数原型strcpy,strcmp,strlen,strcat
- 常见的c字符串处理函数的源代码以及简单例子【1】
- mysql字符串操作相关函数用法总结
- 有关字符串的几个函数(自己编写的)
- 给出一个函数来合并两个字符串A和B。字符串A的后几个字节和字符串B的前几个字节重叠