题目地址:P5238 整数校验器

显然这道题不算难,细心即可AC

细节见代码中的注释

#include <bits/stdc++.h>
#define ll long long
using namespace std;
string s, l, r;//对除了数据组数以外的所有数均用string存

inline bool pd0(int l, int r) {//判断是否每一位都符合要求
    for (int i = l; i < r; i++)
        if ('0' <= s[i] && s[i] <= '9') continue;
        else return 0;
    return 1;
}

inline bool pd1() {//判断是否合法
    int len = s.length();
    if (len == 1 && s[0] == '0') return 1;//0要特判
    if (s[0] == '-') {//负数和正数分开判
        if ('1' <= s[1] && s[1] <= '9')//判断首位是否符合要求
            return pd0(2, len);
        return 0;
    }
    if ('1' <= s[0] && s[0] <= '9')
        return pd0(1, len);
    return 0;
}

inline bool pd(string a, string b) {//判断a是否小于b
    int lena = a.length(), lenb = b.length();
    if (lena == lenb) {
        int flag = 1;
        for (int i = 0; i < lena; i++)
            if (a[i] != b[i]) {
                flag = 0;
                break;
            }
        if (flag) return 1;//特判相等
    }
    if (a[0] == '-' && b[0] != '-') return 1;
    if (a[0] != '-' && b[0] == '-') return 0;
    if (a[0] == '-' && b[0] == '-') {//正数负数分开判
        if (lena < lenb) return 0;
        if (lena > lenb) return 1;//先判长度
        for (int i = 1; i < lena; i++) {
            if (a[i] == b[i]) continue;
            if (a[i] < b[i]) return 0;
            return 1;
        }
    }
    if (a[0] != '-' && b[0] != '-') {
        if (lena > lenb) return 0;
        if (lena < lenb) return 1;
        for (int i = 0; i < lena; i++) {
            if (a[i] == b[i]) continue;
            if (a[i] > b[i]) return 0;
            return 1;
        }
    }
    return 0;
}

inline bool pd2() {//判断是否越界
    return pd(l, s) && pd(s, r);
}

int main() {
    ios::sync_with_stdio(0);//用了string就必须用cin,加点速
    cin >> l >> r;
    int t;
    cin >> t;
    while (t--) {
        cin >> s;
        if (!pd1()) {//判断是否输出1
            puts("1");
            continue;
        }
        if (!pd2()) {//判断是否输出2
            puts("2");
            continue;
        }
        puts("0");
    }
    return 0;
}

P5238 整数校验器的更多相关文章

  1. 洛谷 P5238 整数校验器

    题目描述 有些时候需要解决这样一类问题:判断一个数 x 是否合法. x 合法当且仅当其满足如下条件: x 格式合法,一个格式合法的整数要么是 0,要么由一个可加可不加的负号,一个 1 到 9 之间的数 ...

  2. 洛谷P5238 整数校验器

    看到没有边读入边处理的,我来水一发 我们要看一下有那些情况是格式不合法的 单独的负号 -0(后面可以有其他数字) 0 +(后面一些数字) 我们用快速读入的方法 读取字符进行处理 还有可能超出范围的 考 ...

  3. LuoguP5238 整数校验器 题解

    Content 给定两个整数 \(l,r\),再给定 \(T\) 个整数,请判断对于每个整数 \(x\),是否满足以下要求: \(x\in[l,r]\). \(x\) 格式合法. 数据范围:\(-2^ ...

  4. struts_23_xwork校验器列表使用例子

    required 必填校验器 <field-validator type="required"> <message>性别不能为空!</message& ...

  5. struts_22_xwork校验器列表使用说明

    系统提供的校验器列表如下: required (必填校验器,要求field的值不能为null) requiredstring (必填字符串校验器,要求field的值不能为null,并且长度大于0,默认 ...

  6. Struts2内建校验器(基于校验框架的文件校验)

    位于xwork-2.0.4.jar压缩包中( com.opensymphony.xwork2.validator.validators)有个文件default.xml ,该文件中定义了Struts2框 ...

  7. 使用 Struts2 校验器校验用户注册信息

    基于验证框架的输入校验 一.创建一个struts2项目testValidators.Struts2 初体验:http://www.cnblogs.com/likailan/p/3280820.html ...

  8. Struts 2 之校验器

    对于输入校验,Struts2提供了两种方式,1.使用validate方法:2.基于XML配置实现 . validate()方法 支持校验的Action必须实现Validateable接口,一般直接继承 ...

  9. Struts2内置校验器——完整实例代码

    一.校验器的配置风格 1.字段校验器: <field name="被校验的字段"> <field-validator type="校验器名"& ...

随机推荐

  1. Vue.js 条件与循环

    条件判断: v-if: 条件判断使用 v-if 指令: v-else-if:(其实和Java,c,js的语法差不多) v-show:

  2. CentOS 7 的安装

    CentOS 7的安装 --------------------------- 安装前的准备: 1.去官网或是去网上下载好CentOS 7的镜像文件 下载主页: https://www.centos. ...

  3. eclipse_maven换源

    1. 手动新增一个xml文件: <?xml version="1.0" encoding="UTF-8"?> <settings xmlns= ...

  4. Event Recommendation Engine Challenge分步解析第一步

    一.简介 此项目来自kaggle:https://www.kaggle.com/c/event-recommendation-engine-challenge/ 数据集的下载需要账号,并且需要手机验证 ...

  5. BFC规范

    BFC规范 BFC规范是什么? BFC规范也叫块级格式化上下文.是指一个独立的容器. 如何触发BFC? 我们可以通过一下几种方式触发BFC 1.通过浮动触发:float(除none) 2.通过绝对\固 ...

  6. jsp页面的共用

    我们经常希望一个网页,根据不同得请求显示不同得数据. 方法就是在session中添加一个变量,根据不同得值区分不同得请求类型. 后台:request.getSession().setAttribute ...

  7. ACM-ICPC 2018 焦作赛区网络预赛 L Poor God Water(矩阵快速幂,BM)

    https://nanti.jisuanke.com/t/31721 题意 有肉,鱼,巧克力三种食物,有几种禁忌,对于连续的三个食物:1.这三个食物不能都相同:2.若三种食物都有的情况,巧克力不能在中 ...

  8. 细说tomcat之类加载器

    官网:http://tomcat.apache.org/tomcat-7.0-doc/class-loader-howto.htmlJava类加载与Tomcat类加载器层级关系对比 Java Clas ...

  9. sql parser

    最近在整理很多SQL代码, 需要分析出每个SQL的目标表和源表各有哪些, 网上没有找到工作具, 打算写个工具. Java调研结果:1. 商业组件包 sqlparser 有试用版组件, 限制SQL少于1 ...

  10. Android获取版本号

    public static String getVersionName(Context context) { PackageManager manager = context.getPackageMa ...