QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#498972#6635. Strange Keyboardsalvator_nosterTL 285ms149536kbC++205.1kb2024-07-30 22:25:222024-07-30 22:25:26

Judging History

你现在查看的是最新测评结果

  • [2024-07-30 22:25:26]
  • 评测
  • 测评结果:TL
  • 用时:285ms
  • 内存:149536kb
  • [2024-07-30 22:25:22]
  • 提交

answer

#include <bits/stdc++.h>

template <class T>
inline int qlog(T a) {
    if (!a) return 0;
	double x = a;
	return ((*(long long*) & x) >> 52 & 2047) - 1023;
}

#define cin Mizuhashi
#define cout Parsee
#define endl '\n'

class Reader{
	private:
	    static const int BUF_SIZE = 1 << 22;
	    char BUF_R[BUF_SIZE], *csy1, *csy2;
	    #ifndef _LOCAL_RUNNING
		    #define GC (csy1 == csy2 && (csy2 = (csy1 = BUF_R) + fread(BUF_R, 1, BUF_SIZE, stdin), csy1 == csy2) ? EOF : *csy1 ++)
		#else
		    char cur;
		    #define GC (cur = getchar())
		#endif
	    #define IL inline
		
    public:
        IL bool eof() {
            #ifndef _LOCAL_RUNNING
                return csy1 == csy2 && (csy2 = (csy1 = BUF_R) + fread(BUF_R, 1, BUF_SIZE, stdin), csy1 == csy2);
            #else
                return cur == EOF;
            #endif
        }
        template <class Ty>
        IL Reader& operator >> (Ty &t) {
            int u = 0;
            char c = GC;
	    	for (t = 0; c < 48 || c > 57; c = GC)
                if (c == EOF) break;
                else if (c == '-') u = 1;
	    	for ( ; c > 47 && c < 58; c = GC) t = (t << 1) + (t << 3) + (c ^ 48);
	    	t = u ? -t : t; return *this;
        }
    	IL Reader& operator >> (double &t) {
            int tmp, u = 0; char c = GC;
	    	for (tmp = 0; c < 48 || c > 57; c = GC)
                if (c == EOF) break;
                else if (c == '-') u = 1;
	    	for ( ; c > 47 && c < 58; c = GC) tmp = (tmp << 1) + (tmp << 3) + (c ^ 48);
	    	t = (tmp = u ? -tmp : tmp);
    	    if (c == '.') {
    	        double x = 1;
    	        for (c = GC; c > 47 && c < 58; c = GC) t += (x /= 10) * (c ^ 48);
    	    }
    	    return *this;
    	}
    	IL Reader& operator >> (char *s) {
			char c = GC;
			for (*s = 0; c < 33; c = GC) if (c == EOF) return *this;
			for ( ; c > 32; c = GC) *s ++ = c;
			*s = 0; return *this;
		}
        IL Reader& operator >> (char &c) {
			for (c = GC; c < 33; c = GC) if (c == EOF) return *this;
            return *this;
        }
}cin;
class Writer{
	private:
	    static const int BUF_SIZE = 1 << 22;
	    char BUF_W[BUF_SIZE], *csy;
	    #define IL inline
		inline void WC(const char c) {
			if (csy - BUF_W == BUF_SIZE) fwrite(BUF_W, 1, BUF_SIZE, stdout), csy = BUF_W;
			*csy ++ = c;
		}
	
	public:
		Writer() : csy(BUF_W) {}
		~ Writer() {fwrite(BUF_W, 1, csy - BUF_W, stdout);}
		IL void flush() {fwrite(BUF_W, 1, csy - BUF_W, stdout); csy = BUF_W;}
		template <class Ty>
		IL Writer& operator << (Ty x) {
		    static int sta[32], top;
			if (x < 0) {
				WC('-');
                do sta[top ++] = - (x % 10); while (x /= 10);
			}else do sta[top ++] = x % 10; while (x /= 10);
			while (top) WC(sta[-- top] ^ 48);
			return *this;
		}
		IL Writer& operator << (const char &c) {WC(c); return *this;}
		IL Writer& operator << (const char *s) {while (*s) WC(*s ++); return *this;}
		IL Writer& operator << (char *s) {while (*s) WC(*s ++); return *this;}
}cout;

using namespace std;

typedef long long ll;
typedef pair <int, int> pii;
typedef unsigned int u32;
typedef unsigned long long u64;

const int MAX_N = 5000 + 5;
const int MAX_M = 1000000 + 5;
const int INF32 = 0x3f3f3f3f;
const ll INF64 = 1e18;
const int P = 998244353;

int N, K, minc[MAX_N];
string s[MAX_M];
char t[MAX_N], vis[MAX_N];
ll dis[MAX_N], f[MAX_N];
struct Node{
	int son[26];
	ll val;
	
	Node () {
		val = INF64;
		memset(son, 0, sizeof son);
	}
	
	void clear() {
		val = INF64;
		memset(son, 0, sizeof son);
	}
}node[MAX_M];
int tot;

void ins(const string &s) {
	int n = s.length(), u = 0;
	for (int i = 0; i < n; i ++) {
		ll cost = dis[K - (n - i - 1) % K] + (n - i + K - 2) / K + 1;
		
		int &v = node[u].son[s[i] - 'a']; v = v ? v : ++ tot;
		node[v].val = min(node[v].val, cost); u = v;
	}
}

void query(int p, int n) {
	int u = 0;
	for (int i = p + 1; i <= n; i ++) {
		u = node[u].son[t[i] - 'a'];
		if (!u) return ;
		f[i] = min(f[i], f[p] + node[u].val);
	}
}

void solve() {
	cin >> N >> K;
	for (int i = 1; i < K; i ++) {
		minc[i] = INF32;
		vis[i] = 0;
		dis[i] = INF32;
	}
	for (int i = 1; i <= N; i ++) {
		static char str[MAX_M];
		cin >> str; s[i] = str;
		int tmp = s[i].length() % K;
		minc[tmp] = min(minc[tmp], (int)s[i].length() / K + 1);
	}
	cin >> t + 1;
	vis[0] = 0;
	for (int round = 0; round < K; round ++) {
		int p = -1;
		for (int i = 0; i < K; i ++) {
			if (!vis[i] && (p < 0 || dis[i] < dis[p])) p = i;
		}
		assert(p >= 0);
		vis[p] = 1;
		for (int i = 1; p + i < K; i ++) {
			dis[p + i] = min(dis[p + i], dis[p] + minc[i]);
		}
		for (int i = K - p; i < K; i ++) {
			dis[p + i - K] = min(dis[p + i - K], dis[p] + minc[i] + 1);
		}
	}
	dis[K] = 0;
	for (int i = 0; i <= tot; i ++) node[i].clear();
	tot = 0;
	for (int i = 1; i <= N; i ++) ins(s[i]);
	int M = strlen(t + 1);
	
	for (int i = 1; i <= M; i ++) f[i] = INF64;
	for (int i = 0; i < M; i ++) query(i, M);
	
	if (f[M] < INF64) cout << f[M] << endl;
	else cout << -1 << endl;
}

int main() {
    int T = 1;
    cin >> T;
    while (T --) solve();
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 19ms
memory: 147072kb

input:

2
2 3
defgh
abc
abcde
1 1
a
b

output:

3
-1

result:

ok 2 number(s): "3 -1"

Test #2:

score: 0
Accepted
time: 50ms
memory: 149460kb

input:

1
1413 4867
yumnkkghwtqnhpmmsbfwypcwudihegsvtdaykueuqozagpgdnhbwzoqrqswyctzonwmjdjmmpyzbyihhpyznmqltcuckqmcybbdafoexqztxhzlfjowznisnxtgoiqjztogldyegajmegalqgawrzotuntocmsagvkzdnwhmaewuxiuhvintpzwyrkgapnmegpveyuuorrfvrfakjyetfaoqtvwghlslsvmahrkvzkwpaviufknrpuapicqdnn
yumnkkghwtqnhpmmsbfwypcwudihegsvt...

output:

10

result:

ok 1 number(s): "10"

Test #3:

score: 0
Accepted
time: 285ms
memory: 149536kb

input:

10
446 4905
afigcjhcgagabbiccehjcjajigghgbjjadccicghggijjdfeciaccgheedjdhgfjdfdbgidbbdjaiehhceeehchhabhaideggjbjajgfgicfdggahhbjgdebccbgbiedhehaebdccdfdffaacjcfbgjeegbahhbgcdjigijajheidchbddicehhhjbeiaajgedhdcjiefdgdbjjfaegheeidieheecaicciaajbabiidcecefgiicccdidegeica
afigcjhcgagabbiccehjcjajigghgbj...

output:

3
2
2
11
6
5
1
1
1
1

result:

ok 10 numbers

Test #4:

score: -100
Time Limit Exceeded

input:

100
140 4879
baabaababbababbaabababaaababbbabbbbbbabbababbbabbbbabbbbbbaabbbbbbbbabaabbbaabaabbbaabbabaabaabbbabbbababbbaabbabaaaaabbaaabbbabb
baa
baabaababbababbaabababaaababbbabbbbbbabbab
baabaababbababbaabababaaabab
baabaababbababbaabababaaababbbabbb
baabaababbababbaabababaaababbbabbbbbbabbababbb...

output:


result: