zoukankan      html  css  js  c++  java
  • C# 判断string 是否可为数字

    //正则表达式
    //a)
    using System;
    using System.Text.RegularExpressions;

    public bool IsNumber(String strNumber)
    {
    Regex objNotNumberPattern
    =new Regex("[^0-9.-]");
    Regex objTwoDotPattern
    =new Regex("[0-9]*[.][0-9]*[.][0-9]*");
    Regex objTwoMinusPattern
    =new Regex("[0-9]*[-][0-9]*[-][0-9]*");
    String strValidRealPattern
    ="^([-]|[.]|[-.]|[0-9])[0-9]*[.]*[0-9]+$";
    String strValidIntegerPattern
    ="^([-]|[0-9])[0-9]*$";
    Regex objNumberPattern 
    =new Regex("(" + strValidRealPattern +")|(" + strValidIntegerPattern + ")");

    return !objNotNumberPattern.IsMatch(strNumber) &&
    !objTwoDotPattern.IsMatch(strNumber) &&
    !objTwoMinusPattern.IsMatch(strNumber) &&
    objNumberPattern.IsMatch(strNumber);
    }


    //b)
    public static bool IsNumeric(string value)
    {
    return Regex.IsMatch(value, @"^[+-]?\d*[.]?\d*$");
    }

    public static bool IsInt(string value)
    {
    return Regex.IsMatch(value, @"^[+-]?\d*$");
    }

    public static bool IsUnsign(string value)
    {
    return Regex.IsMatch(value, @"^\d*[.]?\d*$");
    }

    //遍历
    //a)
    public bool isnumeric(string str)
    {
        
    char[] ch=new char[str.Length];
        ch
    =str.ToCharArray();
        
    for(int i=0;i    {
            
    if(ch[i]<48 || ch[i]>57)
                
    return false;
        }

        
    return true;
    }


    //b)
    public bool IsInteger(string strIn) {
    bool bolResult=true;
    if(strIn==""{
    bolResult
    =false;
    }

    else {
    foreach(char Char in strIn) {
    if(char.IsNumber(Char))
    continue;
    else {
    bolResult
    =false;
    break;
    }

    }

    }

    return bolResult;
    }


    //c)
    public static bool isNumeric(string inString)
    {
    inString
    =inString.Trim();
    bool haveNumber=false;
    bool haveDot=false;
    for(int i=0;i{
    if (Char.IsNumber(inString[i]))
    {
    haveNumber
    =true;
    }

    else if(inString[i]=='.')
    {
    if (haveDot)
    {
    return false;
    }

    else
    {
    haveDot
    =true;
    }

    }

    else if(i==0)
    {
    if(inString[i]!='+'&&inString[i]!='-')
    {
    return false;
    }

    }

    else
    {
    return false;
    }

    if(i>20)
    {
    return false;
    }

    }

    return haveNumber;
    }

    }


    from:http://miaoshunping.bokee.com/5836813.html
  • 相关阅读:
    POJ1475 Pushing Boxes 华丽丽的双重BFS
    POJ3322 Bloxorz I 无脑广搜(我死了。。。)
    CH2401 送礼物 双向搜索
    POJ2248 Addition Chains 迭代加深
    POJ3074 Sudoku 剪枝深(神?)搜
    Luogu P1120 小木棍 [数据加强版] 来来来我们一起来剪枝,剪枝,剪枝、、、
    Luogu P4095 [HEOI2013]Eden 的新背包问题 思维/动规
    Luogu P5201 [USACO19JAN]Shortcut 最短路树???
    Luogu P5122 [USACO18DEC]Fine Dining 最短路
    Luogu P1608 路径统计 最短路计数
  • 原文地址:https://www.cnblogs.com/yiki/p/884643.html
Copyright © 2011-2022 走看看