Scala、Java 50道编程题

⚠️ 不保证题解的正确性!

1、有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
def main(args: Array[String]): Unit = {
    var x = 30
    val arr = new Array[Int](x)
    arr(0) = 1 ; arr(1) = 1
    for(i <- 2 to x-1){
      arr(i) = arr(i-1) + arr(i-2)
      println(s"第 ${i+1} 月的兔子数为:${arr(i)} 只")
    }
}
输出:
第 3 月的兔子数为:2 只
第 4 月的兔子数为:3 只
第 5 月的兔子数为:5 只
第 6 月的兔子数为:8 只
第 7 月的兔子数为:13 只
第 8 月的兔子数为:21 只
第 9 月的兔子数为:34 只
第 10 月的兔子数为:55 只
第 11 月的兔子数为:89 只
第 12 月的兔子数为:144 只
第 13 月的兔子数为:233 只
第 14 月的兔子数为:377 只
第 15 月的兔子数为:610 只
第 16 月的兔子数为:987 只
第 17 月的兔子数为:1597 只
第 18 月的兔子数为:2584 只
第 19 月的兔子数为:4181 只
第 20 月的兔子数为:6765 只
第 21 月的兔子数为:10946 只
第 22 月的兔子数为:17711 只
第 23 月的兔子数为:28657 只
第 24 月的兔子数为:46368 只
第 25 月的兔子数为:75025 只
第 26 月的兔子数为:121393 只
第 27 月的兔子数为:196418 只
第 28 月的兔子数为:317811 只
第 29 月的兔子数为:514229 只
第 30 月的兔子数为:832040 只
2、判断101-200之间有多少个素数,并输出所有素数。素数又叫质数,就是除了1和它本身之外,再也没有整数能被它整除的数。也就是素数只有两个因子。
def main(args: Array[String]): Unit = {
    for (i <- 101 to 200) {
      var flag = true
      for (j <- 2 to 9 if flag != false){
        if (i % j == 0) flag = false
      }
      if (flag) println(i)
    }
}
输出:
101
103
107
109
113
121
127
131
137
139
143
149
151
157
163
167
169
173
179
181
187
191
193
197
199
3、打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。想当年,做这些题都是网上找答案,如今事过境迁,不会也得会。
def main(args: Array[String]): Unit = {
    for (i <- 100 to 1000) {
        var a = i % 10; //123 % 10
        var b = i / 10 % 10; //12 % 10;
        var c = i / 10 / 10 % 10; //1 % 10
        if (Math.pow(a,3) + Math.pow(b,3) + Math.pow(c,3) == i) println(i)
    }
}
输出:
153
370
371
407
4、将一个正整数分解质因数。例如:输入90,打印出90=233*5。

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

def main(args: Array[String]): Unit = {
  var n = 90
  var k = 2
  print(s"${n}=")
  while (n != k) {
    if (n % k == 0) {
      print(s"${k}*")
      n = n / k
    } else {
      k = k + 1
    }
  }
  print(k)
}
输出:
90=2*3*3*5
5、利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
def main(args: Array[String]): Unit = {
  var score = 100
  if (score >= 90) {
    println("A")
  } else {
    if(score >= 60){
      println("B")
    } else {
      println("C")
    }
  }
}
输出:
A
6、输入两个正整数m和n,求其最大公约数和最小公倍数。
def main(args: Array[String]): Unit = {
  val x = 42
  val y = 36
  var sta: mutable.Stack[Int] = new mutable.Stack[Int]
  for (i <- 1 to x; if (x % i == 0 & y % i == 0)) sta.push(i)
  var i: Int = sta.pop()
  println(s"最大公约数为:$i")
  println(s"最小公倍数为:${x * y / i}")
}
输出:
最大公约数为:6
最小公倍数为:252
7、输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
def main(args: Array[String]): Unit = {
    var content: Array[Char] = ((new Scanner(System.in)).nextLine()).toCharArray
    var zm, kg, sz, qt = 0
    for (elem <- content) {
        if ('a' <= elem && elem <= 'z' || 'A' <= elem && elem <= 'Z')  zm += 1
        else if (' ' == elem )  kg += 1
        else if ('1' <= elem && elem <= '9')  sz += 1 else qt += 1
    }
    println(s"字母有 $zm 个\n空格有 $kg 个\n数字有 $sz 个\n其他字符有 $qt 个")
}
输入:
sghye356hf7456767632re;'wetet.';'wetye'tyye;'rw'wetry etew er
输出:
字母有 36 个
空格有 2 个
数字有 13 个
其他字符有 10 个
8、求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。
def main(args: Array[String]): Unit = {
  val x = 6
  var sum = 0
  var array: Array[String] = new Array[String](x)
  var str = String.valueOf(x)
  for (i <- 0 to x-1){
    array(i) = s"${x}" * (i+1)
  }
  for (elem <- array) {
    sum += Integer.valueOf(elem)
  }
  println(sum)
}
输出:
740736
9、一个数如果恰好等于它的因子之和,这个数就称为"完数"。例如6=1+2+3.编程 找出1000以内的所有完数
def main(args: Array[String]): Unit = {
    var sum = 0
    for (x <- 1 to 1000) {
        for (y <- 1 to x) {
            if (x % y == 0) sum += y
        }
        if (sum - x == x) println(x)
        sum = 0
    }	
}
输出:
6
28
496
10、一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在 第10次落地时,共经过多少米?第10次反弹多高?
def main(args: Array[String]): Unit = {
    var sum, high: Double = 100
    for (x <- 2 to 10) {
        high = high / 2
        sum += high * 2
    }
    println(s"共经过 ${sum} 米")
    println(s"第 ${10} 次反弹的高多为 ${high}")
}
输出:
共经过 299.609375 米
第 10 次反弹的高多为 0.1953125
11、有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
def main(args: Array[String]): Unit = {
    var arr = Array(1, 2, 3, 4)
    var count = 0
    for (x <- 1 to 4;
         y <- 1 to 4;
         z <- 1 to 4) {
        if (x!=y && x!=z && y!=z){
            count += 1
            println(s"$x$y$z")
        }
    }
    println(s"一共有 $count 种")
}
输出:
123
124
132
134
142
143
213
214
231
234
241
243
312
314
321
324
341
342
412
413
421
423
431
432
一共有 24 种
12、企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可 提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
def main(args: Array[String]): Unit = {
    var profit: Double = 123456
    var bonus: Double = 0.00

    if (profit <= 100000) {
        bonus = profit * 0.1
    } else if (profit < 200000) {
        bonus = 10000 + (profit - 100000) * 0.075
    } else if (profit < 400000) {
        bonus = 17500 + (profit - 200000) * 0.05
    } else if (profit < 600000) {
        bonus = 27500 + (profit - 400000) * 0.03
    } else if (profit < 1000000) {
        bonus = 33500 + (profit - 600000) * 0.015
    } else {
        bonus = 36500 + (profit - 1000000) * 0.01
    }
    println(s"发放奖金为 $bonus ¥")
}
输出:
发放奖金为 11759.2 ¥
13、一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
def main(args: Array[String]): Unit = {
    var x = 0
    var flag = true
    while (flag) {
        x += 1
        if (math.sqrt(x + 100) % 1 == 0 && math.sqrt(x + 268) % 1 == 0) flag = false
    }
    println(s"这个数为:$x")
}
输出:
这个数为:21
14、输入某年某月某日,判断这一天是这一年的第几天?
def main(args: Array[String]): Unit = {
    var content = new Scanner(System.in)
    var year = content.nextInt()
    var month = content.nextInt()
    var days = content.nextInt()
    var Feb = 28
    if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) Feb = 29
    //    days = (month / 2: Int) * 31 + (month / 2 - 1: Int) * 30 + days + Feb
    var arr = Array(0,31,Feb,31,30,31,30,31,31,30,31,30)
    for (i <- 0 to month-1){
        days += arr(i)
    }
    println(s"这一天是该年的第 $days 天!")
}
输入:
2021 12 6
输出:
这一天是该年的第 340 天!
15、输入三个整数x,y,z,请把这三个数由小到大输出。
def main(args: Array[String]): Unit = {
    println("请输入三个数 x、y、z :")
    var sc = new Scanner(System.in)
    var map = SortedMap(sc.nextInt() -> "x", sc.nextInt() -> "y", sc.nextInt() -> "z")
    for (elem <- map) {
        print(elem._2 + " ")
    }
}
输入:
请输入三个数 x、y、z :
5 3 7
输出:
y x z 
16、输出9*9口诀。
def main(args: Array[String]): Unit = {
    for (i <- 1 to 9; j <- 1 to i) {
        print(s"${i}*${j}=${i * j}\t")
        if (i == j) println()
    }
}
输出:
1*1=1	
2*1=2	2*2=4	
3*1=3	3*2=6	3*3=9	
4*1=4	4*2=8	4*3=12	4*4=16	
5*1=5	5*2=10	5*3=15	5*4=20	5*5=25	
6*1=6	6*2=12	6*3=18	6*4=24	6*5=30	6*6=36	
7*1=7	7*2=14	7*3=21	7*4=28	7*5=35	7*6=42	7*7=49	
8*1=8	8*2=16	8*3=24	8*4=32	8*5=40	8*6=48	8*7=56	8*8=64	
9*1=9	9*2=18	9*3=27	9*4=36	9*5=45	9*6=54	9*7=63	9*8=72	9*9=81
17、猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个 第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。
def main(args: Array[String]): Unit = {
    var count = 1
    var days = 10
    for (i <- 1 to days - 1) {
        count = 2 * (count + 1)
    }
    println(s"第一天一共摘了 ${count} 个")
}
输出:
第一天一共摘了 1534 个
18、两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向 队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。
def main(args: Array[String]): Unit = {
    for (a: Char <- 'x' to 'z') {
        for (b: Char <- 'x' to 'z') {
            for (c: Char <- 'x' to 'z') {
                if (a != 'x' && c != 'x' && c != 'z' && a != b && a != c && b != c) {
                    println(s" a -> ${a}")
                    println(s" b -> ${b}")
                    println(s" c -> ${c}")
                }
            }
        }
    }
}
输出:
 a -> z
 b -> x
 c -> y
19、打印出如下图案(菱形)
    *
   ***
 ******
********
 ******
   ***
    *
def main(args: Array[String]): Unit = {
    var num = 4
    for (i <- 1 to num) {
        for (x <- 1 to num - i) print(" ")
        for (y <- 1 to 2 * i - 1) print("*")
        println()
    }
    for (i <- 1 to num - 1 reverse){
        for (x <- 1 to num - i) print(" ")
        for (y <- 1 to 2 * i - 1) print("*")
        println()
    }
}
输出:
   *
  ***
 *****
*******
 *****
  ***
   *
20、有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。
def main(args: Array[String]): Unit = {
    var num = 20
    var fz:Double = 2
    var fm:Double = 1
    var tmp, sum:Double = 0
    for (i <- 1 to num) {
        sum =  sum + fz / fm
        tmp = fz
        fz = fz + fm
        fm = tmp
    }
    println(sum)
}
输出:
32.66026079864164
21、求1+2!+3!+…+20!的和
def main(args: Array[String]): Unit = {
    var num = 20
    var sum: Long = 0
    var tmp: Long = 1
    for (j <- 1 to num) {
        tmp = tmp * j
        sum += tmp
    }
    println(sum)
}
输出:
2561327494111820313
22、利用递归方法求5!。
def main(args: Array[String]): Unit = {
    def f(n: Int): Int = {
        if (n == 1) return 1
        return n*f(n-1)
    }
    println(f(5))
}
输出:
120
23、有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?
def main(args: Array[String]): Unit = {
  def f(age: Int):Int= if(age == 1) return 10 else return f(age-1) + 2
  print(s"第五个人 ${f(5)} 岁")
}
输出:
第五个人 18 岁
24、给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。
def main(args: Array[String]): Unit = {
    var sc = (new Scanner(System.in)).next()
    print(s"这是一个 ${sc.length} 位数 \n逆序为:")
    for (i <- 0 to sc.length - 1 reverse) print(sc(i))
}
输入:
47847
输出:
这是一个 5 位数 
逆序为:74874
25、一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。
def main(args: Array[String]): Unit = {
    var sc = (new Scanner(System.in)).next()
    for (i <- 0 to sc.length - 1) {
        if (sc(0) != sc(sc.length - 1 - i)) {
            print("不是回文")
            return 0
        } else {
            print("是回文")
            return 0
        }
    }
}
输入:
asdfdsa
输出:
是回文
26、请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续 判断第二个字母。
def main(args: Array[String]): Unit = {
    var week = Map("m" -> "星期一", "tu" -> "星期二", "w" -> "星期三", "th" -> "星期四", "f" -> "星期五", "sa" -> "星期六", "su" -> "星期日")
    var sc = (new Scanner(System.in)).next().toLowerCase()
    print(week.getOrElse(sc, "输入错误"))
}
输入:
Tu
输出:
星期二
27、求100之内的素数
def main(args: Array[String]): Unit = {
    println("1\n2")
    for (i <- 2 to 100) {
        var flag = true
        for (j <- 2 to i) {
            if (i % j == 0) flag = false
            if (j == i - 1 && flag) println(i);
        }
    }
}
输出:
1
2
3
5
7
11
13
17
19
23
29
31
37
41
43
47
53
59
61
67
71
73
79
83
89
97
28、对10个数进行排序
def main(args: Array[String]): Unit = {
    var arr = Array(23, 62, 74, 235, 58, 23, 78, 34, 34, 73)
    var tmp = 0
    for (i <- 0 until arr.length - 1; j <- 0 until arr.length - 1 - i) {
        if (arr(j) > arr(j + 1)) {
            tmp = arr(j)
            arr(j) = arr(j + 1)
            arr(j + 1) = tmp
        }
    }
    println(arr.toList)
}
输出:
List(23, 23, 34, 34, 58, 62, 73, 74, 78, 235)
29、求一个3*3矩阵对角线元素之和
def main(args: Array[String]): Unit = {
    var arr: Array[Array[Int]] = Array.ofDim(3,3)
    for (i <- 0 to 2) {
        for ( j <- 0 to 2) {
            arr(i)(j) = j;
        }
    }
    for (i <- 0 to 2) {
        for ( j <- 0 to 2) {
            print(" " + arr(i)(j));
        }
        println();
    }
    var sum = 0
    for (i <- 0 to 2; j <- 0 to 2) {
        if (i == j || i == 2 - j) {
            sum += arr(i)(j)
        }
    }
    println(sum)
}
输出:
 0 1 2
 0 1 2
 0 1 2
5
30、有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
def main(args: Array[String]): Unit = {
    var num = 53
    var arr = ArrayBuffer[Int](23, 23, 34, 34, 58, 62, 73, 74, 78, 235)
    arr += 0
    var tmp = 0
    Breaks.breakable(
        for (i <- 0 to arr.size-1 reverse) {
            arr(i) = arr(i-1)
            if (num > arr(i)){
                arr(i) = num
                Breaks.break()
            }
        }
    )
    println(arr.toList)
}
输出:
List(23, 23, 34, 34, 53, 58, 62, 73, 74, 78, 235)
31、将一个数组逆序输出。
def main(args: Array[String]): Unit = {
    var arr = Array[Int](23, 23, 34, 34, 58, 62, 73, 74, 78, 235)
    for (i <- 0 to arr.size -1 reverse) {
        print("\t" + arr(i))
    }
}
输出;
235	78	74	73	62	58	34	34	23	23
32、取一个整数a从右端开始的4~7位。
def main(args: Array[String]): Unit = {
    var sc = (new Scanner(System.in)).next()
    print(sc.substring(sc.length-7,sc.length-3))
}
输入:
987345635
输出:
7345
33、打印出杨辉三角形(要求打印出10行如下图)
      1
     1 1
    1 2 1
   1 3 3 1
  1 4 6 4 1
1 5 10 10 5 1
def main(args: Array[String]): Unit = {
    var num = 6
    var arr = Array.ofDim[Int](num + 1, num + 1)
    for (i <- 1 to num) {
        for (j <- 1 to i) {
            if (j == 0 || j == i) arr(i)(j) = 1 else arr(i)(j) = arr(i - 1)(j) + arr(i - 1)(j - 1)
        }
    }
    for (x <- 1 to num) {
        print("\t"*(num-x))
        for (y <- 1 to num) {
            if (arr(x)(y) != 0) print(s"\t${arr(x)(y)}\t")
        }
        println()
    }
}
输出:
						1	
					1		1	
				1		2		1	
			1		3		3		1	
		1		4		6		4		1	
	1		5		10		10		5		1	
34、输入3个数a,b,c,按大小顺序输出。
def main(args: Array[String]): Unit = {
    println("请输入三个数 a、b、c:")
    var sc = new Scanner(System.in)
    var map = SortedMap(sc.nextInt() -> "a", sc.nextInt() -> "b", sc.nextInt() -> "c")
    map.foreach(elem => print(elem._2 + " "))
}
输入:
请输入三个数 a、b、c:
535 745 345
输出
c a b 
35、输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
def main(args: Array[String]): Unit = {
    var arr = Array(23, 62, 74, 235, 58, 68, 78, 36, 34, 73)

    var tmp = arr.max
    arr(arr.indexOf(arr.max)) = arr(0)
    arr(0) = tmp

    tmp = arr.min
    arr(arr.indexOf(arr.min)) = arr(arr.size - 1)
    arr(arr.size - 1) = tmp

    println(arr.toList)
}
输出:
List(235, 62, 74, 73, 58, 68, 78, 36, 34, 23)
36、有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
def main(args: Array[String]): Unit = {
    var arr = ArrayBuffer(1, 2, 3, 4, 5, 6, 7, 8, 9)
    var times = 3
    var num = 0
    for (i <- 0 to times - 1) {
        num = arr(0)
        for (j <- 0 to arr.size - 2) arr(j) = arr(j + 1)
        arr(arr.size - 1) = num
    }
    println(arr)
}
输出:
ArrayBuffer(4, 5, 6, 7, 8, 9, 1, 2, 3)
37、有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
def main(args: Array[String]): Unit = {
    var arr = ArrayBuffer[Int]()
    for (i <- 0 until 20) {
        arr += i + 1
    }

    /**
   *实现方法
   * @param array  传入的数组
   * @param start  首次开始的位置
   * @return
   */
    def f(array: ArrayBuffer[Int], start: Int): ArrayBuffer[Int] = {
        var tmp = ArrayBuffer[Int]()
        // 获取本轮叫到3的数
        for (i <- 0 to array.size - 1) if ((i + start) % 3 == 0) tmp += array(i)
        // 下一轮,第一个人叫的数
        var nextStart = (array.size - 1 - array.indexOf(tmp.last)) + 1
        // 去除本轮叫到3的数
        for (elem <- tmp) array -= elem
        // 判断剩余,并递归
        if (arr.size > 2) f(array, nextStart) else return array
    }

    arr = f(arr, 1)
    arr.foreach(println)

}
输出
13
20
38、写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。
def main(args: Array[String]): Unit = {

    var str = (new Scanner(System.in)).next()
    def f(str: String):Int = return str.length
    print(s"字符串的长度为: ${f(str)}")
}
输入:
ykhghgewtry
输出:
字符串的长度为: 11
39、编写一个函数,输入n为偶数时,调用函数求1/2+1/4+…+1/n,当输入n为奇数时,调用函数1/1+1/3+…+1/n(利用指针函数)
def main(args: Array[String]): Unit = {

    var num = (new Scanner(System.in)).nextInt()

    def f(num: Int): Double = {
        var sum: Double = 0.00
        if (num % 2 == 0) {
            for (i <- 2 to num) if (i % 2 == 0) sum += (1 / i.toDouble)
        } else {
            for (i <- 1 to num) if (i % 2 != 0) sum += (1 / i.toDouble)
        }
        return sum
    }
    var res = f(num)
    println(s"结果为: $res ")
}
输入:
6
输出:
结果为: 0.9166666666666666 
40、字符串排序。
def main(args: Array[String]): Unit = {
    var charArr = new Scanner(System.in).next().toCharArray
    var tmp = ' '
    for (i <- 0 until  charArr.size - 1; j <- 0 until  charArr.size - 1 - i) {
        if (charArr(j) > charArr(j + 1)) {
            tmp = charArr(j)
            charArr(j) = charArr(j+1)
            charArr(j+1) = tmp
        }
    }
    println(charArr.toList)
}
输入:
weyrhdf
输出:
List(d, e, f, h, r, w, y)
41、海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子?
public static void main(String[] args) {
    System.out.println(s(10));

}
static int s(int i){
    int u=i;
    for(int x=0;x<5;x++){
        if(i%5!=1)
            return s(u+1);
        i=(i-1)/5*4;
    }
    return u;
}
输出:
3121
42、809*??=800*??+9*??+1 其中??代表的两位数,8*??的结果为两位数,9*??的结果为3位数。求??代表的两位数,及809*??后的结果。
def main(args: Array[String]): Unit = {
    for (i <- 10 to 13) {
        if (8 * i < 100
            && 9 * i >= 100
            && 9 * i < 1000
            && 809 * i == 800 * i + 9 * i + 1) {
            print(s"该数为 ${i}, 809*??=${809 * i}")
        }
        else {
            print("无解!")
        }
    }
}
输出:
无解!无解!无解!
43、求0—7所能组成的奇数个数。
def main(args: Array[String]): Unit = {

    // 一位数的奇数有四种 1,3,5,7
    var count = 4

    def f(num: Int): Int = {
        var res = 1
        for (i <- 1 to num) {
            res *= i
        }
        return res
    }

    for (i <- 2 to 8) {
        count += ((f(7) / f(8 - i) - f(6) / f(8 - i)) * 4)
    }
    println(s"0—7所能组成的奇数个数为:$count ")
}
输出:
0—7所能组成的奇数个数为:46972 
44、一个偶数总能表示为两个素数之和。
def main(args: Array[String]): Unit = {
    var num = new Scanner(System.in).nextInt()
    var arr = new ArrayBuffer[Int]
    for (i <- 2 to num) {
        var flag = true
        for (j <- 2 to i) {
            if (i % j == 0) flag = false
            if (j == i - 1 && flag) {
                arr += i
            }
        }
    }
    for (elem1 <- arr; elem2 <- arr) {
        if (elem1 + elem2 == num) {
            println(s"${num} 次数可表示为: ${elem1} + ${elem2} ")
        }
    }
}
输入:
78
输出:
78 次数可表示为: 5 + 73 
78 次数可表示为: 7 + 71 
78 次数可表示为: 11 + 67 
78 次数可表示为: 17 + 61 
78 次数可表示为: 19 + 59 
78 次数可表示为: 31 + 47 
78 次数可表示为: 37 + 41 
78 次数可表示为: 41 + 37 
78 次数可表示为: 47 + 31 
78 次数可表示为: 59 + 19 
78 次数可表示为: 61 + 17 
78 次数可表示为: 67 + 11 
78 次数可表示为: 71 + 7 
78 次数可表示为: 73 + 5 
45、判断一个素数能被几个9整除
def main(args: Array[String]): Unit = {
    var num = new Scanner(System.in).nextInt()
    var res:Int = num / 9
    print(s"该数能被 ${res} 个9整除")
}
输入:
74
输出:
该数能被 8 个9整除
46、两个字符串连接程序
def main(args: Array[String]): Unit = {
    var str = new Scanner(System.in)
    print(s"连接后为: ${str.next() + str.next()}")
}
输入:
sef etyr
输出:
连接后为: sefetyr
47、读取7个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*。
def main(args: Array[String]): Unit = {
    for (i <- 1 to 7) {
        var num :Int= ( Math.random()*50).toInt
        println(s" ${num}  ${"*"*num}")
    }
}
输出:
 11  ***********
 9  *********
 28  ****************************
 24  ************************
 28  ****************************
 5  *****
 15  ***************
48、某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:每位数字都加上5,然后用和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。
def main(args: Array[String]): Unit = {
    println("请输入需要传递的数据:")
    var sc = new Scanner(System.in).next().toArray
    sc.map( _.toInt.+(5).%(10))
    .reverse
    .foreach(print)
}
输入:
请输入需要传递的数据:
1234
输出:
7654
49、计算字符串中子串出现的次数
def main(args: Array[String]): Unit = {
    var sc = new Scanner(System.in)
    var str, sub = sc.next()
    var count = 0
    for (i <- 0 to str.length - sub.length) {
        if (sub.equals(str.substring(i, sub.length + i))) count += 1
    }
    println(s"子串出现的次数为:$count ")
}
输入:
rtyhgadsrty rt
输出:
子串出现的次数为:2 
50、有五个学生,每个学生有3门课的成绩,从键盘输入以上数据(包括学生号,姓名,三门课成绩),计算出平均成绩,将原有的数据和计算出的平均分数存放在磁盘文件"stud"中。
def main(args: Array[String]): Unit = {

    var arr = new ArrayBuffer[Array[String]]
    var average_scores = new Array[Int](3)

    var sc = new Scanner(System.in)
    val stream = new FileOutputStream(new File("stud.txt"))

    println("请输入学号、姓名及三科成绩:")

    // 存储学生信息
    for (i <- 1 to 5) {
        var content = sc.nextLine()
        stream.write((content + "\n").getBytes)
        arr += content.split(" ")
    }
    // 计算平均成绩
    for (i <- 2 to arr(0).size - 1) {
        var souces = 0
        for (j <- 0 to arr.size - 1) souces += Integer.valueOf(arr(j)(i))
        average_scores(i - 2) = souces / 5
    }
    for (i <- 0 to average_scores.size - 1) stream.write((average_scores(i) + "\t").toString.getBytes())
    stream.close()
}
输入:
01 张三 45 84 63
02 李四 52 34 85
03 王五 74 75 64
04 赵六 74 58 85
05 阿七 85 45 75
输出:stud.txt
01 张三 45 84 63
02 李四 52 34 85
03 王五 74 75 64
04 赵六 74 58 85
05 阿七 85 45 75
66	59	74	

 


❤️ END ❤️
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JOEL-T99

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值