俄罗斯方块
程序员文章站
2024-01-06 17:05:28
链接:https://www.nowcoder.com/questionTerminal/9407e24a70b04fedba4ab3bd3ae29704?orderByHotValue=1&questionTypes=000100&mutiTagIds=592&page=1&onlyReference=false来源:牛客网小易有一个古老的游戏机,上面有着经典的游戏俄罗斯方块。因为它比较古老,所以规则和一般的俄罗斯方块不同。荧幕上一共有 n 列,每次都会有一个 1 x...
链接:https://www.nowcoder.com/questionTerminal/9407e24a70b04fedba4ab3bd3ae29704?orderByHotValue=1&questionTypes=000100&mutiTagIds=592&page=1&onlyReference=false
来源:牛客网
小易有一个古老的游戏机,上面有着经典的游戏俄罗斯方块。因为它比较古老,所以规则和一般的俄罗斯方块不同。
荧幕上一共有 n 列,每次都会有一个 1 x 1 的方块随机落下,在同一列中,后落下的方块会叠在先前的方块之上,当一整行方块都被占满时,这一行会被消去,并得到1分。
有一天,小易又开了一局游戏,当玩到第 m 个方块落下时他觉得太无聊就关掉了,小易希望你告诉他这局游戏他获得的分数。
import java.util.Scanner;
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int m = sc.nextInt();
int [] nums = new int[m];
for(int i = 0; i < m; i++){
nums[i] = sc.nextInt();
}
System.out.println(getScore(n,m,nums));
sc.close();
}
//用一维数组模拟二维数组,一维数组存方块的高度,找出最小的即为分数
public static int getScore(int n, int m, int nums[]){
int [] s = new int[n + 1];//默认初始化为0
for(int i = 0; i < m; i++){
s[ nums[i] ]++;
}
Arrays.sort(s);
return s[1];
}
}
本文地址:https://blog.csdn.net/qq_43515131/article/details/107314873