結果

問題 No.346 チワワ数え上げ問題
ユーザー おいがみおいがみ
提出日時 2016-03-06 16:57:56
言語 C++11
(gcc 13.3.0)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 1,424 bytes
コンパイル時間 1,430 ms
コンパイル使用メモリ 160,420 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-09-24 14:46:56
合計ジャッジ時間 2,256 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
6,816 KB
testcase_01 AC 2 ms
6,940 KB
testcase_02 AC 2 ms
6,944 KB
testcase_03 AC 1 ms
6,940 KB
testcase_04 AC 2 ms
6,940 KB
testcase_05 AC 2 ms
6,940 KB
testcase_06 AC 2 ms
6,940 KB
testcase_07 AC 1 ms
6,944 KB
testcase_08 AC 2 ms
6,944 KB
testcase_09 AC 2 ms
6,944 KB
testcase_10 AC 3 ms
6,944 KB
testcase_11 AC 2 ms
6,940 KB
testcase_12 AC 3 ms
6,944 KB
testcase_13 AC 2 ms
6,944 KB
testcase_14 AC 2 ms
6,944 KB
testcase_15 AC 2 ms
6,940 KB
testcase_16 AC 2 ms
6,940 KB
testcase_17 AC 2 ms
6,944 KB
testcase_18 AC 3 ms
6,940 KB
testcase_19 AC 2 ms
6,944 KB
testcase_20 AC 2 ms
6,944 KB
testcase_21 AC 2 ms
6,940 KB
testcase_22 AC 2 ms
6,944 KB
testcase_23 AC 2 ms
6,944 KB
testcase_24 AC 2 ms
6,940 KB
testcase_25 AC 1 ms
6,940 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include "bits/stdc++.h"
#ifndef err
#define err(...)
#define DebugWriteLine(...)
#endif
using namespace std;
void Calc();
#define ALL(win) begin(win),end(win)
#define RALL(win) (win).rbegin(),(win).rend()
typedef int64_t ll;
typedef uint64_t ull;
int main() {
  cin.tie(0);
  ios::sync_with_stdio(false);
  cout << fixed << setprecision(15);
  cin.exceptions(istream::failbit | istream::badbit);
  Calc();
  cout.flush();
  return 0;
}
template<class T> struct Iter {
  T&operator++() { return ++i; }
  constexpr const T&operator*() const { return i; }
  constexpr bool operator!=(const Iter &o) const { return i != o.i; }
  T i;
};

struct Scanner {
  template<class A = string>static A Next() { A a; cin >> a; return a; }
  template<class A = int>static vector<A> Array(int n) { vector<A> a(n); for (A&i : a) cin >> i; return a; }
  static string Line() { string s; getline(cin, s); return s; }
  static int Int() { return Next<int>(); }
  template<class A>Scanner&operator,(A&a) { a = Next<A>(); return *this; }
  template<class A>operator A() { return Next<A>(); }
}in;

/*---------------------------------------------------------------------*/

void Calc() {
  ll w_cnt = 0;
  string s = in;
  int n = s.size();
  ll cnt = 0;
  for (int i = n - 1; i >= 0; i--) {
    if (s[i] == 'w') w_cnt++;
    if (s[i] == 'c') {
      if (w_cnt < 2) continue;
      cnt += (w_cnt - 1)*w_cnt / 2;
    }
  }
  cout << cnt << endl;
}
0