Moves in squared strings (I) -- 7Kyu

原題

http://www.codewars.com/kata/56dbe0e313c2f63be4000b25/train/cpp

題目

Moves in squared strings (I)
This kata is the first of a sequence of four about "Squared Strings".
You are given a string of n lines, each substring being n characters long: For example:

s = "abcd\nefgh\nijkl\nmnop"

We will study some transformations of this square of strings.

Vertical mirror: vert_mirror (or vertMirror or vert-mirror)
vert_mirror(s) => "dcba\nhgfe\nlkji\nponm"
Horizontal mirror: hor_mirror (or horMirror or hor-mirror)
hor_mirror(s) => "mnop\nijkl\nefgh\nabcd"

high-order function oper(fct, s) where
fct is the function of one variable f to apply to the string s (fct will be one of vertMirror, horMirror)

s = "abcd\nefgh\nijkl\nmnop"
oper(vert_mirror, s) => "dcba\nhgfe\nlkji\nponm"
oper(hor_mirror, s) => "mnop\nijkl\nefgh\nabcd"

分析

  • 字符串矩陣鏡像非常簡單,主要分為三步止喷,分割->交換位置->合并
  • oper()主要是把函數(shù)作為參數(shù)波桩。

參考答案

#include <iostream>
#include <string>
#include <sstream>
#include <vector>
#include <iterator>
#include <algorithm>

using namespace std;

string horMirror(const string &str){
    // 字符串以回車換行分割成數(shù)組
    istringstream iss(str);
    vector<string> str_vec;
    str_vec.assign(istream_iterator<string>(iss),istream_iterator<string>());

    // 交換字符串位置
    swap_ranges(begin(str_vec),(str_vec.begin()+str_vec.size()/2),str_vec.rbegin());

    // 把字符串?dāng)?shù)組組成字符串
    ostringstream oss;
    copy(begin(str_vec),end(str_vec),ostream_iterator<string>(oss,"\n"));
    string res = oss.str();
    res.pop_back(); // 除去最后一個回車菲嘴。

    return res;
}
string vertMirror(const string &str){
    // 字符串以回車換行分割成數(shù)組
    istringstream iss(str);
    vector<string> str_vec;
    str_vec.assign(istream_iterator<string>(iss),istream_iterator<string>());

    // 遍歷字符串
    for(auto& s:str_vec){
        // 交換字符位置
        swap_ranges(begin(s),(s.begin()+s.size()/2),s.rbegin());
    }

    // 把字符串?dāng)?shù)組組成字符串
    ostringstream oss;
    copy(begin(str_vec),end(str_vec),ostream_iterator<string>(oss,"\n"));
    string res = oss.str();
    res.pop_back(); // 除去最后一個回車阀坏。

    return res;
}
string oper(string (func)(const string &),const string &s){
    return func(s);
}

說明

1.字符串分割成向量的C++慣用法(流默認(rèn)以空格、回車鸡挠、Tab作為分割符)譬嚣。
2.容器范圍數(shù)據(jù)交換swap_range()
3.容器元素連接成字符串犀忱。

其它

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末募谎,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子阴汇,更是在濱河造成了極大的恐慌数冬,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搀庶,死亡現(xiàn)場離奇詭異拐纱,居然都是意外死亡,警方通過查閱死者的電腦和手機哥倔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門秸架,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人未斑,你說我怎么就攤上這事咕宿”壹ǎ” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵府阀,是天一觀的道長缆镣。 經(jīng)常有香客問我,道長试浙,這世上最難降的妖魔是什么董瞻? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮田巴,結(jié)果婚禮上钠糊,老公的妹妹穿的比我還像新娘。我一直安慰自己壹哺,他們只是感情好抄伍,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著管宵,像睡著了一般截珍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上箩朴,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天岗喉,我揣著相機與錄音,去河邊找鬼炸庞。 笑死钱床,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的埠居。 我是一名探鬼主播查牌,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼拐格!你這毒婦竟也來了僧免?” 一聲冷哼從身側(cè)響起刑赶,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤捏浊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后撞叨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體金踪,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年牵敷,在試婚紗的時候發(fā)現(xiàn)自己被綠了胡岔。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡枷餐,死狀恐怖靶瘸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤怨咪,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布屋剑,位于F島的核電站,受9級特大地震影響诗眨,放射性物質(zhì)發(fā)生泄漏唉匾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一匠楚、第九天 我趴在偏房一處隱蔽的房頂上張望巍膘。 院中可真熱鬧,春花似錦芋簿、人聲如沸峡懈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽逮诲。三九已至,卻和暖如春幽告,著一層夾襖步出監(jiān)牢的瞬間梅鹦,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工冗锁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留齐唆,地道東北人。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓冻河,卻偏偏與公主長得像箍邮,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子叨叙,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗锭弊。 張土汪:刷leetcod...
    土汪閱讀 12,737評論 0 33
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)擂错,斷路器味滞,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • 火車到站,我來了--北京钮呀。 從火車站出來剑鞍,出口處有很多的人在等待著他們的朋友,親人或是戀人爽醋。 出站口出來離得不遠(yuǎn)是...
    天堂不遠(yuǎn)閱讀 234評論 0 1
  • 請向有結(jié)果的人學(xué)習(xí)蚁署,因為結(jié)果從來不會撒謊。
    青子丹閱讀 828評論 0 1
  • 家鄉(xiāng)的大眾口味偏甜蚂四,像糖醋類的熱菜非常受歡迎光戈,不僅做法簡單又色香味俱全哪痰,很受家鄉(xiāng)人的青睞,時下本土的紫茄子步入收獲...
    王家人寧閱讀 244評論 0 0