2020 百度之星 初赛二 1004 Car

Problem - 6778
题目:给你几个车牌,然后根据车牌尾号在一周的工作日内限行,一种尾号一周只能限一次,问你一天最多有多少辆车。

思路:一开始以为是贪心和最小生成树,写到后面wa了,到后面发现是暴力dfs,吐血 1e5的数据,暴力能过

原代码,不知道问题在哪:

#include
using namespace std;

int turnNum(char a) {
	return a-'0';
}

int main() {
	int o;
	scanf("%d",&o);
	while(o--) {
		int n;
		scanf("%d",&n);
		getchar();
		char a[10];
		int ans[12];
		memset(ans,0,sizeof(ans));
		priority_queue<int> q;
		for(int i=0; i<n; i++) {
			gets(a);
			ans[turnNum(a[4])]--;
		}
		int k = 0;
		for(int i=0; i<10; i++) {
			if(ans[i]!=0) {
				q.push(ans[i]);
//				printf(" %d ",ans[i]);
				k++;
			}
		}
//		printf("K:%d--|%d|--\n",k,q.top());
		if(k<5) {
			printf("%d\n",n);
		} else {
			while (!q.empty()&&k>5) {
//				printf("--|%d||\n",k); 
				int fis = q.top();
				q.pop();
				if (!q.empty()) {
					int sec = q.top();
					q.pop();
					q.push(fis+sec);
				}
				k--;
//				printf("-|%d||\n",k);
			}
			int sum = q.top();
			printf("%d\n",n+sum);
		}

	}
	return 0;
}

然后的暴力的代码(看别人能过,但是发现还是TLE,需要二分) :

#include 
using namespace std;
typedef long long LL;
template <typename T>
void read(T &x)
{
    int s = 0, c = getchar();
    x = 0;
    while (isspace(c))
        c = getchar();
    if (c == 45)
        s = 1, c = getchar();
    while (isdigit(c))
        x = (x << 3) + (x << 1) + (c ^ 48), c = getchar();
    if (s)
        x = -x;
}

template <typename T>
void write(T x, char c = ' ')
{
    int b[40], l = 0;
    if (x < 0)
        putchar(45), x = -x;
    while (x > 0)
        b[l++] = x % 10, x /= 10;
    if (!l)
        putchar(48);
    while (l)
        putchar(b[--l] | 48);
    putchar(c);
}

void DFS(int tot, int cnt[], int sum[], int &ans, int n)
{
    if (tot == 10)
    {
        int qwq = 1e9;
        for (int i = 0; i < 5; ++i)
        {
            qwq = min(qwq, sum[i]);
        }
        ans = min(ans, n - qwq);
        return;
    }
    for (int i = 0; i < 5; ++i)
    {
        sum[i] += cnt[tot];
        DFS(tot + 1, cnt, sum, ans, n);
        sum[i] -= cnt[tot];
    }
}

int main(void)
{
    int kase;
    read(kase);
    for (int ii = 1; ii <= kase; ii++)
    {
        int n;
        read(n);
        int cnt[10] = {0};
        for (int x, i = 1; i <= n; ++i)
        {
            read(x);
            cnt[x % 10]++;
        }
        int ans = 1e9 + 7;
        int sum[5] = {0};
        DFS(0, cnt, sum, ans, n);
        write(ans, '\n');
    }
    return 0;
}

你可能感兴趣的:(C++,二分法,百度之星,C++)