刘汝佳第五章 UVA-10391

这个题,学习了很多关于迭代器和STRING的知识。。。

对于集合set

  1. 创建迭代器用格式 set::iterator it; 目前不是很清楚双冒号什么用。
  2. set.find()函数,如果找到,返回此处的迭代器,如果找不到,返回set.end
  3. set.insert(x),在集合中插入x

对于string

  1. 流式输入cin>>string
  2. string.c_str 返回一个处理后的临时指针,指向一个str数组
  3. string.substr (begin,length) 如果不加Length,那么是从头到尾
  4. string.substring (begin,end) 和前面的substr有点不一样
  5. string.length() 基本操作
#include<bits/stdc++.h>
using namespace std;
set<string> words;
int main(void)
{
    string str;
    while(cin>>str)
    {
        words.insert(str);
    }
    set<string>::iterator it;
    for (it=words.begin();it!=words.end();it++)
    {
        str=*it;
        for(int i=0;i<str.length()-1;i++)
            {
                string former=str.substr(0,i+1);
                string later=str.substr(i+1,str.length()-(i+1));
                if( words.find(former)!=words.end() && words.find(later)!=words.end() )
                {
                    printf("%s\n",str.c_str());
                    break;
                }
            }
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值