题解洛谷P1538【迎春舞会之数字舞蹈】
方法:暴力,判断,输出
本题为了更好理解建议各位可以复制样例来研究,甚至可以复制题解来测试思想,相信大家不会抄。
有什么不好的请大佬们在评论里指出,谢谢
#include <bits/stdc++.h>//头文件,万能,手动滑稽
using namespace std;//开辟名称空间
int k,x,js;//x表示总行数,k表示要摆出数字的大小,js表示
string a;//第二排数字
int main()//开始
{
/*
cout<<"123456--123-- -- -- --123-- -- -- "<<endl;
cout<<"123|1234|1234|1|12|1|1234|12 1234| | | | | |12|"<<endl;
cout<<" | | | | | | | | | | | | | |"<<endl;
cout<<" -- -- -- -- -- -- 1-- "<<endl;
cout<<" | | | | | | | | | | | | |"<<endl;
cout<<" | | | | | | | | | | | | |"<<endl;
cout<<" -- -- -- -- -- -- -- "<<endl;
//这里是复制样例来看空格,为了一目了然这一切。
//发现相邻两个数字之间有两个空格,数字中间的空格是k。
//要画"-"那一行要空一个格。
//第一个数字要顶格
//注意第一个数字是1时不要中陷阱,就是认为刚开始要空3格
*/
cin>>k;//输入数字大小
cin>>a;//输入要输出的数字
x=3+k*2;//发现的规律,计算总共多少行
for(int i=1;i<=x;i++)//进入第一层循环一共要画3+k*2行
{
if(i==1 || i==2+k*1 || i==3+k*2)cout<<" ";//规律的应用,画"-"那一行要空一个格。
for(int j=0;j<a.size();j++)//进入第二层循环,用处:画每行要画的东西。
{
if(j!=0)cout<<" ";//如果不是第一个格就空一个,具体在上面的图中找的
if(i==1)//如果是第一行
{
if(a[j]=='2' ||a[j]=='3' || a[j]=='5' || a[j]=='6' || a[j]=='7' || a[j]=='8'||a[j]=='9'||a[j]=='0')//判断要画"-"的数字
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<'-';//画出"-"
cout<<" ";//相邻两个数字之间有两个空格
}
else //如果不是那些数字就不画'-'
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<' ';//用空格代替"-"
cout<<" ";//相邻两个数字之间有两个空格
}
}
if(i!=1 && i<2+k*1)//如果在第一行和中间行之间画'|'的地方也就是数字的上半部分
{
if(a[j]=='1' || a[j]=='2' || a[j]=='3' || a[j]=='7')//判断在右边画'|'的数字
{
cout<<" ";//替代左边的'|'
for(int psb=1;psb<=k;psb++)cout<<" ";//数字中间的空格
cout<<'|';//画'|'
}
if(a[j]=='5' || a[j]=='6')//判断在左边画'|'的数字
{
cout<<'|';//画'|'
for(int psb=1;psb<=k;psb++)cout<<" "; //数字中间的空格
cout<<" ";//替代右边的'|'
}
if(a[j]=='4' || a[j]=='8' ||a[j]=='9'||a[j]=='0')//判断两边都要画'|'的数字
{
cout<<'|';//画'|'
for(int psb=1;psb<=k;psb++)cout<<" "; //数字中间的空格
cout<<'|';//画'|'
}
}
if(i==2+k*1)//判断是否在中间那行
{
if(a[j]=='2' ||a[j]=='3' || a[j]=='5' || a[j]=='6' || a[j]=='4' || a[j]=='8'||a[j]=='9')//判断要画"-"的数字
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<'-';//画出"-"
cout<<" ";//相邻两个数字之间有两个空格
}
else //如果不是那些数字就不画'-'
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<' ';//用空格代替"-"
cout<<" ";//相邻两个数字之间有两个空格
}
}
if(i>2+k*1 && i!=3+k*2)//判断是否在数字的下半部分要画'|'的那k行
{
if(a[j]=='1' || a[j]=='3' || a[j]=='4' || a[j]=='5' || a[j]=='7' ||a[j]=='9')//判断右边要画'|'的数字
{
cout<<" ";//替代左边的'|'
for(int psb=1;psb<=k;psb++)cout<<" ";//数字中间的空格
cout<<'|';//画'|'
}
if(a[j]=='2')//判断左边要画'|'的数字
{
cout<<'|';//画'|'
for(int psb=1;psb<=k;psb++)cout<<" "; //数字中间的空格
cout<<" ";//替代右边的'|'
}
if(a[j]=='6' || a[j]=='8' || a[j]=='0')//判断两边都要画'|'的数字
{
cout<<'|';//画'|'
for(int psb=1;psb<=k;psb++)cout<<" ";//数字中间的空格
cout<<'|';//画'|'
}
}
if(i==3+k*2)//判断是否在最后一行那行
{
if(a[j]=='2' ||a[j]=='3' || a[j]=='5' || a[j]=='6' || a[j]=='8' || a[j]=='9'||a[j]=='0')//判断要画"-"的数字
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<'-';//画出"-"
cout<<" ";//相邻两个数字之间有两个空格
}
else //如果不是那些数字就不画'-'
{
for(int kkksc03=1;kkksc03<=k;kkksc03++)cout<<' ';//用空格代替"-"
cout<<" ";//相邻两个数字之间有两个空格
}
}
}
cout<<endl; //换行,重!!!!
}
return 0;//结束
}
题解洛谷P1538【迎春舞会之数字舞蹈】的更多相关文章
- 洛谷P1538迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- 洛谷 P1538 迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- P1538 迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- P1538迎春舞会之数字舞蹈
传送 输入输出样例:(洛咕的太丑了就不放了) (1前面有三个空格) 这真是一群闲(qian)圈(zou)的人.大号+小号提交了不下10遍终于a了 好了我们来研究一下这些数字"美观" ...
- Luogu P1538 迎春舞会之数字舞蹈 | 模拟
题目链接 大水题,暴力输出,代码应该能看吧...... #include<iostream> #include<cstdio> using namespace std; int ...
- VIJOS-P1064 迎春舞会之数字舞蹈
洛谷 P1538 迎春舞会之数字舞蹈 洛谷传送门 JDOJ 1245: VIJOS-P1064 迎春舞会之数字舞蹈 JDOJ传送门 Description 在越来越讲究合作的时代,人们注意的更多的 ...
- 【洛谷P1538】迎春舞会之数字舞蹈
迎春舞会之数字舞蹈 题目链接 一道奇怪的模拟题, 先将样例输出复制下来,观察观察 -- -- -- -- -- -- -- -- ① | | | | | | | | | | | | | | ② | | ...
- 洛谷 2953 [USACO09OPEN]牛的数字游戏Cow Digit Game
洛谷 2953 [USACO09OPEN]牛的数字游戏Cow Digit Game 题目描述 Bessie is playing a number game against Farmer John, ...
- 题解 洛谷P5018【对称二叉树】(noip2018T4)
\(noip2018\) \(T4\)题解 其实呢,我是觉得这题比\(T3\)水到不知道哪里去了 毕竟我比较菜,不大会\(dp\) 好了开始讲正事 这题其实考察的其实就是选手对D(大)F(法)S(师) ...
随机推荐
- 【C++】归并排序
性能分析: 时间复杂度:O(n*log(n)) 空间复杂度:O(n) 归并排序算法来自于分而治之思想,"归"是"递归"的意思,"并"是&qu ...
- linux配置tomcat项目包
安装配置tomcat 操作系统: centos 7.1 使用模式:命令模式 使用工具:xshell5 .xftp5 注意之前有配置过tomcat需要进行以下4个步骤 1.关闭网管服务 输入命令: 进 ...
- LeetCode双周赛#34
5492. 分割字符串的方案数 #组合公式 #乘法原理 #区间分割 题目链接 题意 给定01二进制串\(s\),可将\(s\)分割为三个非空 字符串\(s_1,s_2,s_3\),即(\(s_1+s_ ...
- 2020.11.26 IntellJ idea激活码失效解决方法(最新idea激活码及安装参数!)
今天是2020年11月26号,小伙伴们是不是有发现自己的idea激活码失效了,不瞒大家,小编也是一个JAVA开发者,到了公司打开idea,然后就发现事情不妙,经过1个多小时的摸索,终于把最近的安装参数 ...
- C++基础知识篇:C++ 修饰符类型
C++ 允许在 char.int 和 double 数据类型前放置修饰符.修饰符用于改变基本类型的含义,所以它更能满足各种情境的需求. C/C++的学习裙[七一二 二八四 七零五 ],无论你是小白还是 ...
- java学生简单管理系统
1 //设一个班有n名学生,期末考试5门,编写程序评定学生奖学金 2 514 //要求打印输出一二等奖学金学生的学号,姓名和各科成绩 3 515 //总成绩超过全班总平均成绩20%一等奖学金,超过总平 ...
- CentOS虚拟化尝试
KVM ///确认cpu是否支持kvm,确认支持,主板还得开启VT和HT egrep '(vmx|svm)' --color=always /proc/cpuinfo ///yum安装rpm包 yum ...
- IEEE754标准浮点数表示与舍入
原文地址:https://blog.fanscore.cn/p/26/ 友情提示:本文排版不太好,但内容简单,请耐心观看,总会搞懂的. 1. 定点数 对于一个无符号二进制小数,例如101.111,如果 ...
- flask基本使用
一.flask安装以及启动 1.安装 pip install flask 2.开启第一个flask项目 新建文件HelloWord.py from flask import Flask app = F ...
- 软件测试相关术语(测试策略 && 测试方案 ....)
软件测试有几种不同的定义方法: a.软件测试是为了发现程序中的错误而执行程序的过程. b.软件测试是根据软件开发各阶段的规格说明和程序的内部结构而精心设计的一批测试用例,并运用这些测试用例运行程序,以 ...