13. 镂空三角形(卡码网)
题目描述
把一个字符三角形掏空,就能节省材料成本,减轻重量,但关键是为了追求另一种视觉效果。在设计的过程中,需要给出各种花纹的材料和大小尺寸的三角形样板,通过电脑临时做出来,以便看看效果。
输入
每行包含一个字符和一个整数n(0<n<41),不同的字符表示不同的花纹,整数n表示等腰三角形的高。显然其底边长为2n-1。如果遇到@字符,则表示所做出来的样板三角形已经够了。
输出
每个样板三角形之间应空上一行,三角形的中间为空。行末没有多余的空格。每条结果后需要再多输出一个空行。
样例输入
X 2
A 7
@
样例输出
题解1(c++版本)
#include<bits/stdc++.h>
using namespace std;
int n;
char c;
int main(){
while(~scanf(" %c %d", &c, &n)){
if(c == '@') break;
int col = 2 * n - 1; //总列数
for(int i = 1;i < n; i++){ //总行数
for(int j = 1;j <= col; j++){
if(j != n - i + 1 && j != n + i - 1){
printf("%c", ' ');
}else {
//printf("%d\n", j);
printf("%c", c);
}
}
printf("\n");
}
for(int j = 1;j <= col; j++) printf("%c", c);
printf("\n\n");
}
return 0;
}
题解2(Go版本)
package main
import "fmt"
func main(){
var c string
var n int
for {
fmt.Scanln(&c, &n)
if c == "@" {
break
}
var col int = 2 * n - 1
for i := 1; i < n; i++ {
for j := 1; j <= col; j++{
if j != (n - i + 1) && j != (n + i - 1) {
fmt.Printf("%s", " ")
} else {
fmt.Printf("%s", c)
}
}
fmt.Printf("\n")
}
for j := 1;j <= col; j++{
fmt.Printf("%s", c)
}
fmt.Printf("\n\n")
}
}