就是输入一段文本,然后让你实现字符串反转。
肺炎严重,假期延长,闲的不得不自主学习,然后就日常刷水题。
第一次的方法,简单易懂,就是时间超限了。TLIM
#include<bits/stdc++.h>
using namespace std;
stack<string> st;
int main(){
string s;
cin>>s;
reverse(s.begin(),s.end());
st.push(s);
while(getchar() != '\n'){
cin>>s;
reverse(s.begin(),s.end());
st.push(s);
}
while(!st.empty()){
cout<<st.top()<<" ";
st.pop();
}
return 0;
}
然后我就立马想到了gets();函数,简单又实用,就过了。AC
#include<bits/stdc++.h>
#define maxn 105
using namespace std;
int main(){
char s[maxn];
gets(s);
int l = strlen(s);
for(int i=l-1;i>=0;i--){
cout<<s[i];
}
}
可我就是想用栈来实现字符串反转,于是乎,改进~AC
#include<bits/stdc++.h>
using namespace std;
int main()
{
string temp;
getline(cin,temp);//获取一行可能包含有空格的文本
int len = temp.size();
const char *ss = temp.c_str();//将string转换成char*
stack <char> text;
int i = 0;
while(len--) {//入栈
text.push(ss[i++]);
}
while(!text.empty()){//出栈
cout << text.top();
text.pop();
}
return 0;
}