I题链接点击打开链接
题目意思是让你找出人的个数,每个人的形状告诉你了!并且在照片中,每个形状可以部分参与,,那么怎么正确的找出所有的人,,我的做法是从左向右,从上到下,,进行扫描,碰到人身体的某个部分的时候,将这个人身上的合法区域全变为'.',并且ans++,就相当于统计了一个人,,扫描过后,,所有的人也就全部统计出来了!!
#include <cstdio> #include <cstring> #include <string> #include <iostream> #include <algorithm> #include <stack> #include <queue> #include <map> #include <vector> #include <cmath> #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 using namespace std; const int maxn = 55555; int sum[maxn << 2]; struct node { int button, label; }node1[10]; int main(void) { //freopen("in.txt", "r", stdin); int T; scanf("%d", &T); while (T--) //枚举暴力每一种情况 { int d, b[5]; int ans_p, ans_v; int i, j; for (i = 1; i <= 5; i++) { scanf("%d", &d); for (j = 1; j <= 4; j++) scanf("%d", &b[j]); //scanf("%d%d%d%d%d",&d,&b1,&b2,&b3,&b4); if (i == 1) { if (d == 1) { node1[1].button = 2; node1[1].label = b[2]; printf("%d %d\n", 2, b[2]); } else if (d == 2) { node1[1].button = 2; node1[1].label = b[2]; printf("%d %d\n", 2, b[2]); } else if (d == 3) { node1[1].button = 3; //记录值和按钮位置 node1[1].label = b[3]; printf("%d %d\n", 3, b[3]); } else if (d == 4) { node1[1].button = 4; node1[1].label = b[4]; printf("%d %d\n", 4, b[4]); } } else if (i == 2) { if (d == 1) { node1[2].label = 4; int w; for (w = 1; w <= 4; w++) { if (b[w] == 4) break; } node1[2].button = w; printf("%d %d\n", w, 4); } else if (d == 2) { node1[2].button = node1[1].button; node1[2].label = b[node1[1].button]; printf("%d %d\n", node1[2].button, node1[2].label); } else if (d == 3) { node1[2].label = b[1]; node1[2].button = 1; printf("%d %d\n", 1, b[1]); } else if (d == 4) { //node1[2].label = node1[1].label; node1[2].button = node1[1].button; node1[2].label = b[node1[2].button]; printf("%d %d\n", node1[2].button, node1[2].label); } } else if (i == 3) { if (d == 1) { node1[3].label = node1[2].label; //node1[3].button = node1[2].button; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[3].label) break; } node1[3].button = w; printf("%d %d\n", node1[3].button, node1[3].label); } else if (d == 2) { node1[3].label = node1[1].label; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[3].label) break; } node1[3].button = w; printf("%d %d\n", node1[3].button, node1[3].label); } else if (d == 3) { node1[3].button = 3; node1[3].label = b[3]; printf("%d %d\n", node1[3].button, node1[3].label); } else if (d == 4) { node1[3].label = 4; int w; for (w = 1; w <= 4; w++) { if (b[w] == 4) break; } node1[3].button = w; printf("%d %d\n", w, 4); } } else if (i == 4) { if (d == 1) { node1[4].button = node1[1].button; node1[4].label = b[node1[4].button]; } else if (d == 2) { node1[4].button = 1; node1[4].label = b[1]; } else if (d == 3) { node1[4].button = node1[2].button; node1[4].label = b[node1[4].button]; } else if (d == 4) { node1[4].button = node1[2].button; node1[4].label = b[node1[4].button]; } printf("%d %d\n", node1[4].button, node1[4].label); } else { if (d == 1) { //node1[5].button = node1[1].button; node1[5].label = node1[1].label; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[5].label) break; } node1[5].button = w; } else if (d == 2) { //node1[5].button = node1[2].button; node1[5].label = node1[2].label; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[5].label) break; } node1[5].button = w; } else if (d == 3) { //node1[5].button = node1[4].button; node1[5].label = node1[4].label; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[5].label) break; } node1[5].button = w; } else if (d == 4) { node1[5].label = node1[3].label; int w; for (w = 1; w <= 4; w++) { if (b[w] == node1[5].label) break; } node1[5].button = w; } printf("%d %d\n", node1[5].button, node1[5].label); } } } return 0; }