算法面试题:字符串反转

当面试算法问题时,一道常见的问题是 "反转字符串"。这个问题测试了你的基本编程能力以及对字符串和数组操作的了解。

问题:

给定一个字符串,将其反转。例如,输入 "Hello",输出 "olleH"。

解答:

可以使用多种编程语言来解决这个问题。以下是一些常见语言的示例解答:

Python 解答:

css 复制代码
def reverse_string(s):
    return s[::-1]

# 测试
input_string = "Hello"
result = reverse_string(input_string)
print(result)  # 输出 "olleH"

JavaScript 解答:

css 复制代码
function reverseString(s) {
    return s.split('').reverse().join('');
}

// 测试
let inputString = "Hello";
let result = reverseString(inputString);
console.log(result);  // 输出 "olleH"

C++ 解答:

css 复制代码
#include <iostream>
#include <string>
using namespace std;

string reverseString(string s) {
    int left = 0;
    int right = s.length() - 1;
    while (left < right) {
        swap(s[left], s[right]);
        left++;
        right--;
    }
    return s;
}

int main() {
    string inputString = "Hello";
    string result = reverseString(inputString);
    cout << result << endl;  // 输出 "olleH"
    return 0;
}

以上示例中,我们使用不同的编程语言实现了字符串反转。基本思路是从字符串的两端开始,交换字符直到中间位置,从而实现反转。这是一个经典的面试问题,常用于测试面试者的编程技能和对字符串操作的理解。

相关推荐
NAGNIP4 小时前
万字长文!回归模型最全讲解!
算法·面试
知乎的哥廷根数学学派4 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
666HZ6665 小时前
数据结构2.0 线性表
c语言·数据结构·算法
实心儿儿6 小时前
Linux —— 基础开发工具5
linux·运维·算法
charlie1145141917 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎8 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎8 小时前
leetcode_day10_筑基期_《绝境求生》
算法
j_jiajia8 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
源代码•宸9 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
Jasmine_llq10 小时前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计