zoukankan      html  css  js  c++  java
  • Codeforces Round #467 (Div. 1). C

    #include <algorithm>
    #include <cstdio>
    #include <cstring>
    #include <iostream>
    #include <vector>
    const int maxLength = 2005;
    
    char s[maxLength], t[maxLength];
    int letterOfS[30];
    int letterOfT[30];
    std::vector<int> result;
    void shift(char* seqence, int location) {
        std::string tt = seqence;
        tt = tt.substr(location) + tt.substr(0, location);
        std::reverse(tt.begin(), tt.begin() + tt.length() - location);
        for (int i = 0, length = tt.length(); i < length; ++i) {
            seqence[i] = tt[i];
        }
        //   seqence[tt.length()] = 0;
    
        result.push_back(tt.length() - location);
        //   printf("%s
    ", seqence);
    }
    void solveChange(int length) {
        int okLength = 0;
        for (int i = 0; i < length; ++i) {
            char targetLetter = t[i];
            int LocationOftargetInS;
            for (int j = 0; j < length - i; ++j) {
                if (s[j] == targetLetter) {
                    LocationOftargetInS = j;
                    break;
                }
            }
            //   printf("%d
    ", LocationOftargetInS);
            shift(s, LocationOftargetInS + 1);
            shift(s, length - 1);
            shift(s, 0);
            //    printf("
    ");
        }
    }
    
    int main() {
        int n;
        while (~scanf("%d", &n)) {
            result.clear();
            memset(letterOfS, 0, sizeof(letterOfS));
            memset(letterOfT, 0, sizeof(letterOfT));
    
            scanf("%s %s", s, t);
            for (int i = 0; i < n; ++i) {
                letterOfS[s[i] - 'a']++;
            }
            for (int i = 0; i < n; ++i) {
                letterOfT[t[i] - 'a']++;
            }
            bool canChange = true;
            for (int i = 0; i < 26 && canChange; ++i) {
                if (letterOfS[i] != letterOfT[i]) {
                    canChange = false;
                }
            }
    
            if (canChange) {
                solveChange(n);
                printf("%d
    ", (int)result.size());
                for (int i = 0; i < result.size(); ++i) {
                    printf("%d ", result[i]);
                }
                printf("
    ");
            } else
                printf("-1
    ");
        }
        return 0;
    }
    
  • 相关阅读:
    Promise
    ajax基础
    flex布局的盒子模型
    css3核心模块
    响应式开发
    HTML5标签及表单
    JS面向对象编程
    JS面向对象的编程
    ES5构造函数与ES6类
    类欧几里得算法
  • 原文地址:https://www.cnblogs.com/Basasuya/p/8620541.html
Copyright © 2011-2022 走看看