137162025-01-08 13:48:56Leventusz09Táblajátékcpp17Hibás válasz 1/501ms512 KiB
#include <iostream>
#include <bitset>
#include <string>

using namespace std;

void add(bitset<501> &bs, bool n = false) {
	int c = 0;
	if(!n)
		while(true){
			if (bs[c]) {
				bs.reset(c);
				c++;
			}else{
				bs.set(c);
				break;
			}
		}
	else
		while (true){
			if (bs[c]) {
				bs.reset(c);
				break;
			}
			else {
				bs.set(c);
				c++;
			}
		}
}

int main() {
	int K;
	cin >> K;

	int lv = 0;
	bitset<501> p;

	for (int i = 0, s; i < K; i++) {
		cin >> s;
		switch (s){
		case 0:	lv++;	p<<=1;	break;
		case 1:	lv++;	p<<= 1;	p.set(0);  break;
		case 2:	lv--;	p>>= 1;	break;
		case 3: add(p, 1);	break;
		case 4:	add(p);	break;
		}
	}
	for (int i = 500; i >= 0; i--) {
		if (p[i]) {
			cout << p.to_string().substr(500 - i) << "\n";
			return 0;
		}
	}
	cout << 0 << "\n";
	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base1/50
1Hibás válasz0/01ms512 KiB
2Hibás válasz0/01ms316 KiB
3Hibás válasz0/31ms512 KiB
4Hibás válasz0/31ms316 KiB
5Hibás válasz0/31ms316 KiB
6Hibás válasz0/31ms316 KiB
7Hibás válasz0/31ms508 KiB
8Hibás válasz0/31ms316 KiB
9Hibás válasz0/31ms500 KiB
10Hibás válasz0/31ms316 KiB
11Hibás válasz0/31ms316 KiB
12Hibás válasz0/31ms316 KiB
13Hibás válasz0/41ms328 KiB
14Hibás válasz0/41ms316 KiB
15Hibás válasz0/41ms316 KiB
16Hibás válasz0/41ms316 KiB
17Részben helyes1/41ms316 KiB