这个还是一样的哈,题目在这
思路:
我们用一个 flag
(bool)变量记录我们是不是在两个竖条之间,如果是,就不能输出这个字符
但如果这个字符不是竖条,就输出这个字符。
ACcode:
#include <iostream> // 基本入出力ストリーム
#include <algorithm> // 一般的なアルゴリズム(ソート、ルックアップ、やり直し、二分ルックアップなど)
#include <vector> // 動的配列(スペースが足りないと自動的に拡張されます)
#include <queue> // スタック(先に入って先に出ます)
#include <stack> // スタック(先に入ってから出ます)
#include <set> // 集合(反復しない順序)です
#include <map> // キー値対コンテナ(マッピング)
#include <list> // 両方向リスト
#include <math.h> // すうがくかんすう
#include <functional> // 通用的函数绑定和调用机制一般的なバインディングと呼び出しの仕組み
#define endl '\n'
#define pii pair<int, int>
#define pdd pair<double, double>
#define fi first
#define se second
#define pb push_back
#define eb emplace_back
using namespace std;
const int inf = 1e9 + 7;
const int mod = 998244353;
const int N = 2e5 + 10, M = N << 1;
void solve(){
// 竞赛程序
cin >> s;
for (int i = 0; i < (int)s.size(); i++) {
if (s[i] == '|') flag = !flag;
if (!flag && s[i] != '|') cout << s[i];
}
}
signed main(){
ios::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
int t = 1;
// cin >> t; // 非多组测试数据请注释该行
while(t--) solve();
return 0;
}
好了,今天的分享就到这里