답안 #437066

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
437066 2021-06-25T18:11:19 Z DunderMifflin DNA 돌연변이 (IOI21_dna) C++17
컴파일 오류
0 ms 0 KB
#include "dna.h"
using namespace std;

const int N = 123456;

int pref[3][3][N];
int asum[3][N];
int bsum[3][N];
map<char, int> f;

void init(std::string a, std::string b) {
	f['A'] = 0; f['C'] = 1; f['T'] = 2;
	int n = (int) a.size();
	for (int i = 0; i < n; i++) {
		for (int k = 0; k < 3; k++) {
			asum[k][i] = 0;
			bsum[k][i] = 0;
			for (int l = 0; l < 3; l++) {
				pref[k][l][i] = 0;
			}
		}
	}
	for (int i = 0; i < n; i++) {
		if (i > 0) {
			for (int k = 0; k < 3; k++) {
				for (int l = 0; l < 3; l++) {
					pref[k][l][i] = pref[k][l][i - 1];
				}
				asum[k][i] = asum[k][i - 1];
				bsum[k][i] = bsum[k][i - 1];
			}
		}
		for (int k = 0; k < 3; k++) {
			for (int l = 0; l < 3; l++) {
				pref[k][l][i] += (f[a[i]] == k && f[b[i]] == l);
			}
			asum[k][i] += (f[a[i]] == k);
			bsum[k][i] += (f[b[i]] == k);
		}
	}
}

int get_distance(int x, int y) {
	for (int t = 0; t < 3; t++) {
		int res_a = asum[t][y];
		if (x > 0) {
			res_a -= asum[t][x - 1];
		}
		int res_b = bsum[t][y];
		if (x > 0) {
			res_b -= bsum[t][x - 1];
		}
		if (res_a != res_b) return -1;
	}
	int ans = 0;
	int surplus = 0;
	for (int k = 0; k < 3; k++) {
		for (int l = k + 1; l < 3; l++) {
			int k_to_l = pref[k][l][y];
			if (x > 0) {
				k_to_l -= pref[k][l][x - 1];
			}

			int l_to_k = pref[l][k][y];
			if (x > 0) {
				l_to_k -= pref[l][k][x - 1];
			}

			ans += min(k_to_l, l_to_k);
			surplus += max(k_to_l, l_to_k) - min(k_to_l, l_to_k);
		}
	}
	return ans + ((2 * surplus) / 3);
}

Compilation message

dna.cpp:9:1: error: 'map' does not name a type
    9 | map<char, int> f;
      | ^~~
dna.cpp: In function 'void init(std::string, std::string)':
dna.cpp:12:2: error: 'f' was not declared in this scope
   12 |  f['A'] = 0; f['C'] = 1; f['T'] = 2;
      |  ^