TwiceString

Problem Statement


You are given a string s. Return the shortest string which contains s as a contiguous substring twice.

Note that two occurrences of s may overlap. For example, "ababa" contains "aba" twice.

Definition


Class: TwiceString
Method: getShortest
Parameters: string
Returns: string
Method signature: string getShortest(string s)
(be sure your method is public)


Notes

-The shortest string which contains s as a contiguous substring twice is always unique.

Constraints

-s will contain between 1 and 50 characters, inclusive.
-Each character in s will be a lowercase letter ('a'-'z').

Examples

0)

"aba"
Returns: "ababa"
This is the example shown in the problem statement.
1)

"xxxxx"
Returns: "xxxxxx"

2)

"topcoder"
Returns: "topcodertopcoder"

3)

"abracadabra"
Returns: "abracadabracadabra"

题意:就是给你个字符串,然后求包含该字符串的最短字符串。

// BEGIN CUT HERE // END CUT HERE #line 5 "TwiceString.cpp" #include <cstdlib> #include <cctype> #include <cstring> #include <cstdio> #include <cmath> #include <algorithm> #include <vector> #include <string> #include <iostream> #include <sstream> #include <map> #include <set> #include <queue> #include <stack> #include <fstream> #include <numeric> #include <iomanip> #include <bitset> #include <list> #include <stdexcept> #include <functional> #include <utility> #include <ctime> using namespace std; #define PB push_back #define MP make_pair #define REP(i,n) for(i=0;i<(n);++i) #define FOR(i,l,h) for(i=(l);i<=(h);++i) #define FORD(i,h,l) for(i=(h);i>=(l);--i) typedef vector<int> VI; typedef vector<string> VS; typedef vector<double> VD; typedef long long LL; typedef pair<int,int> PII; class TwiceString { public: string getShortest(string s) { //int j; // int len=s.size(); int i=1,j;//j在这里用来标记重复字符串的长度。 for(j=0;j<s.size();) { if(s1[i]=='\0') break; if(s1[i]==s[j]) {i++;j++;} else {i++;j=0;} } return s+s.substr(j); 法二:从第二个字符开始依次截到最后,然后和从第一个开始截到和刚才相同字符长度进行比较,一旦有相同就跳出。 /* for(j=1;j<len;j++) if(s.substr(j)==s.substr(0,len-j)) return s+s.substr(len-j); return s+s; */ } }; // BEGIN CUT HERE int main() { TwiceString ___test; string s; while(cin>>s) cout<<___test.getShortest(s)<<endl; return 0; } // END CUT HERE


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值