C/C++中的ACM题目输入处理——简单易上手
这里就不按其他文章的以各种情况为分类方法,而是以方法本身为分类办法。因为有一些方法是不同情况通用的,比如已知数量数字的输入和未知数量数字的输入,其实可以用同一种办法。
输入
C/C++ :scanf正则表达式
头文件<stdio.h>或<cstdio>
普通使用时,语法为scanf("%d",&a),当遇到空格符、换行、Tab时结束输入,并且丢弃这些空格符、换行、Tab键符号。
所以比如说我们读取的字符串有空格符时,或者需要读取特定的字符,就要用到scanf的一些其他用法,语法如下:
1. scanf("%ns",str)//n为整数,读入的字符串最长不超过n,然后在末尾补’\0’
char str[100];
scanf("%5s",str);输入abcdefghcd,最终str为abcde
2. scanf("%nf",&data);//读入的浮点数最多有n位整数,位数多于n,会截断。
float p;
scanf("%5f",&p);输入123,输出为p为123.00000;输入1234567,输出为12345.000000
3. scanf("%n[a-z]",&str);//读入最多n个字符,如果遇到非a-z的字符,停止,同理,%[0-9]表示只读入’0’到’9’之间的字符,%[a-zA-Z]表示只读入字母
4. scanf("%[^c]",&str);//读入任意多的字符,直到遇到字符c为止停止,这种方法主要是读取含空格、tab字符的字符串
char *str;
scanf("%[^\n]%*c",str);//这就是获取一行字符串,遇到换行符停止。%*c的作用是吸收\n,"%*"表示读入后不赋予任何变量,即跳过该输入值,也就是那个换行符,否则他会在缓冲区里,影响下一次输入
对于第四点,我们做个实验,先写如下代码运行
char a[500];
char b[500];
scanf("%[^\n]",a);
scanf("%[^\n]",b);
printf("%s",a);
printf("%s",b);
结果:输入abcd,换行,马上就输出了abcd,程序结束。
进行更改代码如下,运行
char a[500];
char b[500];
scanf("%[^\n]%*c",a);
scanf("%[^\n]%*c",b);
printf("%s",a);
printf("%s",b);
结果:输入abcd,换行,继续输入efg,换行,程序输出abcdefg,结束。
原因是,第一个程序中,第一个scanf输入abcd和换行,遇到换行了,于是输入结束,字符串a为abcd,换行符虽然没有输入到a里面,但它还在缓冲区,将作为下一次的输入第一个字符,于是第二个scanf输入字符串b时,由于直接输入了还在缓冲区的换行符,所以输入也结束,字符串b为空字符串。
第二个程序使用%*c,表示跳过了缓冲区的一个字符,就是那个换行符,于是达到我们的目的。当然如果把第一个scanf的换行符换为别的字符,效果应该会更明显,读者自行验证。
参考文章:scanf( )与正则表达式
C++ :std::cin
c++中cin的用法,参考C++中cin的详细用法,这里只给出针对acm输入cin的一些简单用法。
首先,cin>>data,遇到空格、tab、换行就停止输入,但是输入之前遇到这些空格、tab、换行,或缓冲区中第一个字符是空格、tab或换行这些分隔符时,cin>>会将其忽略并清除,继续读取下一个字符,若缓冲区为空,则继续等待。但是如果读取成功,字符后面的分隔符是残留在缓冲区的,cin>>不做处理。
所以如果输入的数据是以空格、换行分开,就直接cin>>就行了,如果数量未知,就用while循环
#include<iostream>
#include<vector>
using namespace std;
int main(){
vector<int>data;
int temp;
while (cin>>temp){
data.push_back(temp);
}
for (int i = 0; i < data.size(); i++){
cout<<data[i]<<" ";
}
}
输入:
1 2 3 4
5 6 7 8
9
输出:
1 2 3 4 5 6 7 8 9
第二,就是cin.get()用法,如下
- cin.get(char类型变量) ;
- cin.get(char类型变量数组,最大读取数量);
- cin.get();用于舍弃输入流的不需要的字符(比如回车什么的)
C++ :getline
头文件<iostream>
简单用法,可以通过getline来获取一行字符,语法如下
std::string s;
getline(std::cin, s) //从输入流中读取一行赋给s。
getline(std::cin, s ,ch)//从输入流中读取内容,赋给s,直到遇到字符ch,返回结果。
举个栗子
std::string s1;
std::string s2;
char ch=',';
getline(std::cin,s1);
getline(std::cin,s2,ch);
std::cout<<s1<<std::endl<<s2<<std::endl;
输入:
a,2,b,5 wd hh
2b,LOL
输出:
a,2,b,5 wd hh
2b
我们看到第二行,getline遇到,就停止输入了,那么如果我们想要把拆分后的字符串都保存,怎么办呢?那就用循环。还是用栗子说话。
输入
输入
1,2,5,9,74,582,1124
存储的数据结构自己选择,我这里用vector,代码如下
#include<iostream>
#include<vector>
using namespace std;
int main(){
string s;
char ch=',';
vector<string>str(0);
while (getline(cin,s,ch)){
str.push_back(s);
}
for (int i = 0; i < str.size(); i++){
cout<<str[i]<<" ";
}
}
输出
1 2 5 9 74 582 1124
当然也可以用for循环,特别是如果知道了输入数量的,比如输入n行字符串,保存
输入:
3
I love China
I am chinese
I am not SB
#include<iostream>
#include<vector>
using namespace std;
int main(){
int num;
cin>>num;
cin.get();//之所以要cin.get(),是因为cin>>num之后有一个换行符,这个换行符残留在缓冲区了(前面cin有讲),getline不会忽略缓冲区的换行、空格等,所以要主动去掉
vector<string>str(num);
for (int i = 0; i < num; i++){
getline(cin,str[i],',');
}
for (int i = 0; i < str.size(); i++){
cout<<str[i]<<" ";
}
}
当然,getline还可以用作单独的字符串分割,用到stringstream输入流,这里给出实例代码
#include<sstream>
#include <iostream>
/*
@func 字符串分割
@para1 待分割长字符串
@para2 分割标志字符
@ret 分割后子字符串数组,不包含标志字符delim
*/
vector<string>stringSplit(const string str,char delim){
stringstream ss;
ss<<str;
string item;
vector<string>elems;
while (getline(ss,item,delim))
{
if(!item.empty()){
elems.push_back(item);
}
}
return elems;
}
C++基本上使用以上cin和getline方法就可以处理大部分输入了,灵活运用就行。
输出
输出指定小数点后位数
C语言:printf("%.nf",number);
C++ :cout
#include<iomanip>
cout<<setprecision(n)<<数字<<endl;
其他
类型转换
string to char*
str1.c_str();,然后使用strcpy复制字符串拼接
- string类型,直接相加 +
- 字符串(字符数组),可以用
strcat(str1,str2)// #include<string.h>
char* to number
atoi(char*) // #include <stdlib.h>intatof(char*)floatnumber to string
to_string(num); // #include <string>char* to string
char ach1[] = "Hello";
string str1(ach1);
string str2 = ach1;
练习
用我以上介绍的方法,(其实C++不需要用到scanf),以下练习应该是可以轻松解决的。
进行在线oj输入输出练习
C/C++中的ACM题目输入处理——简单易上手的更多相关文章
- 南阳ACM 题目811:变态最大值 Java版
变态最大值 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 Yougth讲课的时候考察了一下求三个数最大值这个问题,没想到大家掌握的这么烂,幸好在他的帮助下大家算是解决了 ...
- Scanner, BufferedReader, InputStreamReader 与ACM模式输入
Scanner, BufferedReader, InputStreamReader 与ACM模式输入html { -webkit-print-color-adjust: exact } * { bo ...
- python基础练习题(题目 输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数)
day10 --------------------------------------------------------------- 实例017:字符串构成 题目 输入一行字符,分别统计出其中英 ...
- SQL Server存储过程中使用表值作为输入参数示例
这篇文章主要介绍了SQL Server存储过程中使用表值作为输入参数示例,使用表值参数,可以不必创建临时表或许多参数,即可向 Transact-SQL 语句或例程(如存储过程或函数)发送多行数据,这样 ...
- 面试大总结:Java搞定面试中的链表题目总结
package LinkedListSummary; import java.util.HashMap; import java.util.Stack; /** * http://blog.csdn. ...
- 面试大总结之二:Java搞定面试中的二叉树题目
package BinaryTreeSummary; import java.util.ArrayList; import java.util.Iterator; import java.util.L ...
- JAVA 中两种判断输入的是否是数字的方法__正则化_
JAVA 中两种判断输入的是否是数字的方法 package t0806; import java.io.*; import java.util.regex.*; public class zhengz ...
- (转)面试大总结之一:Java搞定面试中的链表题目
面试大总结之一:Java搞定面试中的链表题目 分类: Algorithm Interview2013-11-16 05:53 11628人阅读 评论(40) 收藏 举报 链表是面试中常出现的一类题目, ...
- AngularJS进阶(十八)在AngularJS应用中集成科大讯飞语音输入功能
在AngularJS应用中集成科大讯飞语音输入功能 注:请点击此处进行充电! 前言 根据项目需求,需要在首页搜索框中添加语音输入功能,考虑到科大讯飞语音业务的强大能力,遂决定使用科大讯飞语音输入第三方 ...
- python中的三种输入方式
python中的三种输入方式 python2.X python2.x中以下三个函数都支持: raw_input() input() sys.stdin.readline() raw_input( )将 ...
随机推荐
- Python开发中自动化构建项目结构样式
摘要:在项目开发过程中,一个良好的项目结构对于团队的协作和代码的可维护性起着重要作用.通过使用自动生成项目结构文字样式的工具.不仅节省了手动编写项目结构的麻烦,还确保了结构的一致性和准确性. 本文分享 ...
- K8S | 容器和Pod组件
对比软件安装和运行: 一.场景 作为研发人员,通常自己电脑的系统环境都是非常复杂,在个人的习惯上,是按照下图的模块管理电脑的系统环境: 对于「基础设施」.「主机操作系统」.「系统软件」来说,通常只做配 ...
- 一文了解io包中的discard类型
1. 引言 io.discard是Go语言标准库提供一个结构体类型,其在丢弃不需要的数据场景下非常好用.本文我们将从io.discard 类型的基本定义出发,讲述其基本使用和实现原理,接着简单描述 i ...
- 2023-07-14:讲一讲Kafka与RocketMQ中存储设计的异同?
2023-07-14:讲一讲Kafka与RocketMQ中存储设计的异同? 答案2023-07-14: 在Kafka中,文件的布局采用了Topic/Partition的方式,每个分区对应一个物理文件夹 ...
- docker部署zabbix6.0及企业微信发送告警
1 前言 1.1 实验背景 因zabbix 6.0新增许多新特性,为熟悉界面特意在本地部署一套简易版(未启用HA功能).原本想要在烧制了centos7.9系统树莓派上部署,一查之下armv7果然冷门, ...
- FAQ:Linux 查看服务器型号(R730为例)
命令:dmidecode -t system | grep -e Manufacturer -e Product 查询结果: Manufacturer: Dell Inc. Product Name: ...
- 【NestJS系列】核心概念:Providers提供者
前言 Providers是Nest中的一个基本概念,许多Nest中定义的类都可以被视为一个Provider,比如:service.repository.factory.helper等,它们都可以通过c ...
- 并发编程-FutureTask解析
1.FutureTask对象介绍 Future对象大家都不陌生,是JDK1.5提供的接口,是用来以阻塞的方式获取线程异步执行完的结果. 在Java中想要通过线程执行一个任务,离不开Runnable与C ...
- ES集群&kibana安装
一.elasticsearch介绍 Elasticsearch 是个开源分布式搜索引擎,它的特点有:分布式,零配置,自动发现,索引自动分片,索引副本机制,restful 风格接口,多数据源,自动搜索负 ...
- 使用 Sealos 在离线环境中光速安装 K8s 集群
作者:尹珉.Sealos 开源社区 Ambassador,云原生爱好者. 当容器化交付遇上离线环境 在当今快节奏的软件交付环境中,容器化交付已经成为许多企业选择的首选技术手段.在可以访问公网的环境下, ...