使用scala打印九九乘法表,可以有多种实现方法,实现的过程充分的体现的scala语言的优势和巨大的简洁性和高效性,
下面我用了5种方法实现九九乘法表。
使用类似于java,c++等指令风格的的编程实现,源码如下:
//这里打印倒向九九乘法口诀表
/*指令风格的编程实现九九乘法表*/
def printMultiTable() {
var i = 1 //这里只有i在作用范围内
while (i <= 9) {
var j = i //这里只有i和j在作用范围内
while (j <= 9) {
val prod = (i * j).toString() //这里只有i和j和prod在作用范围内
var k = prod.length() //这里只有i和j和prod和k在作用范围内
while (k < 4) {
print(" ")
k += 1
}
print(i + "*" + j + "=" + prod)
j += 1
}
// i和j让在作用范围内,但是k已经不在作用范围内。
println()
i += 1
}
//i仍在范围内,j,prod,和k脱离了范围
}
执行的结果如下:
1*1=1 1*2=2 1*3=3 1*4=4 1*5=5 1*6=6 1*7=7 1*8=8 1*9=9
2*2=4 2*3=6 2*4=8 2*5=10 2*6=12 2*7=14 2*8=16 2*9=18
3*3=9 3*4=12 3*5=15 3*6=18 3*7=21 3*8=24 3*9=27
4*4=16 4*5=20 4*6=24 4*7=28 4*8=32 4*9=36
5*5=25 5*6=30 5*7=35 5*8=40 5*9=45
6*6=36 6*7=42 6*8=48 6*9=54
7*7=49 7*8=56 7*9=63
8*8=64 8*9=72
9*9=81
发现是倒向的乘法口诀,
下面我们修改代码打印一个正向的九九乘法表,关键在while(j <=i) 这个条件。
/**
* 打印正向的九九乘法表
*/
def printMultiTable2() {
var i = 1 //这里只有i在作用范围内
while (i <= 9) {
var j = 1 //这里只有i和j在作用范围内
while (j <= i) {
val prod = (i * j).toString() //这里只有i和j和prod在作用范围内
var k = prod.length() //这里只有i和j和prod和k在作用范围内
while (k < 4) {
print(" ")
k += 1
}
print(j + "*" + i + "=" + prod)
j += 1
}
// i和j让在作用范围内,但是k已经不在作用范围内。
println()
i += 1
}
//i仍在范围内,j,prod,和k脱离了范围
}
执行结果如下:
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
scala的语法简洁性,和函数式的风格,我们可以使用函数风格实现该功能发现代码量会减少很多,逻辑也更加清晰:
源码如下:
//打印:打印乘法口诀发
def makeRowSeq(row: Int) =
for (col <- 1 to row) yield {
val prod = (row * col).toString()
val padding = " " * (4 - prod.length())
col + "*" + row + "=" + prod + padding
}
def makeRow(row: Int) = makeRowSeq(row).mkString
/*函数风格的编程实现九九乘法表*/
def multiTable() = {
val tableSeq = for (row <- 1 to 9) yield makeRow(row)
println(tableSeq.mkString("\n"))
}
执行结果如下:
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
使用scala的for循环嵌套的方式实现该功能,代码可以更加简洁,只需要5,6行代码即可实现,
充分体现了scala的语言的强大性。
def multiTable2() = {
for(row <- 1 to 9 ; col <- 1 to row){
val prod = (row * col).toString()
val padding = " " * (4 - prod.length())
print(col + "*" + row + "=" + prod + padding)
if(row == col) println()
}
}
执行结果如下:
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
可以使用for嵌套循环和scala的s()方法,使实现更加简单,scala果然博大精深,
源码如下:
def multiTable3 = {
(
for (
i <- 1 to 9;
j <- 1 to i;
ss = s"$j*$i=${i * j}\t"
) yield {
if (j == i) s"$ss\n" else ss
}).foreach(print);
}
执行结果如下:
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