Codeforces Round #279 (Div. 2) a

/**
 * @brief Codeforces Round #279 (Div. 2) a
 * @file a.cpp
 * @author 面碼
 * @created 2014/11/26 17:05
 * @edited  2014/11/26 17:05
 * @type 
 *
 */
#include <cstdio>
#include <stack>
#include <cstring>

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))

typedef stack<int> bbq;

#define MAXT 3

bbq a[MAXT + 1];
int type;
int n;
int cnt;

int main(void){
#ifdef DEBUG
    freopen("./in",  "r", stdin);
    freopen("./out", "w", stdout);
#endif
    scanf("%d", &n);
    for(int i = 1; i <= n; i++){
            scanf("%d", &type);
            a[type].push(i);
    }
    cnt = a[1].size();
    cnt = min(cnt, a[2].size());
    cnt = min(cnt, a[3].size());
    
    printf("%d\n", cnt);

    while( !a[1].empty() && !a[2].empty() && !a[3].empty()){
            printf("%d %d %d\n", a[1].top(), a[2].top(), a[3].top());
            a[1].pop();
            a[2].pop();
            a[3].pop();
    }
    return 0;
}
相關文章
相關標籤/搜索