結果

問題 No.927 Second Permutation
ユーザー Yugimn
提出日時 2022-05-11 01:54:04
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 7 ms / 2,000 ms
コード長 818 bytes
コンパイル時間 1,882 ms
コンパイル使用メモリ 195,320 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-07-18 08:38:25
合計ジャッジ時間 2,863 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 27
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp:9:12: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
    9 | void print(auto a){
      |            ^~~~
main.cpp:13:13: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
   13 | void prints(auto a){
      |             ^~~~
main.cpp:21:13: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
   21 | void printl(auto a){
      |             ^~~~

ソースコード

diff #

//Normal

#define _GLIBCXX_DEBUG
#define ll long long
#include <bits/stdc++.h>
using namespace std;
using Graph = vector<vector<int>>;

void print(auto a){
  cout << a;
}

void prints(auto a){
  cout << a << " ";
}

void prints(){
  cout << " ";
}

void printl(auto a){
  cout << a << endl;
}

void printl(){
  cout << endl;
}

void fix(int n){
  cout << fixed << setprecision(n);
}

int siz(string s){
  return (int)s.size();
}

int main(){
  string S; cin >> S;
  int s = (int)S.size();
  int nZ = 0;

  sort(S.rbegin(), S.rend());
  for(int i = 0; i < s; i++){
    int j = S[i]-'0';

    if(j != 0) nZ++;
  }

  if(S[0] == S[s-1] or nZ == 1){
    printl(-1);
  }else{
    for(int i = s-2; i >= 0; i--){
      if(S[i] != S[s-1]){
        swap(S[i], S[i+1]);

        printl(S);

        return 0;
      }
    }
  }
}
0