洛谷P1538迎春舞会之数字舞蹈

2023-02-12,,,

题目背景

HNSDFZ的同学们为了庆祝春节,准备排练一场舞会

题目描述

在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列。

为了配合每年的倒计时,同学们决定排出——“数字舞蹈”。顾名思义就是所有人一起排成若干个数字 -___-|||| 更为创新的是,每个人都是趴在地上,保证横竖。

现在给出数字及其要求摆出的大小,请你编程,模拟同学们的优美姿态。

输入输出格式

输入格式:

第一行为k。k表示要摆出数字的大小。

第二行为全部由数字组成的字符串,即要摆出的几个数字。

输出格式:

按题目要求输出。

输入输出样例

输入样例#1:

2
1234567890

输出样例#1:

      --   --        --   --   --   --   --   --
| | | | | | | | | | | | | |
| | | | | | | | | | | | | |
-- -- -- -- -- -- --
| | | | | | | | | | | | |
| | | | | | | | | | | | |
-- -- -- -- -- -- --

说明

每个数字之前有1个空格,所有数字全部对齐。

k<=30,s的长度不超过255

--------------------------------------------------------------------------------------------------------------

很水

尽量来简化情况,把三个横着的对每个数字处理,两个竖着的对每个数字处理

见代码

WARN:洛谷的输入格式好xiejin,一开始用getline(),之前放一个getchar,结果一直WA,也不知道什么原因,还跟别人的程序打了一个对拍也没问题,结果直接cin就好了

#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
using namespace std;
int k,a[],w,h,n;
string s;
char up[]="- -- -----",mid[]=" ----- --",down[]="- -- -- --";
int pos[][]={{,,,,,,,,,},{,,,,,,,,,}};
int main(){
//freopen("in.txt","r",stdin);
//freopen("1.txt","w",stdout); cin>>k;
cin>>s;
for(n=;n<s.size();n++) a[n+]=s[n]-'';
w=k+;h=*k+;
for(int i=;i<=h;i++)
for(int j=;j<=n;j++){
//-
if(i==||i==k+||i==h){
putchar(' ');
for(int z=;z<=k;z++){
if(i==) putchar(up[a[j]]);
if(i==+k+) putchar(mid[a[j]]);
if(i==h) putchar(down[a[j]]);
}
putchar(' ');
}
//|
else{
int num=;if(i>k+) num=;
for(int i=;i<=w;i++){
if(pos[num][a[j]]==&&i==) putchar('|');
else if(pos[num][a[j]]==&&i==w) putchar('|');
else if(pos[num][a[j]]==&&(i==||i==w)) putchar('|');
else putchar(' ');
}
}
if(j!=n) putchar(' ');
if(j==n&&i!=h) putchar('\n');
}
}

洛谷P1538迎春舞会之数字舞蹈的相关教程结束。

《洛谷P1538迎春舞会之数字舞蹈.doc》

下载本文的Word格式文档,以方便收藏与打印。