日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > c/c++ >内容正文

c/c++

Compound Words UVA - 10391(c++用法中substr函数用法+map实现)

發(fā)布時(shí)間:2023/12/4 c/c++ 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Compound Words UVA - 10391(c++用法中substr函数用法+map实现) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題意:

給出字典中一堆單詞,單詞的輸入方式是以字典序輸入的。問:在這一堆單詞中,有那些單詞是通過其它兩個(gè)單詞組合而來的。按字典序升序輸出這些單詞。

題目:

You are to find all the two-word compound words in a dictionary. A two-word compound word is a
word in the dictionary that is the concatenation of exactly two other words in the dictionary.

Input

Standard input consists of a number of lowercase words, one per line, in alphabetical order. There will
be no more than 120,000 words.

Output

Your output should contain all the compound words, one per line, in alphabetical order.

Sample Input

a
alien
born
less
lien
never
nevertheless
new
newborn
the
zebra

Sample Output

alien
newborn

分析:

如果用兩個(gè)字符串拼接看拼接好的字符串是否在字典中,一定會(huì)超時(shí)。
我們可以逆向,由于字符串的長(zhǎng)度不是很長(zhǎng),所以把一個(gè)字符串拆為兩個(gè)字符串看這兩個(gè)字符串是否都在字典中即可
在這里我用的map實(shí)現(xiàn)+substr函數(shù)

c++用法中substr函數(shù)用法

#include<string> #include<iostream> using namespace std; int main() { string s("12345asdf"); string a = s.substr(0,5); //獲得字符串s中從第0位開始的長(zhǎng)度為5的字符串 string b=s.substr(5);/**==string b=s.substr(5,9)*////先有pos,若無n,直接認(rèn)為是字符串長(zhǎng)度 cout << a << endl; cout << b << endl; }
  • 用途:一種構(gòu)造string的方法
  • 形式:s.substr(pos, n)
  • 解釋:返回一個(gè)string,包含s中從pos開始的n個(gè)字符的拷貝(pos的默認(rèn)值是0,n的默認(rèn)值是s.size() - pos,即不加參數(shù)會(huì)默認(rèn)拷貝整個(gè)s)
  • 先有pos,若無n,直接認(rèn)為是字符串長(zhǎng)度
  • ac代碼

    #include<iostream> #include<string.h> #include<map> #include<string> #include<algorithm> using namespace std; const int M=1e6+10; map<string,int>mp;//使用map對(duì)于字典中的單詞進(jìn)行映射,作用就是用于查詢單詞是否字典中 string s[M]; int k; int main() {k=0;while(cin>>s[k]){mp[s[k]]=1;k++;}for(int i=0; i<k; i++)for(int j=0; j<s[i].length(); j++){string u,v;u=s[i].substr(0,j);//然后從第一個(gè)開始,將每個(gè)單詞分成它所能變成的任意兩個(gè)單詞v=s[i].substr(j);///substr是C++語言函數(shù),主要功能是復(fù)制子字符串,要求從指定位置開始,并具有指定的長(zhǎng)度。if(mp[u]&&mp[v])//如果分成的兩個(gè)單詞的映射值均為1,那么這個(gè)就輸出這個(gè)單詞{cout<<s[i]<<endl;break;}}return 0; } 創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

    總結(jié)

    以上是生活随笔為你收集整理的Compound Words UVA - 10391(c++用法中substr函数用法+map实现)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 国产xxx| 国产精品suv一区二区三区 | 97碰碰碰| 四虎永久免费地址 | 99热都是精品 | 1024福利| 日韩av男人的天堂 | 久草免费在线观看视频 | 国产做爰高潮呻吟视频 | 亚洲精品一区二三区 | 黑鬼大战白妞高潮喷白浆 | 久久这里| 久久婷婷成人综合色 | 久久这里有精品 | 色肉色伦交av色肉色伦 | 手机福利视频 | 免费的黄色片 | 色天堂视频 | 黄网站免费大全入口 | 手机在线看片日韩 | 不卡中文| 国产精品视频区 | www,日韩| 亚洲人午夜精品 | 在线观看视频一区二区 | 国产一级自拍视频 | 在线观看免费毛片 | 日本三级免费网站 | 又色又爽又黄18网站 | 国产精品爽爽久久久久久 | 色丁香婷婷综合久久 | 朴麦妮原版视频高清资源 | 黄色短视频在线观看 | 干b视频在线观看 | 婷婷丁香在线 | 波多野结衣1区2区3区 | 国产成人无码一区二区在线观看 | 欧美a在线播放 | 国产原创91| 91亚洲精品久久久蜜桃 | 成人妇女淫片aaaa视频 | 精品人妻一区二区三区四区久久 | 中文字幕3 | 欧美日韩国产精品 | 日韩免费高清视频 | 调教女m荡骚贱淫故事 | 国产在线999 | 91国内| av天天干| 丰满人妻妇伦又伦精品国产 | 人妻无码中文字幕免费视频蜜桃 | 韩国主播青草55部完整 | 欧美福利在线观看 | 青草视频在线播放 | 成人国产一区二区 | 久久久久九九九 | 99精品乱码国产在线观看 | 国产成人综合在线视频 | 一区二区三区观看 | 亚洲一区二区视频在线 | 午夜视频www | 理论片毛片 | 国产一级在线观看视频 | av成人亚洲 | 老司机av导航 | 国产一区高清 | 日本美女动态图 | 福利精品| 日本一二三区在线视频 | 国产精品v欧美精品v日韩 | 深夜天堂| 九色porn蝌蚪 | 亚洲国产精品99久久久久久久久 | 久久999 | 欧美亚洲综合网 | 四虎在线影视 | 免费视频久久 | 91国产丝袜在线播放 | 久久五月天综合 | 紧身裙女教师三上悠亚红杏 | 人人妻人人澡人人爽人人欧美一区 | 国产美女久久久久久 | 69av片| 五月天激情综合网 | 国产精品电影在线观看 | 看av在线| 日日干夜夜爽 | 国产成人精品a视频 | 黄网免费观看 | 精品成人中文无码专区 | 日本免费看| 99操 | 性欧美一区二区 | 91亚洲精品一区二区乱码 | 午夜影院18 | 奇米影视在线视频 | 色永久| 日本午夜精品 | 欧洲精品久久久 |