总在想,但凡编程基础正常点,都不至于惨败到这个地步。也像大多数人毕业出来,新鲜的第一份工作,如果做得好还可以略有成就感,做得一般还有提升的空间,但至少不至于像我这样基本没基础的被鄙视得一塌糊涂,被外界持续的否定,再加上经历了一些比较深刻的事,直到你也开始觉得,你存在的意义何在?可是这又怎样呢?事实已经如此了,那就努力改善!没有假如,没有如果,没有任何人可以替你来努力。今天去看了赵星的微博,很励志。有一段话藉以共勉:人总要付出很大努力才会让别人觉得毫不费力,世上没有白挣的钱,没有白付出的辛苦,只有没下够的功夫和没坚持的勇气,而功夫下在哪里,努力放在了什么地方,都是可以直接看得见的。

一.题目:下面程序实现如下功能:输入一个整数字符串转换为一个整值,如”1234”转为1234,”-1234”转

换为-1234。

二.思路: 定义一个数组用来存放输入字符串

输入整数字符串(加判断条件,确定是数字字符串)

将字符串转换为int型整数值

三.程序:

  #include <stdio.h>
#include <string.h> #define SIZE 64
int main(void)
{
char String[SIZE] = {};
int Number[SIZE] = {};
int nStart = ;
int i,j; printf("please input the string :\n");
gets(String);
//判断字符串是否带有负号
if(String[] == '-')
{
nStart = ;//如果是负数,则从字符数组第二个元素开始转换
}
else
nStart = ;//如果是正数,则将字符数组直接转换 //将字符串转换成数字,正负号不参与整型数组的存储,故j从0开始
for(i=nStart,j=;String[i];i++,j++)
{
Number[j] = String[i] - '' ;
}
//判断是不是负号,打印出来
printf("%c",String[]);
for(j=;Number[j];j++)
{
printf("%d",Number[j]);
} return ;
}

四.编译运行

五.分析问题

1.运行的结果看上去是想要的

仔细一想,不对,这只是按照想要的结果方式打印出来了,其实并没有真正实现字符串转化成整型数据,

而是利用%s将正负号打印出来而已,更何况整型数据竟然是存在数组里,编程的时候还在纠结正负号到

底放在第几个元素,搞笑,题目要求的是将字符串转换为一个整型数字!是数字!

2.那么,正负号的问题怎么解决呢?

别忘了,你定义数字的时候用int类型,它本身就是带符号的,根据你输入字符串的正负号,在数字前面

加个正负号就行啦~

3.不是说好了要加判断条件以确保是数字字符串吗?可是在输入时用gets()或者是scanf()怎么样才可

以加以判断嘛?

在输入的时候我们当然没办法来阻止非数字字符的输入,但是可以在转换成整数的过程中判断啊,傻了吧

~

六.改进

 #include <stdio.h>
#include <string.h> #define SIZE 64 int main(void)
{
char String[SIZE] = {};
int Number = ;
int nStart = ; printf("please input the string :\n");
gets(String);
//判断字符串是否带有负号
if(String[] == '-')
nStart = ;//如果是负数,则从字符数组第二个元素开始转换
else
nStart = ;//如果是正数,则将字符数组直接转换
//将字符串转换成数字
for(int i=nStart;String[i];i++)
{
if(String[i]>'0' && String[i]>'9')
Number = Number* + (String[i] - '') ;
}
//判断是不是负号,
if(nStart == )
Number = -Number;//如果负数,则把负号添加给Number
printf("the number is :\n");
printf("%d",Number);
return ;
}

七.编译运行

八.网上解答版本

   #include<stdio.h>
  #include<string.h>
  int main(void)
  {
   char s[];
   int n;
   long chnum(char *p);
   gets(s);
   if (*s=='-') n=-chnum(s+);
   else n=chnum(s);
   printf("%d\n",n);
   return ;
  }
  long chnum(char *p)
  {
   long sum=;
   while(*p)
   {
   if(*p>=''&&*p<='')
   sum=sum*+*p-'';
   p++;
   }
   return sum;
  }

相比之下,网上这种解法更加高大上,第一在于封装了那个转换函数,第二在于充分运用了指针和数组的关系,将

数组名当做指针来用。模仿这种方法,自己也练了一下

 #include <stdio.h>
#include <string.h> #define SIZE 64 //转换函数,将字符串转换成整型值
int StrToInt(char *p)
{
int sum = ;
while(*p)
{
if(*p>'' && *p<'')
sum = sum* + *p-'';
p++;
}
return sum;//返回整型值
} int main(void)
{
char String[SIZE] = {};
int Number = ;
int nStart = ; printf("please input the string :\n");
gets(String); if(*String == '-')//判断是否是负数
Number = -StrToInt(String+);//如果是负数,从字符串数组第二个元素作为参数开始传入,并在数字 前加负号
else
Number = StrToInt(String);//如果是正数,把字符串数组直接作为参数传入
printf("the number is :\n");
printf("%d",Number);
return ;
}

十.知识点:

1.字符串输入专题

1)gets()函数

2)fgets()函数

3)scanf()函数

3.数组和指针的关系

C语言每日一题之No.5的更多相关文章

  1. C语言每日一题之No.1

    鉴于在学校弱弱的接触过C,基本上很少编程,C语言基础太薄弱.刚好目前从事的是软件编程,难度可想而知.严重影响工作效率,已无法再拖下去了.为此,痛下决心恶补C语言.此前只停留在看书,光看好像也记不住,C ...

  2. C语言每日一题之No.9

    再做决定之前,我还是做好自己该做的.我不希望几年后会悔恨自己为什么在最该努力的时候不愿意吃苦.尊敬的女王陛下,请接题: 一.题目:有已按升序排好顺序的字符串a,编写程序将字符串s中的每个字符按升序的规 ...

  3. C语言每日一题之No.8

    正式面对自己第二天,突然一种强烈的要放弃的冲动,在害怕什么?害怕很难赶上步伐?害怕这样坚持到底是对还是错?估计是今天那个来了,所以身体激素有变化导致情绪起伏比较大比较神经质吧(☆_☆)~矮油,女人每个 ...

  4. C语言每日一题之No.4

    这几天老大也没安排我什么项目,于是想正好趁着空补C.当然,是利用晚上加班时间,白天正常上班时间还是学习公司的平台. 今儿个突然弱弱的感觉到在公司补C是件很低级的事情,哪怕是在加班时间都会被喷,因为大家 ...

  5. C语言每日一题之No.3

    几天下来,感慨学习要坚持下来真的是件很难的事,本来说了每天一题,可是毕竟这是个细活,需要用心雕琢,有时候真的不能当天拿下来>_<.虽然说只是一题,却涉及到很多小细节,慢慢的琢磨直至完全摸透 ...

  6. C语言每日一题之No.12

    文件操作知识:如何将一个文件的内容读取到另一个文件里? fread函数和fwrite函数   1.函数功能   用来读写一个数据块. 2.一般调用形式   fread(buffer,count,siz ...

  7. C语言每日一题之No.7

    今天是正式第一天在现有的世界里与自己相处,你再也没有另一个世界可以躲避了.终于要自己面对自己了,一个人要真实的面对自己的灵魂总是痛苦的.从学校到社会的环境转换,现实与理想的冲突,个人价值观和社会价值观 ...

  8. C语言每日一题之No.6

    人总要战胜内心的懦弱的,我不能一直这么缩在里边.终究向自己发出了挑战,还是会伤心的时候,发愣的时候.如果可以,我也希望像盗梦空间的女主一直沉在两个人的梦里永远不要醒来.可是,我们谁又能抗拒时间呢?这雨 ...

  9. C语言每日一题之No.2

    题目:已知三个整型数8,12,6,按公式s=a+b*c计算,并显示结果 思路:定义三个整型变量a,b,c 定义一个变量s用来保存运算结果 输出 程序: #include <stdio.h> ...

随机推荐

  1. java List 排序 Collections.sort() 对 List 排序

    class User { String name; String age;  public User(String name,String age){  this.name=name;  this.a ...

  2. C++ Primer : 第十二章 : 动态内存之shared_ptr类实例:StrBlob类

    StrBlob是一个管理string的类,借助标准库容器vector,以及动态内存管理类shared_ptr,我们将vector保存在动态内存里,这样就能在多个对象之间共享内存. 定义StrBlob类 ...

  3. HDU 4705 Y 树形枚举

    树形枚举--搜索 题目描述: 给你一棵树,要在一条简单路径上选3个不同的点构成一个集合,问能构成多少个不同的集合. 解法: 枚举所有结点,假设某个结点有n棵子树,每棵子树的结点个数分别为s1,s2,` ...

  4. typedef 和 define的区别

    类型取别名,还可以定义常量.变量.编译开关 都知道两个在某些情况下是相同的 但是define是在预编译时就会处理掉,进行简单的宏替换,不管正不正确都替换掉,末尾没有分号,有分号连分号也一起替换了. 而 ...

  5. 【BZOJ1011】【HNOI2008】遥远的行星

    奇奇怪怪突然出戏的奇葩题 原题: 直线上N颗行星,X=i处有行星i,行星J受到行星I的作用力,当且仅当i<=AJ.此时J受到作用力的大小为 Fi->j=Mi*Mj/(j-i) 其中A为很小 ...

  6. 最简puremvc

    工程如下,看来sendNotification是像comand和mediator发消息的 package { import flash.display.Sprite; import flash.eve ...

  7. java jfinal + ajaxfileupload.js 上传

    功能上传 需求:同时上传多张图片 前端:jquery.ajaxfileupload.js 后端:jfinal upload.htm <html> <body> <div ...

  8. QQ登入(3)QQ空间分享-无需登入

    public void myclick2(View v){ //QZone分享, SHARE_TO_QQ_TYPE_DEFAULT 图文,SHARE_TO_QQ_TYPE_IMAGE 纯图 ,SHAR ...

  9. SpringMVC+spring-security+sitemesh+hibernate+freemarker整合-转

    http://www.oschina.net/code/snippet_170632_46774 代码分享 当前位置: 代码分享 » Java  » Web编程 搜 索   SpringMVC+spr ...

  10. 【Hadoop】搭建完全分布式的hadoop

    博客已转移,请借一步说话! http://www.weixuehao.com/archives/577 下面博文已更新,请移步 ↑ 用于测试,我用4台虚拟机搭建成了hadoop结构 我用了两个台式机. ...