题解 | #X形图案#
X形图案
https://www.nowcoder.com/practice/83d6afe3018e44539c51265165806ee4
#include<stdio.h> int main() { int a,i,j,k; while(scanf("%d",&a)!=EOF) { for(i=1;i<=a/2;i++)//上半部分 { for(k=1;k<=i-1;k++)//每行前面的空格, { //i=1,空格为0,i=2,空格为1,i=3,空格为2,故k=1;k<=i-1;k++ printf(" ");//每次循环输出一个空格 } printf("*");//紧接着的一个星星 for(j=1;j<=a-2*i;j++)//接下来两星星间的空格 { //a=6,i=1,空格为4,i=2,空格为2,i=3,空格为0, printf(" "); //因此j=1;j<=a-2*i;j++,大家多练练就顺了,规律很常见 } printf("*\n");//输出最后的星星再加换行符 } if(a%2!=0)//奇数a中间的星星 { for(i=1;i<=a/2;i++) { printf(" "); } printf("*\n"); } for(i=1;i<=a/2;i++)//下半部分 { for(k=1;k<=a/2-i;k++)//每行前面的空格 { //i=1,空格为2,i=2,空格为1,i=3,空格为0,故k=1;k<=a/2-i;k++ printf(" ");//每次循环输出一个空格 } printf("*");//输出紧接着的星星 for(j=1;j<=2*i-1-(a+1)%2;j++)//接下来是两星星间的空格 { //注意此时偶数a与奇数a的不同, //当a为奇数时,比如7,i=1,j需要循环1次,而偶数比如6,当i=1,j需要循环0次 //i=2,j需要循环3次,而偶数比如6,当i=2,j需要循环2次 //i=3,j需要循环5次,而偶数比如6,当i=3,j需要循环4次 printf(" ");//因此j=1;j<=2*i-1-(a+1)%2;j++ } printf("*\n");//输出每行最后的星星再加上换行符 } } return 0; }
总结:
大家最好把a=3,4,5,6都画出来,然后列个表格,表头有a,i,j,k,然后数相应的格子,找规律