鱼C论坛

 找回密码
 立即注册
查看: 2486|回复: 4

[技术交流] 我咋这么笨,这个用了6小时555555

[复制链接]
发表于 2015-3-24 23:34:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
/************************************************************************
输入一个字符串,内有数字和非数字字符,例如:A123x456 17960? 302tab5876
将其中连续的数字作为一个整数,依次存放到一数组 a 中,例如,123 放在 a[0],
456 放到 a[1]……统计共有多少个整数,并输出这些数。
**************************************************************************/



#if(1)
#include <stdio.h>
#include <math.h>

int main()
{
        int i=0,n=0,j=0,m=0,k,y;
        int in[10],temp=0,a[50]={0};
        char *p,car[100];
        printf("请输入一个字符串:");
        
        gets(car);
        p=car;
                
        for (;;j=0)
        {
                if (*(p+i)=='\0') 
                {
                        break;
                }
                
                for(;i<1000;i++)
                {                        
                        if(*(p+i)>=48 && *(p+i)<=57 && *(p+i+1)>=48 && *(p+i+1)<=57 
                                || *(p+i)>=48 && *(p+i)<=57 && *(p+i-1)>=48 && *(p+i-1)<=57 )  //二个以上连续数字
                        {
                                in[j]=(*(p+i))-48;  // 字符ASCII码转十进制
                                j++;  //j 用于统计每个整数的长度
                                
                        }
                        if(!(48<=*(p+i) && *(p+i)<=57))   // 字符不属于0-9
                        {
                                i++;
                                
                                break;
                        }
                        
                }
                
                if(j>1)
                { 

                        y=j;    //循环次数
                        
                        for(j=0,k=y-1;j<y;j++,k--)   //把几个数连起来,变成一个整数
                        {
                                
                                temp+=in[j] * pow(10,k);
                        }
                        
                        
                        a[n]=temp;
                        temp=0;
                        n++;
                        
                        
                }
        }
        
        
                                for(i=0;i<n;i++)
                                {

                                        printf("a[%d]=%d\n",i,a[i]);
                                }
                                printf("\n");
                                
                                
                                return 0;
}




#endif

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-3-24 23:53:00 | 显示全部楼层
凡事慢慢来,后来就会越来越快了——加油哦!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-3-25 09:13:59 | 显示全部楼层
~风介~ 发表于 2015-3-24 23:53
凡事慢慢来,后来就会越来越快了——加油哦!

谢谢 :cry
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-3-25 10:32:24 | 显示全部楼层
本帖最后由 haiouda 于 2015-3-25 14:23 编辑
<p>#include <stdio.h>
#include <math.h></p><p>int main()
{
 int i=0,n=0,j,k;
 int in[20],temp=0,a[100]={0};
 char *p,car[200];
 printf("请输入一个字符串:");
 
 gets(car);
 p=car;
 
 for (;;)
 { j=0;
  if (*(p+i)=='\0')  break;
    
  for(;;i++)
  {   
   if(*(p+i)>=48 && *(p+i)<=57 && *(p+i+1)>=48 && *(p+i+1)<=57 
    || *(p+i)>=48 && *(p+i)<=57 && *(p+i-1)>=48 && *(p+i-1)<=57 )  //二个以上连续数字
   {
    in[j]=(*(p+i))-48;  // 字符ASCII码转十进制
    j++;  //j 用于统计每个整数的长度
    
   }
   else   /*字符不属于0-9 */
   {
    i++;    
    break;
   }   
  }
  
  if(j>1)
  { 
   k=0;
   for(--j;j>=0;j--)   //把几个数连起来,变成一个整数
   {
    
    temp+=in[j] * pow(10,k++);
   }
   
   
   a[n]=temp;
   temp=0;
   n++;
   
   
  }
 }
 
 printf("共有%d个连续数字它们分别是:\n",n);
    for(i=0;i<n;i++)
    {
     
     printf("a[%d]=%d\n",i,a[i]);
    } printf("\n");
    
    
    return 0;
}
精简

评分

参与人数 1荣誉 +10 鱼币 +10 贡献 +5 收起 理由
~风介~ + 10 + 10 + 5 加油哦!看好你:)

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-11-4 13:22:57 | 显示全部楼层
别急
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-12 17:44

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表