暂无描述

Marcelo Fornet 9edab89ac5 Add support for competitive-companion 6 年之前
.vscode 04fcad8f30 Start vscode extension 6 年之前
doc 9a75f41076 Language + Doc + KeyBinding 6 年之前
images 77da2930e2 change logo name 6 年之前
notes 9edab89ac5 Add support for competitive-companion 6 年之前
scripts dec9019190 0.1.8 6 年之前
src 9edab89ac5 Add support for competitive-companion 6 年之前
types e083ddc52a Parsing codeforces 6 年之前
.gitattributes 04fcad8f30 Start vscode extension 6 年之前
.gitignore b0cf1df377 Fix bugs about upgrade arena 6 年之前
.vscodeignore 04fcad8f30 Start vscode extension 6 年之前
CHANGELOG.md 17e92dd0bb 0.1.6 6 年之前
LICENSE 2b08049032 add license and repository 6 年之前
README.md 9edab89ac5 Add support for competitive-companion 6 年之前
package-lock.json 9edab89ac5 Add support for competitive-companion 6 年之前
package.json 9edab89ac5 Add support for competitive-companion 6 年之前
todo.md 9edab89ac5 Add support for competitive-companion 6 年之前
tsconfig.json e083ddc52a Parsing codeforces 6 年之前
tslint.json 04fcad8f30 Start vscode extension 6 年之前

README.md

ACMX

acmX is tool that empower contestants to solve competitive programming problems easily.

Features

  • Contest/Problem parsing. Current sites supported:
  • Running solution against testcases automatically
  • Add custom testcases easily
  • Smart veredict reporting (OK, WA, RTE, TLE, CE)
  • Stressing solution against brute using a generator (Useful to find corner cases)
  • (WIP) Automatic generator creation from inputs/outputs structure

How am I supposed to use acmX

acmX have been designed to run automatically boilerplate actions I repeat often in competitive programming. Next is the expected pipeline to interact with it. It is important that you setup some configurations before start using the tool.

  • Create a contest calling New Contest or maybe a single problem calling New Problem. Testcases are downloaded automatically :)

  • Start coding awesome solution inside file sol.cpp.

  • After you finish the code call Run and automatically your program will be compiled and run against every testcases. If the solutions seems to be ok, it will be reported otherwise you will see failing testcase in a cool layout. You can always go back to original layout calling View: Code.

  • Add more testcases than provided in statement using Add Test Case, or modify and see existing testcases by calling Open Test Case.

  • If your solution keep failing you can stress it using a generator and a brute solution. Call Upgrage to create both generator (gen.py) and correct (brute.cpp) programs. Right now generator must be written in python. After both codes are ready call Stress and your original code will be tested on random test cases from generator against correct solution.

The environment structure is the following:

    round-525/
        A/
            sol.cpp
            brute.cpp
            gen.py
            attic/...
            testcases/
                1.in
                1.out
                1.real
                ...
        B/...
        C/...
        D/...
        E/...

Certainly acmX can be (and hopefully will be) extended so that it fits everyones pipeline. If acmX almost fit yours, feel free to improve it and make a PR! I'll be happy to hear from you and give you support. If you find any issue report it at github issue tracker.

Getting started

You need to tell acmX which folder are you going to use, to save all the problems and contests. To do that:

  • Open settings (from command palette) or Ctrl+,
  • Go to acmx.configuration.solutionPath
  • Set this value to the path you are going to use for storing contests and problems. (e.g. /path/to/my/solutions)

I encourage everyone to read and change all settings before first use. Anyway, after updating acmx.configuration.solutionPath it should work good for C++ users.

Default template is awful, how can I change it

Create a file with your template. In settings, set acmx.configuration.templatePath to the path to your template.

What is contest id on each platform

You can find this information for every supported platform here.

I code in java, can I use this tool

Yes, of course, and any other language you want. Just make sure to update your language configuration setting.

This problem has multiple correct answers, what can I do

TODO: Coming soon. Read minitutorial on configuring custom checker.

Commands

Call this commands from the command pallete (Ctrl + Shift + P).

  • acmx.addProblem (ACMX: New Problem): Create a new problem. Make environment skeleton and download testcases.
  • acmx.addContest (ACMX: New Contest): Create a new contest. Make environment skeleton and download testcases.
  • acmx.runSolution (ACMX: Run): Compile and run current solution against testcases.
  • acmx.openTestcase (ACMX: Open Test Case): Open a paticular testcase.
  • acmx.addTestcase (ACMX: Add Test Case): Add a new testcase.
  • acmx.coding (ACMX: View: Code): Return to 1 column layout (better to code).
  • acmx.stress (ACMX: Stress): Run the solution against correct program using testcases from generator. Useful to find failing and corner cases. Must call upgrade first.
  • acmx.upgrade (ACMX: Upgrade): Create aditionals files before calling Stress.
  • acmx.compile (ACMX: Compile): Compile sol.cpp.

Settings

  • acmx.configuration.templatePath: Path to template file. Leave empty to use default template.
  • acmx.configuration.solutionPath: Path to folder where contest will be created and stored. To set active workspace use .
  • acmx.configuration.extension: Extension of the programming language you will use to code solutions. Default cpp for c++
  • acmx.run.timetimeLimit: Maximum time limit in seconds to run the program on each test case.
  • acmx.execution.compile: Command to compile C++ programs. Refer to the code as $PROGRAM, and output file as $OUTPUT.
  • acmx.execution.pythonPath: Path to python executable. This will be used to run generator.