acmX is tool that empower contestants to solve competitive programming problems easily.
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.
You need to tell acmX which folder are you going to use, to save all the problems and contests. To do that:
Ctrl+,
acmx.configuration.solutionPath
/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.
Create a file with your template. In settings, set acmx.configuration.templatePath
to the path to your template.
You can find this information for every supported platform here.
Yes, of course, and any other language you want. Just make sure to update your language configuration setting.
TODO: Coming soon. Read minitutorial on configuring custom checker.
Call this commands from the command pallete (Ctrl + Shift + P
).
Stress
.sol.cpp
..
cpp
for c++