蓝桥杯-错误票据(两种写法stringstream和扣字符)

2024-05-12 20:36

本文主要是介绍蓝桥杯-错误票据(两种写法stringstream和扣字符),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

某涉密单位下发了某种票据,并要在年终全部收回。

每张票据有唯一的ID号。

全年所有票据的ID号是连续的,但ID的开始数码是随机选定的。

因为工作人员疏忽,在录入ID号的时候发生了一处错误,造成了某个ID断号,另外一个ID重号。

你的任务是通过编程,找出断号的ID和重号的ID。

假设断号不可能发生在最大和最小号。

输入格式

第一行包含整数 N,表示后面共有 N 行数据。

接下来 N 行,每行包含空格分开的若干个(不大于100个)正整数(不大于100000),每个整数代表一个ID号。

输出格式

要求程序输出1行,含两个整数 m,n,用空格分隔。

其中,m表示断号ID,n表示重号ID。

数据范围

1≤N≤100

输入样例:

2
5 6 8 11 9
10 12 9

输出样例:

7 9

题解:

  • 把字符转成数字, 并且把数字存在数组中
  • 对数组排序(升序), 当前数不是前一个数+1, 并且当前数不等于前一个的时候 是缺少
  • 当前数等于前一个数的时候 是重复

扣字符写法:
ac代码👇

#include <bits/stdc++.h>
using namespace std;
vector<int> v;
int main()
{int n, m = 0; cin >> n;string s;cin.ignore();for (int k = 0; k < n; k ++){getline(cin, s);for (int i = 0; i < s.size(); i ++){if (s[i] >= '0' && s[i] <= '9')  // 扣字符的过程{int j = i, cnt = 1;while (j + 1 < s.size() && (s[j + 1] >= '0' && s[j + 1] <= '9')) j ++, cnt ++;string str = s.substr(i, cnt);i = j;v.push_back(stoi(str));  // string类型转成int类型}}}sort(v.begin(), v.end());int res1 = 0, res2;for (int i = 1; i < v.size(); i ++)if (v[i] != v[i - 1] + 1 && v[i] != v[i - 1]) res1 = v[i] - 1;else if (v[i] == v[i - 1]) res2 = v[i];cout << res1 << ' ' << res2 << endl;return 0;
}

stringstream写法:

ac代码👇

#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int v[N];
int main()
{int n, m = 0; cin >> n;string s;cin.ignore();for (int k = 0; k < n; k ++){getline(cin, s);stringstream ssin(s);  // 可以把ssin当成cin来用, 它包含 字符串swhile (ssin >> v[m ++]);}sort(v, v + m);int res1 = 0, res2;for (int i = 1; i < m; i ++)if (v[i] != v[i - 1] + 1 && v[i] != v[i - 1]) res1 = v[i] - 1;else if (v[i] == v[i - 1]) res2 = v[i];cout << res1 << ' ' << res2 << endl;return 0;
}

觉得写的不错的话, 点个赞吧~

这篇关于蓝桥杯-错误票据(两种写法stringstream和扣字符)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983671

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

SpringBoot3匹配Mybatis3的错误与解决方案

《SpringBoot3匹配Mybatis3的错误与解决方案》文章指出SpringBoot3与MyBatis3兼容性问题,因未更新MyBatis-Plus依赖至SpringBoot3专用坐标,导致类冲... 目录SpringBoot3匹配MyBATis3的错误与解决mybatis在SpringBoot3如果

MyBatis流式查询两种实现方式

《MyBatis流式查询两种实现方式》本文详解MyBatis流式查询,通过ResultHandler和Cursor实现边读边处理,避免内存溢出,ResultHandler逐条回调,Cursor支持迭代... 目录MyBATis 流式查询详解:ResultHandler 与 Cursor1. 什么是流式查询?

nginx配置错误日志的实现步骤

《nginx配置错误日志的实现步骤》配置nginx代理过程中,如果出现错误,需要看日志,可以把nginx日志配置出来,以便快速定位日志问题,下面就来介绍一下nginx配置错误日志的实现步骤,感兴趣的可... 目录前言nginx配置错误日志总结前言在配置nginx代理过程中,如果出现错误,需要看日志,可以把

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp