Codeforces 286 div2 a

本文详细解析了Codeforces Round #286 (Div. 2) a题的解题思路和代码实现,包括使用基本算法解决字符串匹配问题。
/**
 * @brief Codeforces Round #286 (Div. 2) a
 * @file a.cpp
 * @author mianma
 * @created 2014/01/19 09:30
 * @edited  2014/01/19 09:30
 * @type brute
 * @note
 */
#include <fstream>
#include <iostream>
#include <string>

using namespace std;

#define max(a, b)  ((a) > (b) ? (a) : (b))
#define min(a, b)  ((a) > (b) ? (b) : (a)) 
#define abs(a)     ((a) >  0  ? (a) : (0 - (a)))
#define CLR(vec)   memset(vec, 0, sizeof(vec))

#ifdef DEBUG
ifstream in;
ofstream out;
#define CIN in
#define COUT out
#else
#define CIN cin
#define COUT cout
#endif

string str;

/*idx to find the char*/
static inline int idx_to_ch(const string &str, const int &curr, const int &pos, const int &ch){
    return (curr == pos ? ch : (curr > pos ? str[curr - 1] : str[curr]) );
}

/*check pa*/
static inline int check_pa(const string &str, const int &pos, const int &ch){
    for(int i = 0, j = str.size(); i < j; i++, j--)
        if(idx_to_ch(str, i, pos, ch) != idx_to_ch(str, j, pos, ch))
                    return -1;
    return 0;
}

/*output the string insert char ch into pos */
static inline string out_pa(const string &str, const int &pos, const int &ch){
    string ret;
    for(int i = 0; i <= str.size(); i++)
        ret += idx_to_ch(str, i, pos, ch);
    return ret;
}

int main(void){
    ios_base::sync_with_stdio(0);
#ifdef DEBUG
    CIN.open("./in",  ios::in);
    COUT.open("./out",  ios::out);
#endif
    CIN >> str;
    for(int pos = 0; pos <= str.size(); pos++)
        for(int ch = 'a'; ch <= 'z'; ch++)
            if(!check_pa(str, pos, ch)){
                    COUT << out_pa(str, pos, ch) << "\n";
                    return 0;
            }
    COUT << "NA\n";
    return 0;
}


转载于:https://my.oschina.net/u/572632/blog/369178

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值