字符串:getline、删除子串.erase()函数、插入子串.insert()函数

news2024/12/23 23:31:59

getline具体用法:

1、函数形式

getline ( cin,字符串类型:变量名);//默认以换行符结束

1.jpg

getline (cin, 字符串类型:变量名指定的结束符); //指定换行结束符

2.jpg

2注意事项:

1)如果在使用getline()之前有使用scanf()或cin读取数据,那么需要用getline()将前面的换行符读取,再使用getline()。

2)getline()这个函数是可以读取空格,遇到换行符或者EOF结束,但是不读取换行符的。

3)当以指定的结束符(例:’!’)作为结束符时,’!’以及’!’后面的字符就不再读取。

4)经常需要将getline()与while使用

  在这个例子中,逗号运算符的作用就是将最后一个式子作为判定的条件,即while判断的是str!=”#”这个条件,只有当输入到str的为#键时,循环才会结束。

3.jpg

erase具体用法:

erase(开始位置i,删除长度len); 删除从i开始的n个字符(包括i位置)

e1.jpg

insert具体用法:

insert(插入位置i,插入字符串s);在字符串的第i个位置插入s。

i1.jpg

 

第1题     棋子 查看测评数据信息

棋盘从左往右分成 N 个格子。 棋盘上有且仅有 1 只白色棋子 (‘W’表示白旗) 和零个或多个黑色棋子 (‘B’表示黑旗)。在游戏开始时,白棋放置在棋盘的第 1 个格子上,黑棋放置在其他格子上,一个棋子占据一个格子。没有棋子的格子为空(用‘-’表示)。

FJ 然后开始移动白棋,他的每一步都可以做以下两件事之一(不能做其他事):

1、如果白旗的右邻居格子为空,FJ 会将白棋向右移动一个格子。

2、如果白旗的右邻居格子是黑棋,且该黑棋的右邻居为空,那么 FJ 会将白棋移动到该黑棋的右邻居。

FJ 一直重复上述操作,直到不能移动为止。

给定棋盘的初始状态,请输出游戏的最终状态。

输入格式

一个长度不超过 50 的字符串 S,表示棋盘的初始状态。‘W’表示白旗,‘B’表示黑旗,-’表示空格子。

输出格式

一个字符串,表示棋盘的最终状态。

输入/输出例子1

输入:

WB-B-B-

输出:

-B-B-BW

输入/输出例子2

输入:

W--BB---

输出:

--WBB---

输入/输出例子3

输入:

W

输出:

W

输入/输出例子4

输入:

W-B--B---BB-

输出:

--B--B--WBB-

#include<bits/stdc++.h>
using namespace std;
int main() {
    string board;
    cin>>board;
    int n=board.length();
    int w=0;
    for(int i=0;i<n;i++){
        if(board[i]=='W'){
            w=i;
            break;
        }
    }
    while(w<n-1){
        if(board[w+1]=='-'){
            swap(board[w],board[w+1]);
            w++;
        } 
		else if(w<n-2&&board[w+1]=='B'&&board[w+2]=='-'){
            swap(board[w], board[w+2]);
            w+=2;
        } 
		else break;
    }
    cout<<board;
    return 0;
}
第2题     字母统计  查看测评数据信息

        晨晨刚上幼儿园,对字母很感兴趣,特别是对‘b’、‘B’、‘m’、‘M’四个字母感觉很亲切,因为这四个字母很像“爸”、“妈”的发音。每次看到一段英文文章,她都要数一数文章里面有多少个上面四个字母。由于她刚学数数,数不准,想让大哥哥、大姐姐帮她数一下,你能帮她吗?

输入格式

一行:输入一段以‘#‘结束的字符串

输出格式

一行:一个整数代表字符串出现了多少个‘b’、‘B’、‘m’、‘M’字母

输入/输出例子1

输入:

Thanks for being there, mom. Happy Mother’s Day.#

输出:

4

样例解释

对于80%的数据,字符串长度小于255;

对于100%的数据,字符串长度小于1000;

#include<bits/stdc++.h>
using namespace std;
int main() {
    char str[1000];
    cin.getline(str,1000,'#');
    int count[26] = {0};
    for(int i=0;i<strlen(str);i++){
        if(str[i]>='a'&&str[i]<='z'){
            count[str[i]-'a']++;
        } 
		else if(str[i]>='A'&&str[i]<='Z'){
            count[str[i]-'A']++;
        }
    }
    int s=0;
    for(int i=0;i<26;i++){
        if(count[i]!=0){
            if('a'+i=='b'||'a'+i=='m')s+=count[i];
        }
    }
    cout<<s;
    return 0;
}
第3题     动物简介 查看测评数据信息

到了动物园,琦琦开心得跳起来。哗,这里好多动物呀,有老虎,有狮子……,在开心之余,琦琦也不忘妈妈的教导:观察动物时要认真仔细,还要看动物园附上的动物简介呀。

动物的简介原来还有英文版的呢!为了卖弄自己的英文水平,琦琦就告诉妈妈每张动物简介里出现了多少次该动物的名称。注意:琦琦只认识小写字母,而且只要是某部分连续的字母同动物名称完全一样,她就会认为这就是那动物的名称,因此当简介中同时出现了monkeys、smonkey、smonkeys时,她就会说出现了3个猴子的名称。

你能编程完成琦琦的任务吗?

输入格式

第1行为数字n(n<=3000),表示该动物的简介共有n行。

第2行为一个单词,表示琦琦认识的动物名称。

接着是n行,每行为一个长度小于250个字符的字符串,表示动物的简介。

输出格式

输出文件共1行,为简介里出现了多少次琦琦能识别出的动物的单词。

输入/输出例子1

输入:

2

 snake

 The snake is a long and thin animal.

 Snakes have no legs or feet.

输出:

1

#include<bits/stdc++.h>
using namespace std; 
int m; 
string a; 
string b; 
int c; 
int main(){ 
    cin>>m;
    cin>>a;
    getline(cin,b); 
    int lena=a.size(); 
    c=0; 
    for(int i=0;i<m;i++){     
       getline(cin,b);
       int lenb=b.size(); 
        for(int j=0;j<=lenb-lena;j++){ 
        bool f=true; 
        for(int k=0;k<lena;k++){ 
             if(b[j+k]!=a[k]){ 
             f=false; 
             break; 
             } 
        } 
             if(f)c++;         	       
        }
    
    }
   cout<<c<<endl; 
   return 0;

}
第4题     翻转字符串 查看测评数据信息

给你一个字符串s,你可以进行一种操作:选取前i个字母,得到一个前缀,把它翻转。你可以操作任意次,要求你最后得到的字符串是最小的。

当然,为了增加趣味性,我们有一个限制:你依次取的前缀的长度一定要是递增的。

比如:s="BCDAF",你可以先把前3个翻转,得到"DCBAF",然后把前4个翻转,得到"ABCDF"。

输入格式

第一行为一个字符串s

输出格式

你得到的最小字符串。

输入/输出例子1

输入:

ABBA

输出:

AABB

输入/输出例子2

输入:

ACAB

输出:

AACB

样例解释

s的长度在1到50之间。

#include<bits/stdc++.h>
using namespace std;
string s;
int main(){
    cin>>s;
    for(int i=1;i<s.size();i++){
        if(s[0]>=s[i]){
            s=s[i]+s;
            s.erase(i+1,1);
        }
    }
    cout<<s;
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1422272.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java基础--异常

异常 将程序执行中发生的不正常情况称为“异常”&#xff08;语法错误和逻辑错误不是异常&#xff09;。 异常时间分为两大类&#xff1a; 1.Error&#xff08;错误&#xff09;&#xff1a;Java虚拟机无法解决的严重问题。Error 是严重错误&#xff0c;程序会崩溃。 2.Except…

【AI视野·今日NLP 自然语言处理论文速览 第七十七期】Mon, 15 Jan 2024

AI视野今日CS.NLP 自然语言处理论文速览 Mon, 15 Jan 2024 Totally 57 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Computation and Language Papers Machine Translation Models are Zero-Shot Detectors of Translation Direction Authors Michelle Wastl, Ja…

奥威-金蝶BI方案:企业获利能力该这样看

获利能力、偿债能力、营运能力是企业经营发展中需要密切关注的三大基础能力&#xff0c;通常可通过详细的数据分析可视化来获知。那么&#xff0c;怎么分析企业获利能力&#xff1f;奥威-金蝶BI方案做了个示范。 按年看 按月看 一般来说&#xff0c;我们会做成两张报表&#x…

代码随想录算法刷题训练营day20

代码随想录算法刷题训练营day20&#xff1a;LeetCode(654)最大二叉树、LeetCode(617)合并二叉树、LeetCode(700)二叉搜索树中的搜索、LeetCode(700)二叉搜索树中的搜索、LeetCode(98)验证二叉搜索 LeetCode(654)最大二叉树 题目 代码 import java.util.Arrays;/*** Definit…

Java面试架构篇【一览众山小】

文章目录 &#x1f6a1; 简介☀️ Spring&#x1f425; 体系结构&#x1f420; 生命周期 &#x1f341; SpringMVC&#x1f330; 执行流程 &#x1f31c; SpringBoot&#x1f30d; 核心组件&#x1f38d; 自动装配&#x1f391; 3.0升级 &#x1f505; spring Cloud Alibaba&am…

Consul容器服务自动发现和更新

目录 前瞻 什么是服务注册与发现 什么是consul Docker-consul实现过程 Docker-consul集群部署 实验准备 实验流程 前瞻 什么是服务注册与发现 服务注册与发现是微服务架构中不可或缺的重要组件。起初服务都是单节点的&#xff0c;不保障高可用性&#xff0c;也不考虑服…

web应用课——(第一讲:html基础标签)

目录 一、html文件结构 二、文本标签 三、图片 四、音频和视频 五、超链接 六、表单 七、列表 八、表格 九、语义标签 十、特殊符号 一、html文件结构 <html>标签&#xff1a;表示一个 HTML 文档的根&#xff08;顶级元素&#xff09;&#xff0c;所以它也被…

可以举一反三的动态规划问题(最短编辑问题)

给定两个字符串 A 和 B&#xff0c;现在要将 A经过若干操作变为 B&#xff0c;可进行的操作有&#xff1a; 删除–将字符串 A 中的某个字符删除。插入–在字符串 A 的某个位置插入某个字符。替换–将字符串 A 中的某个字符替换为另一个字符。 现在请你求出&#xff0c;将 A 变…

掌握 Android JNI 基础

写在前面 最近在看一些底层源码&#xff0c;发现 JNI 这块还是有必要系统的看一下&#xff0c;索性就写一写博客&#xff0c;加深加深印象&#x1f37b; 本文重点聊一聊一些干货&#xff0c;避免长篇大论 JNI 概述 JNI 是什么&#xff1f; 定义&#xff1a;Java Native In…

类和对象 第六部分 继承 第一部分:继承的语法

一.继承的概念 继承是面向对象的三大特性之一 有些类与类之间存在特殊的关系&#xff0c;例如下图&#xff1a; 我们可以发现&#xff0c;下级别的成员除了拥有上一级的共性&#xff0c;还有自己的特性&#xff0c;这个时候&#xff0c;我们可以讨论利用继承的技术&#xff0c;…

使用antdesign3.0、echarts制作固定资产后台管理系统原型

学了半个月Axure,周末用半天时间&#xff0c;照着网上的模板做了一个固定资产后台管理系统的原型。重点是内联框架的使用&#xff0c;和对echarts表格js代码的调试。原型链接&#xff1a;https://qoz5rv.axshare.com 资产管理系统

qt 动态添加多个button按钮,并添加单击响应

qt动态添加多个button按钮简单&#xff0c;难题是如何对动态的按钮添加响应函数&#xff0c;本文解决方案有两个 方法一&#xff1a;使用信号-槽函数 QString strTemp;int nCol 6;//一行有6个for(int i 0; i < CZList.size(); i){int ii i / nCol;int jj i % nCol;strT…

Qt+css绘制标题

之前学过html和小程序&#xff0c;帮老师做项目的时候也用过vue&#xff0c;在想qt绘制界面是不是也可以使用css,然后查了一些资料&#xff0c;绘制了一个标题&#xff0c;准备用到智能家居的上位机上面。 成果 源码 重写了paintEvent函数和TimeEvent函数&#xff0c;一个用于绘…

Next.js如何正确处理跨域问题?

以前一直使用Vue来写前端。去年下半年接手了一个基于React Next.js的项目&#xff0c;于是顺带学习了一下Next.js。由于Next.js的特点&#xff0c;这个项目的前后端是放在一起的。一开始没什么问题&#xff0c;看了半天文档就上手了。 上周我们需要在另一个网页项目中&#x…

基于DataX完成数据导入-仅新增方案

仅新增方式: 订单退款表为例, 探讨如何完成仅新增方式导入操作 从业务库将数据导入到ODS层, 分为 首次导入和增量导入两部分, 其中首次导入指的第一次建表, 导入数据, 此时一般都是全量导入, 后续每一天都是采用增量导入的方式, 当前项目, 增量模式: T1(当天处理都是上一天的数…

Vue中嵌入原生HTML页面

Vue中嵌入html页面并相互通信 需求&#xff1a;b2b支付需要从后获取到数据放到form表单提交跳转&#xff0c;如下&#xff1a; 但是vue目前暂时没找到有类似功能相关文档&#xff0c;所以我采用iframe嵌套的方式 1. Vue中嵌入Html <iframe src"/static/gateway.htm…

储能柜控制单元|EsccUnit8300储能柜控制单元功能简介及定制开发|储能EMS能量控制单元|储能控制单元|储能柜EMS系统|储能协调控制器

储能柜控制单元&#xff5c;EsccUnit8300储能柜控制单元功能简介及定制开发|储能EMS能量控制单元|储能控制单元|储能柜EMS系统|储能协调控制器 一&#xff1a;什么叫储能柜 Energy storage cabinet 储能柜包含柜体、由池组单元、由池管理单元、储能变流器、控制单元、消防单元…

【算法与数据结构】121、122、123、188、309、714、LeetCode买卖股票的最佳时机I II III IV+含冷冻期+含手续费

文章目录 一、121、LeetCode买卖股票的最佳时机1.1 动态规划1.2 动态规划-滚动数组 二、122、买卖股票的最佳时机 II三、123、买卖股票的最佳时机 III七、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、121、LeetCode买…

【科技素养题】少儿编程 蓝桥杯青少组科技素养题真题及解析第23套

少儿编程 蓝桥杯青少组科技素养题真题及解析第23套 1、英国计算机科学家艾伦图灵于 1950 年提出了著名的“图灵测试”,用于判断计算机是否具有智能。“图灵测试”是通过()的方法进行判断的 A、让两台计算机对话 B、让人类与计算机对话 C、给计算机出题 D、让计算机分辨图…

Logstash 7.7.1版本安装系统梳理

前言 上一篇文章介绍了 《ElasticSearch7.7.1集群搭建 & Kibana安装》&#xff0c;今天说一下 Logstash的安卓和配置&#xff1b; Logstash是一个开源的数据收集引擎&#xff0c;具有实时管道功能。它可以动态地将来自不同数据源的数据统一起来&#xff0c;并将数据标准化…