Er, you are not following the instructions.
Your output:
Critique to Help You Out
The point of the test was to see if you have very basic comprehension and can write a trivial C++ program — a basic litmus, if you will, to weed out people who are lying on their résumés.
While it is clear that you can write a program, you have, sadly, missed the point.
The first mistake was trying to be clever. Don’t do that. It adds complexity and makes it too easy to confuse things.
For example, you have introduced a function named “getint”.
But the function does not get an int. It prints stuff to the console, gets
two (or more) ints, possibly performs recursion, and returns the
sum of the last two ints received at input.
Everything about that violates the concept behind “get an int”.
Beyond that, you have introduced a function which seeks to do all the stuff that the program is expected to do. In fact, the only thing it
doesn’t do is print the sum. Whenever you find yourself writing main() under another name, stop and reconsider your structure.
You also do not test A and B properly, but you should not be doing that anyway — the instructions
do not ask you to do that.
Breakdown
To help follow the instructions, let’s break them down.
This is the problem description.
For this problem you must calculate A + B, numbers given in the input. |
This is a general synopsis about what the program will do:
• input will provide two numbers (A and B)
• you will calculate their sum (A + B)
Notice that we are lacking a lot of specifics. The following will clarify the important points: how input is shaped, and how output is to be shaped.
Input specification
The only line of input contain two space separated integers A, B (0 <= A, B <= 10). |
This is fairly clear, and you have understood everything but the constraints, which are a fairly standard mathematical notation to say that both A and B will fall in the range 0..10 inclusive.
Importantly, it does not ask you to verify this fact. You can take it as
given that the input will be composed of two integers, separated by one or more spaces, and that the integers will be in the correct range of values.
Output specification
The only line of output should contain one integer: the sum of A and B. |
You should produce:
• exactly one line of output (meaning, terminated with a newline)
• the output must have exactly one item: an integer
• that integer must be the numerical sum of the two input integers
Sample input
1 2
Sample output
3 |
Common in program specifications are example inputs and outputs, meant to clarify the description with concrete examples. (And often, to hint at corner cases you should be aware of).
Here the problem designer has given you very exacting examples to clarify the instructions.
• As “Sample input” we see two integers, separated by a space, both in the range 0..10 inclusive.
• As “Sample output” we see a single integer. Applying a little mental math we see that it is, in fact, the sum of 1 and 2.
This is a very normal approach to specifying problems. It is typically —as in this case— very exacting. You should learn to recognize the structure and understand its meaning. You will see it again and again.
So, to finish off, a correctly performing program would look something like this:
1 2 3 4 5 6 7
|
#include <iostream>
int main()
{
int A, B;
std::cin >> A >> B;
std::cout << (A + B) << "\n";
}
|
This program would demonstrate:
• I can actually write a simple C++ program, which compiles and functions correctly
• I have understood the program requirements and properly translated the
“written problem” to working code.
It also demonstrates:
• I don’t spend time with unnecessary convolutions.
That last point is important to an employer. It demonstrates an employee who can see a simple, straight-forward solution, and not spend time (== money) on bells and whistles or not get confused in the middle of an algorithm. It also demonstrates an employee who can plan an algorithm before jumping in to writing code.
Don’t be dismayed.
This is all part of the learning curve. The lessons here are:
• be exact
• don’t waste time trying to do extra or be fancy in any way
this problem has not asked you to use functions, for example
• recognize that written language follows specific patterns
I hope this helps. May future competitive programming efforts bring you fun and joy!