CCC '19 J3 - Cold Compress

View as PDF

Submit solution

Points: 5
Time limit: 1.0s
Memory limit: 32M

Problem type
Canadian Computing Competition: 2019 Stage 1, Junior #3

Your new cellphone plan charges you for every character you send from your phone. Since you tend to send sequences of symbols in your messages, you have come up with the following compression technique: for each symbol, write down the number of times it appears consecutively, followed by the symbol itself. This compression technique is called run-length encoding.

More formally, a block is a substring of identical symbols that is as long as possible. A block will be represented in compressed form as the length of the block followed by the symbol in that block. The encoding of a string is the representation of each block in the string in the order in which they appear in the string.

Given a sequence of characters, write a program to encode them in this format.

Input Specification

The first line of input will contain the number N, which is the number of lines that follow. The next N lines will contain at least one and at most 80 characters, none of which are spaces.

Output Specification

Output will be N lines. Line i of the output will be the encoding of the line i + 1 of the input. The encoding of a line will be a sequence of pairs, separated by a space, where each pair is an integer (representing the number of times the character appears consecutively) followed by a space, followed by the character.

Sample Input

4
+++===!!!!
777777......TTTTTTTTTTTT
(AABBC)
3.1415555

Output for Sample Input

3 + 3 = 4 !
6 7 6 . 12 T
1 ( 2 A 2 B 1 C 1 )
1 3 1 . 1 1 1 4 1 1 4 5

Explanation of Output for Sample Input

To see how the first message (on the second line of input) is encoded, notice that there are 3 + symbols, followed by 3 = symbols, followed by 4 ! symbols.


Comments


  • 3
    0Power10  commented on July 23, 2021, 2:58 p.m.

    Me after seeing the title: ah this must have something to do with medical stuff! me after reading the question: what does this have to do with anything?


  • 1
    CountT  commented on Feb. 15, 2021, 9:23 p.m.

    Can someone explain why I got AC on DMOJ but not on the CCC grader? Thanks!


    • 0
      qiao_yun20060930  commented on April 26, 2021, 3:41 p.m.

      first congrats to all ac on dmoj, and your question is caused by: there are probably different samples, ccc grader has more accurate samples but dmoj's sample maybe a little bit easier and not like that complicated, just my guess, hope this helps


  • 0
    mahes0640  commented on Feb. 4, 2021, 7:58 p.m.

    Can anyone please explain to me why my code jumbles up the occurrences of a certain letter?


  • 19
    tappbros  commented on July 27, 2020, 9:27 p.m.

    Wow, so we have to pay every time we type. Why did we even get this plan.


  • 3
    ryan20070709  commented on Dec. 8, 2019, 7:18 p.m. edited

    how do you check someone else submissions?


    • 3
      ItzMidnightShadowWolf  commented on July 29, 2020, 5:27 p.m.

      That's my question.


    • 14
      AlanL  commented on Dec. 8, 2019, 9:12 p.m.

      You can only check other's submissions if you have solved the problem yourself, and once you do a view button will appear on anyone else's submission so you can see it.


  • 52
    GD_FrostByte  commented on Oct. 13, 2019, 10:11 a.m. edited

    3+3=4

    h m m


    • 1
      ASDAN149A  commented on Jan. 16, 2021, 2:31 a.m.

      It would be correct if there're only 3 '!' XD


    • 3
      Jinx  commented on April 28, 2020, 4:45 p.m.

      I knew someone was gonna say that XD