输入一个字符串,判断该字符串是否是回文(回文是指将该字符串含有的字符逆序排列后得到的字符串和原字符串相同的字符串)如果是回文,则输出“Yes”;否则输出“No”。
时间: 2024-10-21 13:03:31 浏览: 18
判断一个字符串是否是回文的一种简单方法是通过双指针技术。首先,我们创建两个指针,一个从字符串的开始位置(索引0),另一个从结束位置(最后一个字符的索引减一)。然后依次比较这两个指针指向的字符,如果它们相等,就移动两个指针各向内移动一位,直到两者相遇或者发现不相等的字符。如果整个过程都没有找到不相等的字符,那么该字符串就是回文。
以下是使用C++实现的一个示例:
```cpp
#include <iostream>
#include <string>
std::string isPalindrome(const std::string& str) {
int start = 0, end = str.length() - 1;
while (start < end) {
if (str[start] != str[end]) {
return "No"; // 不是回文
}
start++;
end--;
}
return "Yes"; // 是回文
}
int main() {
std::string test = "madam";
std::cout << isPalindrome(test) << std::endl;
return 0;
}
```
在这个例子中,如果输入的字符串是"madam",函数会返回"Yes",因为无论正读还是反读,结果都是相同的。
相关问题
编码实现:输入一个字符串,判断该字符串是否是回文(回文是指将该字符串含有的字符逆序排列后得到的字符串和原字符串相同的字符串)如果是回文,则输出“yes”;否则输出“no”。
可以使用以下代码实现:
```python
s = input("请输入一个字符串:")
if s == s[::-1]:
print("yes")
else:
print("no")
```
首先,使用`input()`函数获取用户输入的字符串。然后,使用字符串切片`[::-1]`将字符串反转,判断反转后的字符串是否和原字符串相等。如果相等,则输出“yes”,否则输出“no”。
java编码实现:输入一个字符串,判断该字符串是否是回文(回文是指将该字符串含有的字符逆序排列后得到的字符串和原字符串相同的字符串)如果是回文,则输出“Yes”;否则输出“No”。
在Java中,你可以通过双指针技术来判断一个字符串是否是回文。下面是一个简单的示例:
```java
import java.util.Scanner;
public class PalindromeCheck {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("请输入一个字符串:");
String input = scanner.nextLine();
if (isPalindrome(input)) {
System.out.println("Yes");
} else {
System.out.println("No");
}
}
// 判断字符串是否为回文
private static boolean isPalindrome(String str) {
int left = 0;
int right = str.length() - 1; // 从两端开始比较
while (left < right) {
// 如果左右字符不相等则不是回文
if (str.charAt(left) != str.charAt(right)) {
return false;
}
// 移动指针
left++;
right--;
}
// 全部比较完都相等,说明是回文
return true;
}
}
```
在这个程序中,我们首先获取用户输入的字符串,然后调用`isPalindrome`函数来检查它是否是回文。如果所有的字符从左到右和从右到左都匹配,那么就返回`true`,表示是回文,否则返回`false`。
阅读全文