22752_Nim-BSu

2022-5-16 18:22| 发布者: Hocassian| 查看: 24| 评论: 0|原作者: 肇庆学院ACM合集

摘要:
C:\Users\Administrator\Downloads\2019-10-12-10-14-5-89506925360300-Problem List-采集的数据-后羿采集器.html

Pro.ID

22752

Title

Nim-B Sum

Title链接

http://10.20.2.8/oj/exercise/problem?problem_id=22752

AC

2

Submit

2

Ratio

100.00%

时间&空间限制

  • Time Limit: 200/100 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Others)
  • 描述

    The game of NIM is played with any number of piles of objects with any number of objects in each pile. At each turn, a player takes one or more (up to all) objects from one pile. In the normal form of the game, the player who takes the last object is the winner. There is a well-known strategy for this game based on the nim-2 sum.

    The Nim-B sum (nim sum base B) of two non-negative integers X and Y (written NimSum(B, X, Y)) is computed as follows:

    1) Write each of X and Y in base B.

    2) Each digit in base B of the Nim-B sum is the sum modulo B of the corresponding digits in the base B representation of X and Y.

    For example:

    NimSum(2, 123, 456) = 1111011 ¤ 111001000 = 110110011 = 435

    NimSum(3, 123, 456) = 11120 ¤ 121220 = 102010 = 300

    NimSum(4, 123, 456) = 1323 ¤ 13020 = 10303 = 307

    The strategy for normal form Nim is to compute the Nim-2 sum T of the sizes of all piles. If at any time, you end your turn with T = 0, you are guaranteed a WIN. Any opponent move must leave T not 0 and there is always a move to get T back to 0. This is done by computing NimSum(2, T, PS) for each pile; if this is less than the pile size (PS), compute the difference between the PS and the Nim-2 sum and remove it from that pile as your next move.

    Write a program to compute NimSum(B, X, Y).

    输入

    The first line of input contains a single integer P, (1 ≤ P ≤ 1000), which is the number of data sets that follow. Each data set is a single line that contains the data set number, followed by a space, followed by three space separated decimal integers, B, X and Y. 2 ≤ B ≤ 2000000, 0 ≤ X ≤ 2000000, 0 ≤ Y ≤ 2000000.

    输出

    Description

    The game of NIM is played with any number of piles of objects with any number of objects in each pile. At each turn, a player takes one or more (up to all) objects from one pile. In the normal form of the game, the player who takes the last object is the winner. There is a well-known strategy for this game based on the nim-2 sum.

    The Nim-B sum (nim sum base B) of two non-negative integers X and Y (written NimSum(B, X, Y)) is computed as follows:

    1) Write each of X and Y in base B.

    2) Each digit in base B of the Nim-B sum is the sum modulo B of the corresponding digits in the base B representation of X and Y.

    For example:

    NimSum(2, 123, 456) = 1111011 ¤ 111001000 = 110110011 = 435

    NimSum(3, 123, 456) = 11120 ¤ 121220 = 102010 = 300

    NimSum(4, 123, 456) = 1323 ¤ 13020 = 10303 = 307

    The strategy for normal form Nim is to compute the Nim-2 sum T of the sizes of all piles. If at any time, you end your turn with T = 0, you are guaranteed a WIN. Any opponent move must leave T not 0 and there is always a move to get T back to 0. This is done by computing NimSum(2, T, PS) for each pile; if this is less than the pile size (PS), compute the difference between the PS and the Nim-2 sum and remove it from that pile as your next move.

    Write a program to compute NimSum(B, X, Y).

    Input

    The first line of input contains a single integer P, (1 ≤ P ≤ 1000), which is the number of data sets that follow. Each data set is a single line that contains the data set number, followed by a space, followed by three space separated decimal integers, B, X and Y. 2 ≤ B ≤ 2000000, 0 ≤ X ≤ 2000000, 0 ≤ Y ≤ 2000000.

    Output

    For each data set there is one line of output. It contains the data set number followed by a single space, followed by N, the decimal representation of the Nim sum in base B of X and Y.

    Sample Input

    4
    1 2 123 456
    2 3 123 456
    3 4 123 456
    4 5 123 456

    Sample Output

    1 435
    2 300
    3 307
    4 429

    Source

    样例输入

    4
    1 2 123 456
    2 3 123 456
    3 4 123 456
    4 5 123 456

    样例输出

    1 435
    2 300
    3 307
    4 429

    作者


    路过

    雷人

    握手

    鲜花

    鸡蛋

    最新评论

    返回顶部