| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 438 人关注过本帖
标题:一个小程序,结果不对,麻烦大家看一下
只看楼主 加入收藏
yuanyang317
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2007-8-7
收藏
 问题点数:0 回复次数:2 
一个小程序,结果不对,麻烦大家看一下

题目:随便输入一个字符串,例如:a123x456-7689?89njmk321nk123
将连续的数字作为一个整数,计算整数的个数,分别输出,例如,该字符串应该有六个数,分别是:123 456 7689 89 321 23

以下是我的程序:
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
int main()
{
char *s;
int n,i,j,l,*p;
printf("please enter a string:\n");
s=(char*)malloc(30);
gets(s); //输入字符串
p=(int*)malloc(30*2); //将找出的数分别存到指针p里面
i=0;
j=0;
n=0;
*p=0;
while((*(s+i))!='\0')
{
if((*(s+i)<='9')&&(*(s+i)>='0')) //检查是不是数字字符
j++;
else
{
if(j>0) //连续数字后的第一个非数字字符
{
n++;
for(l=1;l<=j;l++) //将连续数字求出来并存与p中
*(p+n-1)=*(p+n-1)+(*(s+i-l)-48)*((int)pow(10,l-1));
j=0;
}
}
i++;
}
if(j>0) //以数字结尾的字符串的最后一个数据
{
n++;
for(l=1;l<=j;l++)
*(p+n-1)=*(p+n-1)+(*(s+i-l)-48)*((int)pow(10,l-1));
}
printf("there are %d numbers in the string,they are:\n",n);
for(i=0;i<n;i++)
printf("%5d",*(p+i));
free(s);
free(p);
return 0;
}
编译没错,但是运行结果不对,不知道哪里错了,请大家帮忙看一下,谢谢!

搜索更多相关主题的帖子: 结果 麻烦 
2007-08-11 22:52
maoguoqing
Rank: 6Rank: 6
来 自:重庆
等 级:贵宾
威 望:28
帖 子:2980
专家分:19
注 册:2005-12-5
收藏
得分:0 

汗不用那么麻烦了,这样就可以了

#include <stdio.h>
#include <memory.h>
#include <malloc.h>
#include <string.h>

int _tmain(int argc, _TCHAR* argv[])
{
char *s = (char*)malloc(30);
memset(s,0,sizeof(s));
gets(s);

char * pend = s+strlen(s)-1;

while ( 1 )
{
if (!( *pend<='9' && *pend>='0'))
{
if ( '\0' != *(pend+1) ) puts(pend+1);
*pend = '\0';
}
if ( pend == s)
{
if('\0' != pend) puts(pend);
break;
}
else pend--;
}
free(s);
return 0;
}

[此贴子已经被作者于2007-8-12 1:04:22编辑过]


天行健,君子以自强不息!!QQ:68660681
2007-08-12 01:03
ConZhang
Rank: 1
来 自:北京
等 级:新手上路
帖 子:282
专家分:0
注 册:2007-8-7
收藏
得分:0 
你只是分配了p所指向的空间,而没有分配p+1所指向的空间,所以当p=0的时候,p所指向的空间被初始化为0,为p+1空间没有被初始化就是乱码,而且p+n,n&gt;0的都是乱码。
2007-08-12 09:20
快速回复:一个小程序,结果不对,麻烦大家看一下
数据加载中...
 
   



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

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