Codeforces 363A Soroban-算盘模拟
2016-09-15 12:18
996 查看
You know that Japan is the country with almost the largest ‘electronic devices per person’ ratio. So you might be quite surprised to find out that the primary school in Japan teaches to count using a Soroban — an abacus developed in Japan. This phenomenon has its reasons, of course, but we are not going to speak about them. Let’s have a look at the Soroban’s construction.
Soroban consists of some number of rods, each rod contains five beads. We will assume that the rods are horizontal lines. One bead on each rod (the leftmost one) is divided from the others by a bar (the reckoning bar). This single bead is called go-dama and four others are ichi-damas. Each rod is responsible for representing a single digit from 0 to 9. We can obtain the value of a digit by following simple algorithm:
Set the value of a digit equal to 0.
If the go-dama is shifted to the right, add 5.
Add the number of ichi-damas shifted to the left.
Thus, the upper rod on the picture shows digit 0, the middle one shows digit 2 and the lower one shows 7. We will consider the top rod to represent the last decimal digit of a number, so the picture shows number 720.
Write the program that prints the way Soroban shows the given number n.
Input
The first line contains a single integer n (0 ≤ n < 109).
Output
Print the description of the decimal digits of number n from the last one to the first one (as mentioned on the picture in the statement), one per line. Print the beads as large English letters ‘O’, rod pieces as character ‘-’ and the reckoning bar as ‘|’. Print as many rods, as many digits are in the decimal representation of number n without leading zeroes. We can assume that number 0 has no leading zeroes.
Sample Input
Input
2
Output
O-|OO-OO
Input
13
Output
O-|OOO-O
O-|O-OOO
Input
720
Output
O-|-OOOO
O-|OO-OO
-O|OO-OO
AC代码:
Soroban consists of some number of rods, each rod contains five beads. We will assume that the rods are horizontal lines. One bead on each rod (the leftmost one) is divided from the others by a bar (the reckoning bar). This single bead is called go-dama and four others are ichi-damas. Each rod is responsible for representing a single digit from 0 to 9. We can obtain the value of a digit by following simple algorithm:
Set the value of a digit equal to 0.
If the go-dama is shifted to the right, add 5.
Add the number of ichi-damas shifted to the left.
Thus, the upper rod on the picture shows digit 0, the middle one shows digit 2 and the lower one shows 7. We will consider the top rod to represent the last decimal digit of a number, so the picture shows number 720.
Write the program that prints the way Soroban shows the given number n.
Input
The first line contains a single integer n (0 ≤ n < 109).
Output
Print the description of the decimal digits of number n from the last one to the first one (as mentioned on the picture in the statement), one per line. Print the beads as large English letters ‘O’, rod pieces as character ‘-’ and the reckoning bar as ‘|’. Print as many rods, as many digits are in the decimal representation of number n without leading zeroes. We can assume that number 0 has no leading zeroes.
Sample Input
Input
2
Output
O-|OO-OO
Input
13
Output
O-|OOO-O
O-|O-OOO
Input
720
Output
O-|-OOOO
O-|OO-OO
-O|OO-OO
AC代码:
#include <cstdio> #include <cstring> #include <cmath> #include <ctime> #include <cstdlib> #include <queue> #include <stack> #include <string> #include <map> #include <vector> #include <iostream> #include <algorithm> using namespace std; int main() { char s[102]; while(~scanf("%s",&s)) { int m=strlen(s); for(int i=m-1; i>=0; i--) { if(s[i]>='5'&&s[i]<='9') { printf("-O|"); for(int j=1; j<=s[i]-'5'; j++) printf("O"); printf("-"); for(int j=1; j<='9'-s[i]; j++) printf("O"); printf("\n"); } else { printf("O-|"); for(int j=1; j<=s[i]-'0'; j++) printf("O"); printf("-"); for(int j=1; j<='4'-s[i]; j++) printf("O"); printf("\n"); } } } return 0; }
相关文章推荐
- Codeforces 363A Soroban(算盘模拟)
- Codeforces 363A Soroban(算盘模拟)
- codeforces 459C Pashmak and Buses(模拟,组合数A)
- Codeforces 309C Memory for Arrays 二进制模拟进位
- Codeforces 724C [坐标][乱搞][模拟]
- 【CodeForces 803B】Distances to Zero(模拟)
- CodeForces 589B-Layer Cake-暴力模拟
- CodeForces - 665B Shopping(模拟)
- Codeforces 534D - Handshakes (贪心 + 模拟)
- Codeforces--626B--Cards(模拟)
- CodeForces - 868B Race Against Time(模拟)
- codeforces 404B Marathon(模拟)
- Codeforces 706E Working routine (模拟链表)
- [codeforces] C - Efim and Strange Grade 模拟+贪心
- 【STL】【模拟】Codeforces 696A Lorenzo Von Matterhorn
- 【CodeForces 651A】Joysticks 模拟
- CodeForces 471B MUH and Important Things 模拟 水
- Codeforces 793C Mice Problem 几何(模拟)
- 【并查集】【模拟】Codeforces 698B & 699D Fix a Tree
- CodeForces 260A Adding Digits 模拟