7-20 打印九九口诀表
分数 15
作者 徐镜春
单位 浙江大学
下面是一个完整的下三角九九口诀表:
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
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
代码1
#include<stdio.h>
int main()
{
int n,i,j;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
for(j=1;j<=i;j++)
{
if(i!=j)
{
printf("%d*%d=%-4d",j,i,i*j);
}
else
{
printf("%d*%d=%-4d\n",j,i,i*j);
}
}
}
return 0;
}
代码2(略简单一些)
#include "stdio.h"
#include "math.h"
int main(){
//打印乘法口诀i表
int n;
int i=1,j=1;
scanf("%d",&n);
for (i=1; i<=n; i++) {
for (j=1; j<=i; j++) {//注意j的范围
printf("%d*%d=%-4d",j,i,i*j);//注意顺序
if(i==j){ printf("\n");}
}
}
return 0;
}
注意事项:
1、注意j的范围是“j=1;j<=i;j++”这样子才能做出上三角形的九九乘法表,否则是方块形状的,且有重复算式。
2、注意i,j的顺序,在输出printf里面一定要先输出j,因为j是内层循环,受到的限制更多,数值上更小,然后第二位再输出外层循环i,这样得出的是理想的九九乘法表,否则是九九乘法表的转置。