如题:
实现代码:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main()
{
int n,i,j,k,t=0;
char a[100];
while(~scanf("%d",&n))
{
getchar();//防止回车被gets接受,造成第一次不用键盘输入的错误
for(i=1;i<=n;i++)
{
gets(a);
for(j=0;a[j]!='\0';j++)
{
if(a[j]<='9'&&a[j]>='0')
t++;
}
memset(a,0,sizeof(a));//清空数组数据 ,该函数在string.h中,其中a要为指针变量
printf("%d\n",t);
t=0;
}
}
}
一、memset函数:
void *memset(void *s, int ch, size_t n);
函数解释:将s中当前位置后面的n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。
memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
memset()函数原型是extern void *memset(void *buffer, int c, int count) buffer:为指针或是数组,c:是赋给buffer的值,count:是buffer的长度.
常见错误:
1、:memset函数按字节对内存块进行初始化,所以不能用它将int数组初始化为0和-1之外的其他值(除非该值高字节和低字节相同)。
2、:memset(void *s, int ch,size_t n);中ch实际范围应该在0~~255,因为该函数只能取ch的后八位赋值给你所输入的范围的每个字节,比如int a[5]赋值memset(a,-1,sizeof(int )5)与memset(a,511,sizeof(int )5) 所赋值的结果是一样的都为-1;因为-1的二进制码为(11111111 11111111 11111111 11111111)而511的二进制码为(00000000 00000000 00000001 11111111)后八位都为(11111111),所以数组中每个字节,如a[0]含四个字节都被赋值为(11111111),其结果为a[0](11111111 11111111 11111111 11111111),即a[0]=-1,因此无论ch多大只有后八位二进制有效,而后八位二进制的范围在(0~255)中改。而对字符数组操作时则取后八位赋值给字符数组,其八位值作为ASCIl码。
3、: 搞反了 ch 和 n 的位置.
一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20sizeof(char));
而不是 memset(a,20sizeof(char),0);
二、清除数组内容:
1、循环赋值:
2、memset函数
详细介绍请参考:https://baike.baidu.com/item/memset/4747579?fr=aladdin