欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    C语言-获取一个字符串中的数字组.doc

    • 资源ID:23959664       资源大小:952.50KB        全文页数:11页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    C语言-获取一个字符串中的数字组.doc

    Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateC语言-获取一个字符串中的数字组C语言-获取一个字符串中的数字组输入一个字符串,内有数字和非数字字符,例如: a123x456 17960?302tab5876 将其中连续的数字作为一个整数,依次存放到数组a中,例如123存放在a0,456存放在a1.统计共有多少个整数,并输出这些整数。这个程序的关键有两个问题:Q1. 如何发现连续的数字序列。Q2. 如何把这些数字队列整合成整数存储起来。对于Q1,判断数字序列的方法就是,当指针指向的一个元素是数字,(即处在0和'9'之间的字符)的时候开始记数,如果下一个仍然是数字,那么记数flag(在程序中为j)自加。若下一个元素不是数字,那么判断当前记数flag是不是大于0(即至少有一位),如果记数flag大于0的话。那么问题就转向了Q2,即一个完整的数字序列如何转换成一个整数。Q2的问题其实单拿出来是很简单的,就是输入一个只含有数字的字符串,如“7589”, 怎样把它转换成一个整形数7889, 具体算法是这样的:首先得到“7589”这个字符串的长度,为4.7589=7*1000+5*100+8*10+9;这里采用自加的方法: 7处在第4位上,乘数因子是10*(4-1); 5处在第3位上,乘数因子是10*(3-1); ./*其实这个问题扩展一下还可以做一个问题就是倒序输出,给“123456”输出“654321”这种问题。*/ 所以问题就被一步步简化了。 题目虽然很简单,但要学习这种结构化的思路以及层层简化问题的方法。另外需要考虑到的一个问题就是如果字符串以数字结尾,那么记数flag就会一直自加,直到到达字符串最后一位跳出循环,但却没有执行数字序列转整形数的操作,所以,需要在跳出循环时,判断当前的记数元素是不是大于0,从而将最后一个数字序列转换成为整形数。附源代码如下:1. #include <stdio.h>2. void main()3. char s100=;4. int a20;5. char *pstr;6. int *pa;7. int i=0,j=0;8. int k,m;9. int e10;10. int digit;11. int ndigit=0;12.  13. printf("Input a string:n");14. scanf("%s",s);15.  16. pstr=&s0;17. pa=&a0;18.  19. for(i=0;*(pstr+i)!='0'i+)20. if(*(pstr+i)>='0')&&(*(pstr+i)<='9')21. j+;22. else23. if(j>0)24. digit=*(pstr+i-1)-48;25. for(k=1;k<j;k+)26. e10=1;27. for(m=1;m<=k;m+)28. e10=e10*10;29. digit=digit+(*(pstr+i-1-k)-48)*e10;30. 31. *pa=digit;32. ndigit+;33. pa+;34. j=0;35. 36. 37. 38.  39. if(j>0)40. digit=*(pstr+i-1)-48;41. k=1;42. e10=1;43. while(k<j)44. for(m=1;m<=k;m+)45. e10*=10;46. digit+=(*(pstr+i-1-k)-48)*e10;47. k+;48. 49. *pa=digit;50. ndigit+;51. j=0;52. 53.  54. printf("There are %d numbers in this line. They are:n",ndigit);55. j=0;56. pa=&a0;57.  58. for(j=0;j<ndigit;j+)59. printf("%dt",*(pa+j);60. 61. printf("n");62.  63. -

    注意事项

    本文(C语言-获取一个字符串中的数字组.doc)为本站会员(豆****)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开