This repository has been archived on 2022-06-22. You can view files and clone it, but cannot push or open issues or pull requests.
usaco-guide/content/1_Intro/Languages.md
Benjamin Qi 0c2bbb297a minor
2020-06-28 21:17:56 -04:00

3.4 KiB

id title author description
lang Languages Nathan Wang, Benjamin Qi What languages you can use for programming contests and what you're expected to know before continuing.

Choosing a Language

The most popular languages that USACO supports are C++11, Java, and Python 3. In general, we recommend the following:

  • If you already know one of these languages, just use it.
    • If you know multiple languages, we recommend you pick C++ over Java, and Java over Python.
  • For Bronze, any language will do.
  • For Silver, Gold, and Platinum, Python is not recommended.

Keep in mind that it's easy to switch languages down the road. Don't get caught up on which language to choose. Just pick the one you feel most comfortable with!

Language References

All of these are provided at the IOI aside from the additional C++ reference.

Expected Knowledge

The remainder of this guide assumes that you know the basics of how to code in one of the languages listed above, including the following topics:

  • Variables
    • Data types
  • Reading Input
  • Writing Output
  • Loops
  • If / Else
  • Logical operators
  • Functions
    • Basic Recursion (a function calling itself)
  • Arrays
    • Multidimensional Arrays

In particular, contestants using Java should be familiar with roughly the first half of AP Computer Science A.

  • If you do not meet these prerequisites, see the links below to get started.
  • Familiarity with competition math (ex. AIME qualification) is helpful but not required.

Resources for Learning How to Code

C++

Use one of these resources (or find your own) to learn C++.

also courses for Java, Python

If you use Sololearn, we recommend you finish everything up to (but not including) "More on Classes." You don't have to complete the full course.

You do not need to learn pointers (for now). Knowledge of structs and classes is useful but not required.

Resources for Getting Started

Let us know what works (or doesn't) for you.

can practice basics with "Arcade," "Interview Practice" lots of links! not so up to date generally good, although CSES (see resources) is definitely a better place to start than USACO Training or Codechef