问题:https://paste.ubuntu.com/p/yks3Whdtxh/
注意ij更新为0,注意循环范围。尤其注意!
代码:
#include<stdio.h>
#include<string.h>
//输入倒三角,利用对称关系,输出正三角。
//数量关系:每行;空格i个,星号n-i个,形式:(n-i-1)个(* )星号空格,末尾星号*,i个空格。
int main(){
int n,i,j,low,num;
//while(scanf("%d",&n)!=EOF){
scanf("%d",&n);
low=2*n-1;//底边范围
for(i=0;i<n;i++){//上三角
num=0;//(每行更新)记录每行星号空格已输入数量 ,每行前n-i-1个星号后跟随空格,即星号之间的空格随星号输出
for(j=0;j<low;j++){
if(j<i) printf(" ");//列<行时,输出空格
if(j>=i&&(num<n-i)) {//往后列≥行时,且不是最后一个星号,输出星号空格
printf("* ");
num++;
}
else printf("*");//最后一个星号
for(j=0;j<i;j++){//输出末尾空格
printf(" ");
}
}
printf("\n");//换行
}
for(i=n;i<2*n-1;i++){//正三角(中心一点倒三角时已输出)
num=0;//每行更新num
int temp=n-1-i;//寻找对称关系,利用现成倒三角
for(j=0;j<low;j++){
if(j<temp) printf(" ");
if(j>=temp&&(num<n-temp)) {
printf("* ");
num++;
}
else printf("*");
for(j=0;j<temp;j++){
printf(" ");
}
}
printf("\n");
}
// }
return 0;
}
正确代码:memcpy0
#include <cstdio>
int main()
{
int n;
while (scanf("%d", &n) != EOF) {
//打印上半部分
int UpEdge = n + n - 1; //第一层的字符数(包括空格和星号)
for (int i = UpEdge; i >= n; i--) { //i表示每层所拥有的字符数
int spaceNum = UpEdge - i;
for (int j = 0; j < spaceNum; j++)
printf(" ");
int charNum = i - n + 1;
for (int j = 0; j < charNum - 1; j++)
printf("* ");
printf("*\n");
}
//打印下半部分
for (int i = n + 1; i <= UpEdge; i++) {
int spaceNum = UpEdge - i;
for (int j = 0; j < spaceNum; j++)
printf(" ");
int charNum = i - n + 1;
for (int j = 0; j < charNum - 1; j++)
printf("* ");
printf("*\n");
}
}
return 0;
}