下面是一个完整的下三角九九口诀表:
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
1*5=5 2*5=10 3*5=15 4*5=20 5*5=25
1*6=6 2*6=12 3*6=18 4*6=24 5*6=30 6*6=36
1*7=7 2*7=14 3*7=21 4*7=28 5*7=35 6*7=42 7*7=49
1*8=8 2*8=16 3*8=24 4*8=32 5*8=40 6*8=48 7*8=56 8*8=64
1*9=9 2*9=18 3*9=27 4*9=36 5*9=45 6*9=54 7*9=63 8*9=72 9*9=81
本题要求对任意给定的一位正整数N
,输出从1*1
到N*N
的部分口诀表。
输入格式:
输入在一行中给出一个正整数N
(1≤N
≤9)。
输出格式:
输出下三角N*N
部分口诀表,其中等号右边数字占4位、左对齐。
输入样例:
4
输出样例:
1*1=1
1*2=2 2*2=4
1*3=3 2*3=6 3*3=9
1*4=4 2*4=8 3*4=12 4*4=16
对于九九口诀表进行分析:
第一列都是1*x=y的形式,第二列为2*x=y的形式,以此类推;
第一行是x*1=y的形式,第二行为x*2=y的形式,以此类推;
由此推知,算式中前面的数字控制列,后面数字控制行
输出时注意格式,通过“-”确保输出时格式为“数字空空空”(直接打空格可能看不出来,只能如此,将就一下啦)而不是(空空空数字)!!
上代码!!
#include <stdio.h>
int main()
{
int N;
scanf("%d",&N);
int i,j,k;
for(j=1;j<=N;j++) //外层控制行
{
for(i=1;i<=N;i++) //内层控制列
{
if(i<=j)
{
printf("%d*%d=%-4d",i,j,i*j);
//-4d确保输出形式为1 而不是 1;
}
}
printf("\n");
}
return 0;
}