301718: CF325B. Stadium and Games

Memory Limit:256 MB Time Limit:1 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Stadium and Games

题意翻译

有若干队伍参加足球赛。 如果队伍数量为偶数,则两两配对进行比赛,最终淘汰一半的队伍。 当所剩队伍数量为奇数,若剩下一支队,比赛结束;若剩下多支队,这些队伍进行单循环赛(即若有x支队,再进行x(x-1)/2场比赛)。 比如,如果20支队参加比赛: 1.两两配对,进行10场比赛,剩10支队 2.两两配对,进行5场比赛,剩5支队 3.剩下5支队进行单循环比赛,共10场比赛 综上,一共进行了25场比赛 给定比赛场数,计算可以有多少支队进行比赛,升序输出所有可能的队伍数。若无解,输出-1。 输入格式: 第一行输入一个整数n(1<=n<=10^18),n为比赛场数。 输出格式: 升序输出可能的队伍数,每行一个。若无解,输出-1.

题目描述

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 $ x $ teams, there will be ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF325B/e5061b7dfd3556627af3b421a8198ff388b1a5d3.png) 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 $ n $ games. Help him to determine how many teams he should invite so that the tournament needs exactly $ n $ games. You should print all possible numbers of teams that will yield exactly $ n $ games in ascending order, or -1 if there are no such numbers.

输入输出格式

输入格式


The first line contains a single integer $ n $ ( $ 1<=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 $ n $ games cannot be played, output one number: -1.

输入输出样例

输入样例 #1

3

输出样例 #1

3
4

输入样例 #2

25

输出样例 #2

20

输入样例 #3

2

输出样例 #3

-1

Input

题意翻译

有若干队伍参加足球赛。 如果队伍数量为偶数,则两两配对进行比赛,最终淘汰一半的队伍。 当所剩队伍数量为奇数,若剩下一支队,比赛结束;若剩下多支队,这些队伍进行单循环赛(即若有x支队,再进行x(x-1)/2场比赛)。 比如,如果20支队参加比赛: 1.两两配对,进行10场比赛,剩10支队 2.两两配对,进行5场比赛,剩5支队 3.剩下5支队进行单循环比赛,共10场比赛 综上,一共进行了25场比赛 给定比赛场数,计算可以有多少支队进行比赛,升序输出所有可能的队伍数。若无解,输出-1。 输入格式: 第一行输入一个整数n(1<=n<=10^18),n为比赛场数。 输出格式: 升序输出可能的队伍数,每行一个。若无解,输出-1.

加入题单

算法标签: