| Task: | Niitty |
| Sender: | Pikaksi |
| Submission time: | 2024-11-06 18:28:05 +0200 |
| Language: | C++ (C++20) |
| Status: | READY |
| Result: | 0 |
| group | verdict | score |
|---|---|---|
| #1 | WRONG ANSWER | 0 |
| #2 | WRONG ANSWER | 0 |
| #3 | WRONG ANSWER | 0 |
| #4 | WRONG ANSWER | 0 |
| #5 | WRONG ANSWER | 0 |
| #6 | WRONG ANSWER | 0 |
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.19 s | 1, 2, 3, 4, 5, 6 | details |
| #2 | ACCEPTED | 0.18 s | 1, 2, 3, 4, 5, 6 | details |
| #3 | WRONG ANSWER | 0.19 s | 1, 2, 3, 4, 5, 6 | details |
| #4 | ACCEPTED | 0.18 s | 1, 2, 3, 4, 5, 6 | details |
| #5 | WRONG ANSWER | 0.18 s | 1, 2, 3, 4, 5, 6 | details |
| #6 | ACCEPTED | 0.19 s | 2, 3, 4, 5, 6 | details |
| #7 | ACCEPTED | 0.18 s | 2, 3, 4, 5, 6 | details |
| #8 | WRONG ANSWER | 0.18 s | 2, 3, 4, 5, 6 | details |
| #9 | ACCEPTED | 0.18 s | 2, 3, 4, 5, 6 | details |
| #10 | ACCEPTED | 0.19 s | 3, 4, 5, 6 | details |
| #11 | ACCEPTED | 0.19 s | 3, 4, 5, 6 | details |
| #12 | WRONG ANSWER | 0.19 s | 3, 4, 5, 6 | details |
| #13 | ACCEPTED | 0.19 s | 3, 4, 5, 6 | details |
| #14 | ACCEPTED | 0.22 s | 4, 5, 6 | details |
| #15 | ACCEPTED | 0.22 s | 4, 5, 6 | details |
| #16 | WRONG ANSWER | 0.22 s | 4, 5, 6 | details |
| #17 | ACCEPTED | 0.22 s | 4, 5, 6 | details |
| #18 | ACCEPTED | 0.70 s | 5, 6 | details |
| #19 | ACCEPTED | 0.69 s | 5, 6 | details |
| #20 | WRONG ANSWER | 0.69 s | 5, 6 | details |
| #21 | ACCEPTED | 0.69 s | 5, 6 | details |
| #22 | TIME LIMIT EXCEEDED | -- | 6 | details |
| #23 | TIME LIMIT EXCEEDED | -- | 6 | details |
| #24 | TIME LIMIT EXCEEDED | -- | 6 | details |
| #25 | TIME LIMIT EXCEEDED | -- | 6 | details |
Compiler report
input/code.cpp: In function 'void printRows(int, int*)':
input/code.cpp:15:13: warning: variable 'prewOrTowerSpace' set but not used [-Wunused-but-set-variable]
15 | int prewOrTowerSpace = rowSpace;
| ^~~~~~~~~~~~~~~~
input/code.cpp: In function 'int main()':
input/code.cpp:138:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
138 | for (int k = 0; k < row.size(); k++) {
| ~~^~~~~~~~~~~~Code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int FIELD_SIZE = 500;
const int FIELD_ROW_OFFSET = FIELD_SIZE * (FIELD_SIZE + 1) / 2;
int containedFlowers = 0;
void printRows(int n, int* field)
{
for (int y = 0; y < n; y++) {
int rowSpace = y * FIELD_ROW_OFFSET;
int prewOrTowerSpace = rowSpace;
int offsetTriangle = 0;
cout << "row:\n";
for (int x = 0; x < n; x++) {
int orTowerSpace = rowSpace + offsetTriangle;
for (int len = 0; len < n - x; len++) {
cout << field[orTowerSpace + len] << " at " << (orTowerSpace + len) << " ";
}
prewOrTowerSpace = orTowerSpace;
offsetTriangle += n - x;
cout << "\n";
}
}
}
ll bruteForce(int n, int* field)
{
ll ans = 0;
for (int y = 0; y < n; y++) {
int rowSpace = y * FIELD_ROW_OFFSET;
int prewOrTowerSpace = rowSpace;
int offsetTriangle = n;
for (int x = 1; x < n; x++) { // loop or tower spaces
int orTowerSpace = rowSpace + offsetTriangle;
for (int len = 0; len < n - x; len++) { // loop over or tower
int bitMaskCombination = field[prewOrTowerSpace + len] | field[prewOrTowerSpace + len + 1];
field[orTowerSpace + len] = bitMaskCombination;
if (bitMaskCombination == containedFlowers) {
ans += 1;
}
}
prewOrTowerSpace = orTowerSpace;
offsetTriangle += n - x;
}
}
//printRows(n, field);
for (int y = 0; y < n - 1; y++) { // loop rows
int rowSpace = y * FIELD_ROW_OFFSET;
for (int orRowIndex = y + 1; orRowIndex < n; orRowIndex++) { // loop other rows to add to main row
int addRowSpace = orRowIndex * FIELD_ROW_OFFSET;
int offsetTriangle = 0;
for (int x = 0; x < n; x++) { // loop orTowers
int mainOrTowerSpace = rowSpace + offsetTriangle;
int addOrTowerSpace = addRowSpace + offsetTriangle;
for (int len = 0; len < n - x; len++) { // loop orTower bitmasks
field[mainOrTowerSpace + len] |= field[addOrTowerSpace + len];
if (field[mainOrTowerSpace + len] == containedFlowers) {
ans += 1;
}
}
offsetTriangle += n - x;
}
}
}
return ans;
}
void randomTest(int n)
{
for (int i = 0; i < n; i++) {
for (int k = 0; k < n; k++) {
}
}
for (int i = 0; i < 26; i++) {
}
for (int i = 0; i < n; i++) {
for (int k = 0; k < n; k++) {
}
}
}
int main()
{
//vector<string> testField = {"AAAAA", "AAAAA", "AABAA", "AAACA", "AAADA"};
//vector<string> testField = {"BAA", "AAB", "AAA"};
//vector<string> testField = {"Z"};
//vector<string> testField = {"AZ", "ZA"};
//vector<string> testField = {"AAAC", "ABAA", "ABAA", "AAAA"};
//vector<string> testField = {"AAAAA", "AAAAA", "AAAAA", "AAAAA", "AAAAA"};
//vector<string> testField = {"ZAAAA", "AAAAA", "AAAAA", "AAAAA", "AAAAK"};
//vector<string> testField = {"AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA","AAAAAAAAAA",};
//vector<string> testField = {"AUFCHGK","GXAPVWB","NUHYMEA","HSCSNSI","IMBMTJS","TPVRJUF","SIKDVWY"};
int n;
//n = testField.size();
//n = testField.size();
cin >> n;
//auto begin = std::chrono::high_resolution_clock::now();
// n * n(n+1) / 2
int* field = new int[FIELD_SIZE * FIELD_ROW_OFFSET]{0};
//auto end = std::chrono::high_resolution_clock::now();
for (int i = 0; i < n; i++) {
//string row = testField[i];
string row;
cin >> row;
for (int k = 0; k < row.size(); k++) {
int bitMask = 1 << (row[k] - 'A');
field[i * FIELD_ROW_OFFSET + k] = bitMask;
containedFlowers |= bitMask;
}
}
ll ans = bruteForce(n, field);
cout << ans;
/*for (int i = 0; i < n; i++) {
for (int k = 0; k < n; k++) {
cout << field[i * FIELD_ROW_OFFSET + k] << " ";
}
cout << "\n";
}*/
//auto duration = std::chrono::duration_cast<std::chrono::milliseconds>(end-begin).count();
//std::cout << " ms: " << duration << "\n";
}Test details
Test 1
Group: 1, 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 10 TNCTNPNTPC NPPNTNTPTP NTNTTCNTCT NPCPNPPNTT ... |
| correct output |
|---|
| 2035 |
| user output |
|---|
| 2035 |
Test 2
Group: 1, 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 10 NFWQLWNWYS DZOQJVXFPJ CNHXPXMCQD QRTBVNLTQC ... |
| correct output |
|---|
| 9 |
| user output |
|---|
| 9 |
Test 3
Group: 1, 2, 3, 4, 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 10 XXXXXXXXXX XXXXXXXXXX XXXXXXXXXX XXXXXXXXXX ... |
| correct output |
|---|
| 3025 |
| user output |
|---|
| 2925 |
Test 4
Group: 1, 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 10 FFFFFFFFFF FFFFFCFFFF FFFFFFJFFF FFFFFFFFFF ... |
| correct output |
|---|
| 12 |
| user output |
|---|
| 12 |
Test 5
Group: 1, 2, 3, 4, 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 1 X |
| correct output |
|---|
| 1 |
| user output |
|---|
| 0 |
Test 6
Group: 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 20 BBCBUBOUOBBCUUBBCOUO BOUCOOCUBCOOOCOBOCUO UCCUUUOBCOCBCBUBUCOO BUOBUCUCUOOBCOOUBUOO ... |
| correct output |
|---|
| 38724 |
| user output |
|---|
| 38724 |
Test 7
Group: 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 20 CBGLSHGZHYZDWBNDBJUG SMUXOJQYPXZDTMJUIWOJ XIDSTNBGHKRKOVUVMINB MTQGCFRUHQKALXRNCQGS ... |
| correct output |
|---|
| 8334 |
| user output |
|---|
| 8334 |
Test 8
Group: 2, 3, 4, 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 20 KKKKKKKKKKKKKKKKKKKK KKKKKKKKKKKKKKKKKKKK KKKKKKKKKKKKKKKKKKKK KKKKKKKKKKKKKKKKKKKK ... |
| correct output |
|---|
| 44100 |
| user output |
|---|
| 43700 |
Test 9
Group: 2, 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 20 AAAAAAAAXAAAAAAAAAAA AAAWAAAAAAAAAAAAAOAA AAAAAAAAAAAAAAAAAPAA AAAAAAAAKAAAAAAAAAAZ ... |
| correct output |
|---|
| 18 |
| user output |
|---|
| 18 |
Test 10
Group: 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 50 GRGREEEGREGXRXXEGXXREXGRRRGRRR... |
| correct output |
|---|
| 1584665 |
| user output |
|---|
| 1584665 |
Test 11
Group: 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 50 AITIISJUHCCRZNKSDCNQKYSQRINFWJ... |
| correct output |
|---|
| 1077746 |
| user output |
|---|
| 1077746 |
Test 12
Group: 3, 4, 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 50 OOOOOOOOOOOOOOOOOOOOOOOOOOOOOO... |
| correct output |
|---|
| 1625625 |
| user output |
|---|
| 1623125 |
Test 13
Group: 3, 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 50 FFFFFFFFFFFFFFFFFFFFFFFFFFFFFF... |
| correct output |
|---|
| 1680 |
| user output |
|---|
| 1680 |
Test 14
Group: 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 100 NNCMDCDDCCNNNDNCMMNCDCDCCDCDNM... |
| correct output |
|---|
| 25325366 |
| user output |
|---|
| 25325366 |
Test 15
Group: 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 100 LIMQQIHASECROEVILNVULGWZJPPKOG... |
| correct output |
|---|
| 22342463 |
| user output |
|---|
| 22342463 |
Test 16
Group: 4, 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 100 TTTTTTTTTTTTTTTTTTTTTTTTTTTTTT... |
| correct output |
|---|
| 25502500 |
| user output |
|---|
| 25492500 |
Test 17
Group: 4, 5, 6
Verdict: ACCEPTED
| input |
|---|
| 100 QXQQQQQQQQQQQQQQQQQQQQQQQQQQQQ... |
| correct output |
|---|
| 25650 |
| user output |
|---|
| 25650 |
Test 18
Group: 5, 6
Verdict: ACCEPTED
| input |
|---|
| 200 NAANANMMKNKKAKMKMAKNKMNKMMNNAA... |
| correct output |
|---|
| 403292767 |
| user output |
|---|
| 403292767 |
Test 19
Group: 5, 6
Verdict: ACCEPTED
| input |
|---|
| 200 OMYWATTLURKQPTKEFMGGYAOONXWVSC... |
| correct output |
|---|
| 388111321 |
| user output |
|---|
| 388111321 |
Test 20
Group: 5, 6
Verdict: WRONG ANSWER
| input |
|---|
| 200 CCCCCCCCCCCCCCCCCCCCCCCCCCCCCC... |
| correct output |
|---|
| 404010000 |
| user output |
|---|
| 403970000 |
Test 21
Group: 5, 6
Verdict: ACCEPTED
| input |
|---|
| 200 LLLLLLLLLLLLLLLLLHLLLLLLLLLLLL... |
| correct output |
|---|
| 14159445 |
| user output |
|---|
| 14159445 |
Test 22
Group: 6
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 500 VVHWVUHVHUWWWVUUUWVUUHUUWHWUVW... |
| correct output |
|---|
| 15683003812 |
| user output |
|---|
| (empty) |
Test 23
Group: 6
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 500 OIMZGEQSBMBDSDXSWRFNKSGFEBBTJE... |
| correct output |
|---|
| 15575906951 |
| user output |
|---|
| (empty) |
Test 24
Group: 6
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 500 IIIIIIIIIIIIIIIIIIIIIIIIIIIIII... |
| correct output |
|---|
| 15687562500 |
| user output |
|---|
| (empty) |
Test 25
Group: 6
Verdict: TIME LIMIT EXCEEDED
| input |
|---|
| 500 WWWWWWWWWWWWWWWWWWWWWWWWWWWWWW... |
| correct output |
|---|
| 3058970930 |
| user output |
|---|
| (empty) |
