zoukankan      html  css  js  c++  java
  • 利用指针将一个数字字串转成int型

    題目内容:
    问题描述:本题利用指针完成将一个数字字符串转换为int整数的程序。
    Input
    输入数据可以是多组,每组是一个字符串。
    Ouput
    输出将这个字符串转换为int整数的形式。说明,如果输入字符串的第一个字符为“-”,则此数为负数,如果第一个字符为“+”或没有符号表示为正数。如果第一个字符或符号位后的第一个字符为非数字字符(‘0’——‘9’之间的为数字字符),则输出结果为0.字符串中其他位置上遇到非数字字符,则将该字符前面的数字字符转换为整数。
    输入输出说明:

    Input

    123
    -12345
    +678
    -12a
    +s
    -q
    ksd

    Output

    123
    -12345
    678
    -12
    0
    0
    0



    #include <stdio.h>
    #include <stdlib.h>

    int atoi(char *p)
    {
        int i,result=0;
        int j; //表示当前扫描到非数字字符的个数

        if(p[0]!='+'&&p[0]!='-'&&(p[0]>'9'||p[0]<'0'))
            return 0;                  //非法字符

        for(i=0,j=0; p[i]!=''; i++)
        {
            if(p[i]>='0'&&p[i]<='9')
                result=result*10+(p[i]-'0');//把字符数字转化为整型数字:ch - '0'
            else
                j++;

            if(p[0]=='-'||p[0]=='+')
            {//当数据以正负号开头时,第2次遇到非数字字符时(j=2),终止扫描
                if(j==2)
                    break;
            }
            else
            {//数据不是以正负号开头时,一遇到非数字字符,终止扫描
                if(j==1)
                    break;
            }
        }
        if(p[0]=='-')
            result=-result;
        return result;
    }

    int main()
    {
        char str[50];
        int k;
        while(scanf("%s",str)!=-1)
        {
            k=atoi(str);
            printf("%d ",k);
        }
        return 0;
    }
    成功不是偶然的,失败也不是必然的。
  • 相关阅读:
    docker-compose
    Cassandra
    npm常用命令
    k8s linux win10
    wsl2 docker 迁移
    docker http 代理
    mysql查看当前所有的数据库和索引大小
    mybatis 遍历list拼接 or查询
    es head crud
    nginx 代理转发mysql
  • 原文地址:https://www.cnblogs.com/zhuyukun/p/12669326.html
Copyright © 2011-2022 走看看