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

一.题目:下面程序实现如下功能:输入一个整数字符串转换为一个整值,如”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. suse linux修改hostname

    SUSELinux中修改hostname需要修改以下两个文件 $vi /etc/HOSTNAME $vi /etc/hosts 然后重启系统即可.

  2. 光流算法:Brox算法(转载)

    参考论文:1. High Accuracy Optical Flow Estimation Based on a Theory for Warping, Thomas Box, ECCV20042. ...

  3. 用java将excel表格中的内容修改后写入到另一个excel中

    package nn; import java.io.File; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl. ...

  4. hdu 2795 线段树(二维问题一维化)

    Billboard Time Limit: 20000/8000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. SQL注入测试平台 SQLol -4.UPDATE注入测试

    访问首页的update模块http://127.0.0.1/sql/update.php,开始对update模块进行测试. update语法: UPDATE [users] SET [username ...

  6. Websphere发布时遇到的问题

    在发布时遇到了data source配置的问题,搞了好久没搞定,最后问题出现在 JDBC providers那边,Implementation class name 改成: com.ibm.db2.j ...

  7. TCP通讯程序设计---5

    这里主要包含客户机和服务器的编程. 一.编程模型函数化 使用函数说明:socket的理解 服务器: 创建socket使用函数----->socket 绑定地址使用函数------->bin ...

  8. Android 客户端和服务器 json交互

    http://www.cnblogs.com/jyan/articles/2544974.html 1.JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. ...

  9. HDU-4089 Activation (概率DP求概率)

    题目大意:一款新游戏注册账号时,有n个用户在排队.每处理一个用户的信息时,可能会出现下面四种情况: 1.处理失败,重新处理,处理信息仍然在队头,发生的概率为p1: 2.处理错误,处理信息到队尾重新排队 ...

  10. 被IP代理网站屏蔽了,真是跪了

    被IP代理网站http://www.xicidaili.com/nn/屏蔽了,真是跪了 T T