/ SeriousOJ /

Record Detail

Wrong Answer


  
# Status Time Cost Memory Cost
#1 Wrong Answer 1ms 540.0 KiB
#2 Wrong Answer 17ms 560.0 KiB

Code

#include <iostream>
#include <string>
#include <vector>
using namespace std;

int maxConsecutiveOnes(string s) {
    int maxCount = 0, currentCount = 0;
    vector<int> counts; 
    
    for (char c : s) {
        if (c == '1') {
            currentCount++;
        } else {
            if (currentCount > 0) {
                counts.push_back(currentCount);
                currentCount = 0;
            }
        }
    }
    if (currentCount > 0) {
        counts.push_back(currentCount); 
    }

    
    if (counts.empty()) return 0;

 
    int totalOnes = 0;
    for (int count : counts) {
        totalOnes += count; 
    }

    
    int maxConsecutive = 0;

    for (size_t i = 0; i < counts.size(); ++i) {
        maxConsecutive = max(maxConsecutive, counts[i]);
       
        if (i < counts.size() - 1) {
            maxConsecutive = max(maxConsecutive, counts[i] + counts[i + 1]);
        }
    }

    
    int numberOfFlips = (s.length() - totalOnes);
    
    if (numberOfFlips >= 1) {
        maxConsecutive = max(maxConsecutive, totalOnes + numberOfFlips);
    }

    return maxConsecutive;
}

int main() {
    int T;
    cin >> T; 
    while (T--) {
        int N;
        cin >> N; 
        string S;
        cin >> S; 

        
        int result = maxConsecutiveOnes(S);
        cout << result << endl; 
    }
    return 0;
}

Information

Submit By
Type
Submission
Problem
P1113 Fliping Game
Contest
Brain Booster #7
Language
C++11 (G++ 13.2.0)
Submit At
2024-11-05 15:02:27
Judged At
2024-11-05 15:02:27
Judged By
Score
0
Total Time
17ms
Peak Memory
560.0 KiB