急字符串查找有关问题
发布时间:2011-06-28 16:12:47 文章来源:www.iduyao.cn 采编人员:星星草
急,字符串查找问题
#include <stdio.h>
#include <string.h>
int *getPostion(char *str,char *findstr){
char *strTemp = str;
static int pos[100];
int m = 0;
while(1)
{
strTemp = strstr(strTemp,findstr);
if(NULL == strTemp)
break;
else
{
printf( "Position:%d\r\n ",strTemp - str);
pos[m] = strTemp - str;
m++;
strTemp += strlen(findstr);
}
}
return pos;
}
int main()
{
//char str[] = "hello world,hello,helloworld,hello,hello,world! ";
char str[] = "hello world,hello,helloworld ";
char findstr[] = "hello ";
int *pos = getPostion(str,findstr);
printf( "size:%d\r\n ",sizeof(pos));
int m = 0;
for(m = 0 ; m < sizeof(pos); m++){
printf( "Pos:%d\r\n ",pos[m]);
}
}
我想得取findstr在str串中位置,返回一个数组
但是我返回的sizeof(pos)为什么每次都是4
请问有什么办法。。。
------解决方案--------------------
没有办法,sizeof(int *)永远都是4,sizeof(int [])也是一个定值
可以把数量存放到pos[0]
------解决方案--------------------
pos是函数的局部数组,传不出来,只能传出数组的首地址。
所以事先用一个数组专门来存放pos的信息,见以下void main()函数。
void getPostion(int pos[],char *str,char *findstr){
//对pos的数据进行修改
}
int getLen(int a[])
{
int i=0;
while (a[i++]!=0)
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。
其他相似内容:
-
【★C/C++奖励基金-30期★】更新获奖书籍,请选择~ - C/C++ / 非技术区
【★C/C++奖励基金-30期★】
C/C++ 2011-12专家榜
名次...
-
C/c++ 如何按位拷贝呢?
我有一个结构体
strut st_header
{
unsigned short ver:2
unsigned short ping:1
unsgne...
-
uboot上的一点代码,没看明白!
struct in_str {
const char *p;
#ifndef __U_BOOT__
char peek_buf[2];
#endif
int __promptme;
...
-
Debug时为什么变量的地址不变?
是巧合还是某种必然. 是不是因为C中生成的可执行程序存储的地址是相对地址而不是绝对的物理地址.
...
-
关于switch语句。我不知道哪里错了,大侠帮忙bug一下
#include <stdio.h>
int main()
{
int a;
char b;
do{
printf("1.Chines...
-
#pragma section 的 $ 语法
在 ARX 头文件中间过如下三行,放在一起:
#pragma section("ARXCOMMAND$__a")
#pragma section("ARXCOMM...
-
read 问题再现
#define N 205
signed short x[N];
for(i=0;i<N;i++)
{
printf("hello boy!!\n");
...
-
征求一个C语言输入函数?
不知道大家有没有学习过Java? 现在需要一个类似Java的Scanner的函数集, 要求如下:
1. 三个函数: int rea...
-
求一道算法。一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
/*我写了一点,但是有错误,汗*/
/*
...
-
3n+1问题
求救,不知道错在哪里
#include<stdio.h>
int count(int a,int b)
{
int max=0,len=0,a1;
while(a<=b)
{
...