Skip to content

Latest commit

 

History

History
85 lines (68 loc) · 2.77 KB

template.md

File metadata and controls

85 lines (68 loc) · 2.77 KB

As an experienced coder, your task is to provide an accurate and optimal solution to a coding problem in C++. To accomplish this, follow these steps:

Solution Design:

Step 1: "Proposed Solution". Then brainstorm and design the solution. Be aware of the time complexity of the solution. The solution should be as optimal as possible.

Here are some guidelines to help you analyze the problem:

  • Summarize the problem
  • The key insight to solve the problem (Follow the HINT if it presents)
  • A step-by-step plan for the solution

Step 2: "Implementation". Then implement the proposed solution in C++ (std=c++20). In this step, only include the code in a quote block. Don't add any explanations.

Here are some rules to follow when coding:

  • Include <bits/stdc++.h> and using std namespace to use the C++ standard library.
  • Use using i64 = long long; for simplifying the use of long long types.
  • Include a debugging function dbg that behaves like printf, but only outputs when the DBG macro is defined and outputs to stderr. The DBG macro should not be defined within the code.
    #ifdef DBG
    #include "debug.h"
    #else
    #define dbg(...)
    #define dbg_export(...)
    #endif
  • If each test consists of multiple test cases, the solve function should be called multiple times, each time for a different test case; each call to the solve function returns the result for one test case. If there is only one test case, ignore this rule.
  • Follow the indexing conventions used by the problem statement. If the problem uses one-indexing (e.g., a_1, a_2, ... a_n), use one-indexing in the code. If the problem uses zero-indexing, use zero-indexing in the code.
  • If the answer needs to take modulo, define the constant MOD. Otherwise, ignore this rule.

Here is a reference implementation that conforms to the above rules:

Problem Summary: ...

Key Insight: ...

Step-by-Step Plan:

  1. ... a. ... b. ...
  2. ...
#include <bits/stdc++.h>
using namespace std;
using i64 = long long;

#ifdef DBG
#include "debug.h"
#else
#define dbg(...)
#define dbg_export(...)
#endif

void solve()
{
    int n;
    cin >> n;
    vector<int> a(n + 1);
    for (int i = 1; i <= n; i++)
        cin >> a[i];

    // Solve the problem here.

    cout << ans.size() << endl;
    for (int i = 1; i <= n; i++)
        cout << ans[i] << " \n"[i==n];
}

int main()
{
#ifndef DBG
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
#endif
    int t;
    cin >> t;
    while (t--) {
        solve();
    }

    return 0;
}

Below content the problem description. At the end of the problem description. You can find a "HINT" section that tells you how to solve the problem. The hint may be messy because it is written in a hurry. Try your best to guess the meaning. Please strictly follow the HINT!!!