CF325B.Stadium and Games

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

Daniel is organizing a football tournament. He has come up with the following tournament format:

  1. In the first several (possibly zero) stages, while the number of teams is even, they split in pairs and play one game for each pair. At each stage the loser of each pair is eliminated (there are no draws). Such stages are held while the number of teams is even.
  2. Eventually there will be an odd number of teams remaining. If there is one team remaining, it will be declared the winner, and the tournament ends. Otherwise each of the remaining teams will play with each other remaining team once in round robin tournament (if there are xx teams, there will be games), and the tournament ends.

For example, if there were 20 teams initially, they would begin by playing 10 games. So, 10 teams would be eliminated, and the remaining 10 would play 5 games. Then the remaining 5 teams would play 10 games in a round robin tournament. In total there would be 10+5+10=25 games.

Daniel has already booked the stadium for nn games. Help him to determine how many teams he should invite so that the tournament needs exactly nn games. You should print all possible numbers of teams that will yield exactly nn games in ascending order, or -1 if there are no such numbers.

输入格式

The first line contains a single integer nn ( 1<=n<=10181<=n<=10^{18} ), the number of games that should be played.

Please, do not use the %lld specifier to read or write 64-bit integers in С++. It is preferred to use the cin, cout streams or the %I64d specifier.

输出格式

Print all possible numbers of invited teams in ascending order, one per line. If exactly nn games cannot be played, output one number: -1.

输入输出样例

  • 输入#1

    3
    

    输出#1

    3
    4
    
  • 输入#2

    25
    

    输出#2

    20
    
  • 输入#3

    2
    

    输出#3

    -1
    
首页