• 题解-洛谷P1184 高手之在一起


    https://www.luogu.org/problemnew/show/P1184

    (题目出处)

    见到地名,自然就想到字符串了。可以从第一天开始,将她的位置与高手方便取得地方一一比较,(char字符串型可用strcmp(s1,s2):

    当字符串s1<s2时,返回为负数;
    当s1==s2时,返回值= 0;
    当s1>s2时,返回正数。
    即:两个字符串自左向右逐个字符相比(按ASCII值大小相比较),直到出现不同的字符或遇''为止。)
    (string型可直接用“==”比较,若相等,返回1,反之为0)
    这里用string型。(wa了一次后)注意到一个地名中可能有空格,于是用string型的整行输入getline(cin,s1),即整行输入s1。
      注意getline有一个细节,即与cin连用的话要用cin.ignore()清除输入缓冲区的一个字符(或使用多次来清除多个字符),因为cin读到空格或回车后就会停止不读,但并不会清除这个字符。而这个字符如不清除,便会直接被getline读入。getline一读到回车(回车的表示视操作系统而定)就停止读入并把回车删除,故读到最后少读了一个数据(因为一开始的getline什么都没读到)。
    (又wa了N次后再就是因操作系统的不同导致的回车的表示不一样。Windows的回车为“ ”,Linux为“ ”,Mac为“ ”,而此题测试数据是由Windows生成、由Linux评测,即在Linux系统(评测系统)getline较Windows会多读入一个" "(ascll码为13),而第一个测试点的最后是没有回车的,即最后读入的地点较之前的地点名最后没有 ,故需要加特判(终于能过这个诡异的题了)
    上代码!
     1 #include<cstdio>
     2 #include<iostream>
     3 using namespace std;
     4 string g[21],luo[1000001];
     5 int main()
     6 {
     7     int m,n,total=0;
     8     cin>>n>>m;
     9     cin.ignore().ignore();
    10     for(int i=1;i<=n;i++)
    11     {
    12         getline(cin,g[i]);
    13     }
    14     for(int i=1;i<=m;++i)
    15     {
    16         getline(cin,luo[i]);
    17         if(luo[i][luo[i].length()-1]!=13) luo[i]+=char(13);
    18         for(int j=1;j<=n;j++)
    19         {if(luo[i]==g[j]){total++;break;}}
    20     }
    21     cout<<total;
    22     return 0;
    23 }

    课后巩固:https://blog.csdn.net/qq_38171115/article/details/70855325(strcmp函数的使用)

     https://www.cnblogs.com/ymd12103410/p/9514896.html(getline使用)
    https://blog.csdn.net/wxbmelisky/article/details/48596881(cin.ignore()使用)
    最后再了解一下不同系统回车与换行的表示吧。
    扩展:https://www.cnblogs.com/xiaotiannet/p/3510586.html(回车换行辨析)
  • 相关阅读:
    对于函数中多个返回值的处理
    Docker-compose 安裝单机版redis
    设计模式七大设计原则
    UML 设计技巧
    使用Docker 容器配置nexus3.29 私有仓库
    分布式消息Kafka通信原理分析
    分布式消息Kafka通信
    使用docker 搭建nexus3.29
    分布式消息Kafka初步认识及基本应用
    Dubbo 常用配置及源码分析
  • 原文地址:https://www.cnblogs.com/InductiveSorting-QYF/p/10452689.html
Copyright © 2020-2023  润新知