CSDN博客

img solotony

两个字符串操作函数.

发表于2004/7/17 15:12:00  1486人阅读

/*!brief 复制字符串的后一部分

编写函数strmcpy(s,t,m),将字符串从第m个字符开始的全部字符复制到字串s中去。n
难度系数:简单
param [in] source 源字符串.只读
param [in] dest 目的字符串
param [in] nStart 从第nStart个字符开始复制
bug
-# 未考虑strlen(source) < nStart的情况.(出错)
-# 未考虑dest[]空间不足的情况.(出错)
-# 未考虑source不以'/0'结尾的情况.(出错)
.

pre source is zero ending && strlen(source) > nStart && sizeof(dest) > sizeof(source)
post dest is zero ending   && strcmp(dest, source + nStart) == 0
*/
void LeftSubStr(char *source, char * dest, int nStart)
{
  char *p = source + nStart;
  char *q = dest;
  while (*q++ = *p++);
}

 

//4.编写函数,输入一个字符串,内有数字和非数字字符,将其连续的数字作为一个整数,依次存放到数组A中,并统计有多少个整数。

//不使用库的话:
int isdigit(int c)
{
return !(c < '0' || c >'9');
}

int atoi(char* str)
{
char *p = str;
int sum = *p - '0';
while( isdigit(*++p))
{
sum = sum * 10 + (*p - '0');
}

return sum;
}


int findDigital(char* str, int buf[], int nLen)
{
char *p = str;
int i;
for (i = 0; i< nLen && *p; i++)
{
while(*p && !isdigit(*++p));
buf[i] = atoi(p);
while(isdigit(*++p));
}
return i;
}

#include <stdio.h>

int main ()
{
  int a[10];
int len = findDigital("-11,2", a, 10);
printf("%d 个, %d, %d", len, a[0], a[1]);
return 0;
}

0 0

相关博文

我的热门文章

img
取 消
img