HJ1 字符串最后一个单词的长度# HJ11 数字颠倒
约 402 字大约 1 分钟...
HJ1 字符串最后一个单词的长度# HJ11 数字颠倒
描述
输入一个整数,将这个整数以字符串的形式逆序输出
程序不考虑负数的情况,若数字含有0,则逆序形式也含有0,如输入为100,则输出为001
数据范围: 0≤n≤2^30−1
输入描述:
输入一个int整数
输出描述:
将这个整数以字符串的形式逆序输出
方法一:转换为字符串
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
int main() {
string s;
cin >> s; // 以字符串格式输入
reverse(s.begin(), s.end()); // reverse来倒序原有的字符串
cout << s;
return 0;
}

方法二:数学方法转换

#include<iostream>
using namespace std;
int main()
{
int n;
cin >> n;
if(n == 0) cout<<0;
while(n) {
cout << n % 10; // 取个位数字并输出
n /= 10; // 整除10
}
return 0;
}

HJ12 字符串反转
描述
接受一个只包含小写字母的字符串,然后输出该字符串反转后的字符串。(字符串长度不超过1000)
输入描述:
输入一行,为一个只包含小写字母的字符串。
输出描述:
输出该字符串反转后的字符串。
方法一:逆序拼接
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main(){
string s;
cin >> s;
string output = ""; //从一个空串开始
for(int i = s.length() - 1; i >= 0; i--) //逆序遍历字符串
output += s[i]; //将字符加到新串后面
cout << output << endl;
return 0;
}
