首页 > 编程语言 >KY146 魔咒词典C++

KY146 魔咒词典C++

时间:2024-01-30 20:00:56浏览次数:36  
标签:map tem int 魔咒 KY146 while C++ include string

构建一个map,还是查找问题。

麻烦点就是要 分解输入的过程

#include<iostream>
#include<string>
#include<map>
using namespace std;

int main(){
    string a,b;
    map<string,string> m;
    while(getline(cin,a)){//构建map
        b.clear();
        if(a[0]=='@') break;
        int i=0;
        for(;i<a.size();i++){
            if(a[i]==']') {
                break;
            }
        }
        i=i+2;
        for(int j=i;j<a.size();j++){
            b.push_back(a[j]);
        }
        a.erase(i-1,a.size()-i+1);
        m[a]=b;
    }
    int n;
    cin >> n;
    char c;
    c=getchar();//从输入缓冲区中读入换行
    while(n!=0){
        string tem;
        getline(cin,tem);
        map<string,string> :: iterator it =m.begin();
        while(it!=m.end()){
            if(tem[0]=='['){
                if(tem==it->first){
                    cout << it->second <<'\n';
                    break;
                }
            }else{
                if(tem==it->second){
                    string p=it->first;
                    p.erase(0,1);
                    p.erase(p.size()-1,1);
                    cout << p <<'\n';
                    break;
                }
            }
            it++;
        }
        if(it==m.end()) cout << "what?"<<'\n';
        n--;
    }
    return 0;
}

结果:

标签:map,tem,int,魔咒,KY146,while,C++,include,string
From: https://www.cnblogs.com/llllmz/p/17997854

相关文章

  • KY27 查找学生信息C++
    用map做查找就行了。#include<iostream>#include<string>#include<map>usingnamespacestd;structnode{stringname;stringx;intage;};typedefstructnodesinfo;intmain(){intn;while(cin>>n){map<......
  • c++ - 实现环形队列
    简介队列的核心思想是FIFO(FirstInFirstOut),即先入先出。入队(新增元素)必须从队尾加入,出队(删除元素)必须从队首出去。实现1、需要实现的方法#pragmaonce#include<iostream>usingnamespacestd;#ifndefMYQUEUE_H#defineMYQUEUE_H//环形队列的实现classMyQueue{......
  • C++ 避免不必要的复制进行优化的思路
    对于函数传入的参数,如果只是需要读取其中的值,一般来说,除了基础的int类型这种,建议声明为const&类型,这样避免不必要的复制操作。特殊的,std::vector进行增加元素时,可以考虑使用vec[0]=std::move(value),通过转移所有权来避免复制操作,因为vec[0]=value也存在复制操作。不......
  • 【C++】c++中的输入输出;缺省;重载;
    1、c++输入输出#include<iostream>//std是C++标准库的命名空间名,C++将标准库的定义实现都放到这个命名空间中usingnamespacestd;intmain(){ cout<<"Helloworld!!!"<<endl; return0;}//流插入运算符<<在一个语句中可以多次使用,如上面实例中所示,endl用于在行末添加......
  • c++ cast
    static_caststatic_cast(expression)用于非多态类型的低风险转换,如基类和派生类之间的转换,基本数据类型之间的转换(包括任何隐式转换),用户自定义转换,把void指针转换成目标类型的指针等。不进行运行时类型检查,只在编译时检查。具体如下用于类层次结构中基类和派生类之间指针......
  • Visual Studio部署C++矩阵库Armadillo的方法
      本文介绍在VisualStudio软件中配置C++环境下线性代数运算库Armadillo的方法。  首先,我们需要在Armadillo库官网下载其源代码,直接点击下图所示红色框内部分即可。  点击上图所示位置后,将弹出一个新的下载界面;Armadillo库的源代码将随后自动下载。  接下来,我们在Vis......
  • C++多态
    多态的概念多态(Polymorphism)是面向对象编程中的一个重要概念,它允许同一类型的对象在不同的上下文中表现出不同的行为。多态性有两种主要形式:编译时多态(静态多态性)和运行时多态(动态多态性)。编译时多态可以看成是函数重载和运算符重载,之前的文章已经涉及过,不再赘述;所以,下面所提到的多......
  • C++实现直接插入排序、冒泡排序、快速排序、选择排序(含调试程序)
    #include<iostream>#include<fstream>#include<string>#include<vector>#include<algorithm>usingnamespace::std;classSolution{public: //直接插入排序 voidinsertsort(vector<int>&num){ for(inti=1;i<num......
  • C++ Qt开发:运用QJSON模块解析数据
    Qt是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍如何运用QJson组件的实现对JSON文本的灵活解析功能。JSON(JavaScriptObjectNotation)是一种轻量级......
  • 有关UE5在VisualStudio升级后产生C++无法编译的问题及处理方案
    哈喽大家好,我是咕噜美乐蒂,很高兴又见面啦!最近,许多使用UE5的游戏开发者遇到了一个问题:在VisualStudio升级后,他们的C++代码无法编译。这个问题可能是由于UE5工程和VS之间的版本不兼容导致的。本文将深入探讨这个问题的原因以及如何解决它。一、问题的产生原因UE5是一款基于C++的游戏......