【codechef】 Chef and Piano Scales (简单题)

本文详细介绍了钢琴初学者如何通过演奏音阶来提高指速,解释了不同音阶的间隔模式,并通过具体实例展示了如何在键盘上操作。文章还说明了演奏音阶时的注意事项,以及如何使用特定数量的八度来创建不同的音阶模式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Recently, Chef got obsessed with piano. He is a just a rookie in this stuff and can not move his fingers from one key to other fast enough. He discovered that the best way to train finger speed is to play scales.

There are different kinds of scales which are divided on the basis of their interval patterns. For instance, major scale is defined by pattern T-T-S-T-T-T-S, where ‘T’ stands for a whole tone whereas ‘S’ stands for a semitone. Two semitones make one tone. To understand how they are being played, please refer to the below image of piano’s octave – two consecutive keys differ by one semitone.

If we start playing from first key (note C), then we’ll play all white keys in a row (notes C-D-E-F-G-A-B-C – as you can see C and D differ for a tone as in pattern, and E and F differ for a semitone).

This pattern could be played some number of times (in cycle).

Each time Chef takes some type of a scale and plays using some number of octaves. Sometimes Chef can make up some scales, so please don’t blame him if you find some scale that does not exist in real world.

Formally, you have a set of 12 keys (i.e. one octave) and you have N such sets in a row. So in total, you have 12*N keys. You also have a pattern that consists of letters 'T' and 'S', where 'T' means move forward for two keys (from key x to key x + 2, and 'S' means move forward for one key (from key x to key x + 1).

Now, you can start playing from any of the 12*N keys. In one play, you can repeat the pattern as many times as you want, but you cannot go outside the keyboard.

Repeating pattern means that if, for example, you have pattern STTST, you can play STTST as well asSTTSTSTTST, as well as STTSTSTTSTSTTST, as well as any number of repeating. For this pattern, if you choose to repeat it once, if you start at some key x, you'll press keys: x (letter 'S')-> x + 1 (letter 'T')-> x + 3 (letter 'T')-> x + 5 (letter 'S') -> x + 6 (letter 'T')-> x + 8. Also 1 ≤ x, x + 8 ≤ 12*N so as to avoid going off the keyboard.

You are asked to calculate number of different plays that can be performed. Two plays differ if and only if they start at different keys or patterns are repeated different number of times.

Input

The first line of the input contains an integer T denoting the number of test cases. The description of T test cases follows.
First line of each test case contains scale’s pattern – string s consisting of letters ‘T’ and ‘S’ only.
Second line contains one integer N – number of octaves he’ll be using.

Output

For each test case output a single number in a line corresponding to number of different scales he’ll play. 

Constraints

  • 1 ≤ T ≤ 105
  • 1 ≤ |S| ≤ 100
  • 1 ≤ n ≤ 7

Subtasks

Subtask 1: T < 10 4, N = 1

Subtask 2: No additional constraints.

Example

Input:
2 
TTTT
1
TTSTTTS
3

Output:
4
36

Explanation

Example case 1. In the first case there is only one octave and Chef can play scale (not in cycle each time) starting with notes C, C#, D, D# - four together.

简单题,但是题目不容易读懂啊╮(╯▽╰)╭

http://www.codechef.com/APRIL15/problems/PIANO1/

#include<stdio.h>
int main()
{
    int t, n,i,scales,res;
    char arr[101];
    scanf("%d", &t);
    while(t--)
    {
        scanf("%s", arr);
        scanf("%d", &n);
        n=12*n;
        scales=0;
        for(i=0;arr[i]!='\0';i++)
        {
            if(arr[i]=='S')
                scales+=1;
            else
                scales+=2;
        }
        res=0;
        for(i=scales;i<n;i+=scales)
        {
            res+=n-i;
        }
        printf("%d\n", res);
    }
    return 0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值