| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 281 人关注过本帖
标题:一个有关指针的问题,请教一下
只看楼主 加入收藏
林浩
Rank: 2
等 级:论坛游民
帖 子:47
专家分:23
注 册:2011-1-12
结帖率:90.91%
收藏
已结贴  问题点数:10 回复次数:5 
一个有关指针的问题,请教一下
用指针做,将一个字符数组中数字,赋给一个整型数组,比如Aa223aeb54...中的223,54
2011-03-09 14:09
瓦药墙
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:218
专家分:556
注 册:2009-9-16
收藏
得分:0 
恩, 很好做, 用最朴素的算法, 从头到尾处理这个字符串, 然后加判断啊之类就好了
2011-03-09 14:22
『点点滴滴』
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:168
专家分:1035
注 册:2007-7-9
收藏
得分:2 
#include <stdio.h>
#define MAXN 101
int main()
{
    char s[MAXN] ;
    int a[MAXN] ;
    char *p = s ;
    int i , j = 0 ;
    gets( s ) ;
    while( *p )
    {
        if( *p - '0' >= 0 && *p - '0' <= 9 )
            a[j++] = *p - '0' ;
        p++ ;
    }
    for( i = 0 ; i < j ; ++i )
        printf("%d",a[i] ) ;
    return 0 ;
}

[ 本帖最后由 『点点滴滴』 于 2011-3-9 14:45 编辑 ]
2011-03-09 14:40
瓦药墙
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:218
专家分:556
注 册:2009-9-16
收藏
得分:3 
#include <stdio.h>
#define N 100

int main(void)
{
    char        str[N];
    char        *ptr = NULL;
    int         i, j;
    int         flag;
    int         result[N] = {0};

    scanf("%s", str);
   
    for (flag = i = 0, ptr = str; *ptr; ++ptr)
    {
        if (*ptr < '0' || *ptr > '9')
            continue;

        result[i] = result[i] * 10 + *ptr - '0';
        if (*(ptr + 1) < '0' || *(ptr + 1) > '9')
            ++i;
    }
   
    for (j = 0; j < i; ++j)
    {
        printf ("%d\n", result[j]);
    }

    return 0;
}
2011-03-09 14:51
baobaoisme
Rank: 7Rank: 7Rank: 7
来 自:AVATAR
等 级:黑侠
帖 子:260
专家分:506
注 册:2010-7-9
收藏
得分:5 
程序代码:
#include <stdio.h>

int tenPow(int);
int searchNum(int *a,char *str,char *num);
int main()
{
    char str[100];//存放输入的字符串
    int a[100],i,n;//存放数字
    char num[10];//用来存放每次取出的一组数字符号
    printf("input string:\n");
    gets(str);
    n=searchNum(a,str,num);
    printf("the seleted numbers are:\n");
    for(i=0;i<n;i++)
        printf("%d ",a[i]);
    putchar(10);
    return 0;
}
int searchNum(int *a,char *str,char *num)
{
    int i,result,bit,anum=0;
    char c=*(str++);
    while(c)
    {
        if(c<'0' || c>'9')
        c=*(str++);
        else
        {
            bit=i=result=0;

            num[i++]=c;
            c=*(str++);
            while(c>='0' && c<='9')
            {
                num[i++]=c;
                c=*(str++);
            }
            //计算num[i]中存放的数字
            int j=0;
            while(i>0)
            {
                bit=(num[j]-'0')*tenPow(i-1);
                result+=bit;
                i--;
                j++;
            }
            a[anum++]=result;
        }
    }
    return anum;//返回a[100]中存储数字的数量
}
int tenPow(int i)
{
    int x=1;
    while(i>0)
    {
        x *= 10;
        i--;
    }
    return x;
}
我以前做过的一道练习题,供你做参考

调试界面:
图片附件: 游客没有浏览图片的权限,请 登录注册
2011-03-09 14:57
方杰斌
Rank: 2
等 级:论坛游民
帖 子:42
专家分:45
注 册:2010-10-26
收藏
得分:0 
罗格

邻家货站
2011-03-09 15:56
快速回复:一个有关指针的问题,请教一下
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.092113 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved