# | Problem | Pass Rate (passed user / total user) |
---|---|---|
13485 | String Calculator(class) |
|
13862 | Pineapple senpai’s family |
|
Description
In this problem, you need to finish a string calculator.
The calculator has three string operators:
- a + b: Concatenate the string b after the string a.
- a - b: If string b has appeared in string a, delete the first appearance of b in a, otherwise the result is "error".
- a / b: The number of occurrences of string b in string a.
Note: You are suggested to practice the usage of C++ string class (https://www.cplusplus.com/reference/string/string/).
- function std::operator+: Concatenate strings (https://www.cplusplus.com/reference/string/string/operator+/)
- public member function std::string::find: Find content in string (https://www.cplusplus.com/reference/string/string/find/)
- public member function std::string::substr: Generate substring (https://www.cplusplus.com/reference/string/string/substr/)
- etc.
Input
The first line contains an integer N
The following N lines, each line contains two string a b.
testcases:
(6/6) 1 <= N <= 100, 1 <= |a|, |b| <= 100
Output
The output contains N lines.
For each a b, output ((a - b)+b)/b
Sample Input Download
Sample Output Download
Partial Judge Code
13485.cppPartial Judge Header
13485.hTags
Discuss
Description
Pineapple Senpai is introducing his family to you.
Each member of his family has some strong relatives such as ParentA, ParentB, Mate, and Child.
And there would be a narrator in the family, who is responsible to introduce the family to you.
Initially, the narrator is Pineapple Senpai himself, and the narrator would introduce his relative's attributes such as gender, age, name, and personality.
Each relative is selected by a strong-relative-chain. For example, if the strong-relative-chain is "ParentA Child", it means that the relative is the narrator's ParentA's Child(which is the narrator itself).
So there are three types of queries you need to proceed
- 1 strong-relative-chain this type of query asks you to change the narrator to the current narrator's relative, which is selected by the strong-relative-chain.
- 2 strong-relative-chain attribute-modification this type of query asks you to change the attribute of the current narrator's relative, which is selected by the strong-relative-chain. the attribute-modification's would specify the name of the attribute, and the value to be changed. There are four types of attributes: "Gender: ENUM, Age: INT, Name: STRING, Personality: STRING".
- 3 this type of query asks you to print the info of the current narrator, you should call the built-in function directly.
Note that the first time every relative is introduced to you, there may be some information that is not directly revealed by the narrator but you should notice.
When a Child is first introduced to you, at least one of its parent is introduced early, which should be the Child's ParentA.
A Child's ParentA and ParentB should always be Mate to each other.
If B is A's Mate, A's Child would be B's Child, too.
Each time a perstonality is described, you should concatenate the new described personality behind the original personalities spacing by a single space character.
- \(1 \leq Q \leq 1000\)
- \(1 \leq len(strong-relative-chain) \leq 1000\)
- \(1 \leq len(attribute-chain) \leq 200\)
Constraints
This is a Partial judge Problem.
All you need to do is to implement the getRelative and describe function.
For the getRelative function, you should return the pointer to the relative that is selected by the strong-relative-chain
For the describe function, you should modify the corresponding attribute of the relative selected by the strong-relative-chain