OpenJudge | 回文串判断

总时间限制: 1000ms 内存限制: 65536kB

描述

任意给定一个非空的字符串,判断其是否是回文串。回文串是指正向看和反向看均相等的串,如AbcDcbA和cDDc。如果是回文串,则输出1,否则,输出0

输入

长度不小于1不大于100的字符串

输出

如果是回文串,输出1
如果不是回文串,输出0

样例输入

abcdefghijkjihgfedcba

样例输出

1

思路

方法一:栈思想

将字符串的前半部分入栈,然后遍历后半部分,判断是否和栈顶元素相等。
这里要注意字符串长度为奇数和偶数的情况。

方法二:双指针

设置两个指针,一个指向字符串的头部,一个指向字符串的尾部,判断两个指针指向的字符是否相等。

Code

C

方法二
#include <stdio.h>
#include <string.h>
int main() {
	char str[9999];
	gets(str);
	for(int i = 0, j = strlen(str)-1; i < j; i++, j--){
		if(str[i] != str[j]) {
			printf("%d", 0);
			goto out;
		}
	}
	printf("%d", 1);
	out:;
}

C++

方法一
#include <bits/stdc++.h>
using namespace std;
int main() {
	string str;
	stack<char> S;
	cin >> str;
	for(long long unsigned int i = 0; i < str.size()/2; i++) {
		S.push(str[i]);
	}
	if(str.size() % 2 == 0) {
		for(long long unsigned int i = str.size()/2; i < str.size(); i++) {
			if(str[i] != S.top()) goto out;
			S.pop();
		}
	} else {
		for(long long unsigned int i = str.size()/2+1; i < str.size(); i++) {
			if(str[i] != S.top()) goto out;
			S.pop();
		}
	}
	cout << 1;
	goto out1;
	out:;
	cout << 0;
	out1:;
}
方法二
#include <bits/stdc++.h>
using namespace std;
int main() {
	string str;
	cin >> str;
	for(int i = 0, j = str.size()-1; i < j; i++, j--){
		if(str[i] != str[j]) {
			cout << 0;
			goto out;
		}
	}
	cout << 1;
	out:;
}

相关推荐

  1. OpenJudge | 判断

    2024-07-14 22:30:03       22 阅读
  2. 验证

    2024-07-14 22:30:03       34 阅读
  3. 131. 分割

    2024-07-14 22:30:03       52 阅读
  4. 647.

    2024-07-14 22:30:03       46 阅读
  5. 131. 分割

    2024-07-14 22:30:03       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-14 22:30:03       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-14 22:30:03       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-14 22:30:03       58 阅读
  4. Python语言-面向对象

    2024-07-14 22:30:03       69 阅读

热门阅读

  1. C++数组

    2024-07-14 22:30:03       19 阅读
  2. 数仓工具—Hive语法之正则表达式函数

    2024-07-14 22:30:03       21 阅读
  3. 【Lua】lua实现C# continue效果

    2024-07-14 22:30:03       17 阅读
  4. 探索TASKCTL和 DataStage 的ETL任务调度协同

    2024-07-14 22:30:03       17 阅读
  5. TCPDump协议分析工具

    2024-07-14 22:30:03       20 阅读
  6. 神领物流项目第二天

    2024-07-14 22:30:03       17 阅读