C语言每日一题之No.5

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

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

四.编译运行

C语言每日一题之No.5

五.分析问题

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

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

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

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

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

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

加个正负号就行啦~

C语言每日一题之No.5

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

以加以判断嘛?

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

~

C语言每日一题之No.5

六.改进

 #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 ;
}

七.编译运行

C语言每日一题之No.5

八.网上解答版本

   #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.数组和指针的关系

上一篇:HDU2888 Check Corners(二维RMQ)


下一篇:【HDOJ 2888】Check Corners(裸二维RMQ)