zoukankan      html  css  js  c++  java
  • PAT A1077 Kuchiguse (20)

    晴神书中AC代码

    #include <cstdio>
    #include <cstring>
    #include <iostream>
    using namespace std;
    int n, minLen = 256, ans = 0;
    char s[100][260];
    
    int main() {
    	#ifdef ONLINE_JUDGE
    	#else
    		freopen("1.txt", "r", stdin);
    	#endif // ONLINE_JUDGE
    	scanf("%d", &n); //n是字符串的个数
    	getchar();
    	for(int i = 0; i < n; i++) {
    		cin.getline(s[i], 260);
    		int len = strlen(s[i]);
    		if(len < minLen) minLen = len; //取最小长度
    		for(int j = 0; j < len / 2; j++) { //反转字符串s[i], 转化为求公共后缀
    			char temp = s[i][j]; //交换str[i]与str[len - i - 1]
    			s[i][j] = s[i][len - j - 1];
    			s[i][len - j - 1] = temp;
    		}
    	}
    	for(int i = 0; i < minLen; i++) { //判断所有字符串的第i个字符是否全部相等
    		char c = s[0][i]; //取第一个字符串的第i个字符
    		bool same = true;
    		for(int j = 1; j < n; j++) {	//判断其余字符串的第i个字符是否等于c
    			if(c != s[j][i]) { //只要有一个不等,就停止枚举,说明公共后缀到处为止
    				same = false;
    				break;
    			}
    		}
    		if(same) ans++; //若所有字符串的第i位相等,则计数器ans加1
    		else break;
    	}
    	if(ans) {
    		for(int i = ans - 1; i >= 0; i--) {
    			printf("%c", s[0][i]);
    		}
    	} else {
    		printf("nai"); //不存在公共后缀
    	}
    	return 0;
    }
    
  • 相关阅读:
    Prim算法的3个版本
    [转]"undefined reference to" 问题解决方法
    C/C++ 读写 Excel
    Poj 3468
    关于PS中矩形工具的学习
    PS初学习
    java第二天学习。
    Java学习第一天
    二叉树的线索化
    struct files_struct
  • 原文地址:https://www.cnblogs.com/isChenJY/p/11400360.html
Copyright © 2011-2022 走看看