华为8.19编程题
一个公司做团建活动,排成1个M行N列的队形。左上角的同事编号为(0,0),右上角的同事编号为(M-1,N-1)。为了打散队伍重新分组。从队列左上角同事开始从1开始报数,最外圈的同事按顺时针报数。外圈同事全部报完,内圈的同事按同样规则继续报数。个位数为7且十位数为奇数被挑选出来作为特战队员。
请设计一个计算的方法,入参是两个大于等于10且小于等于1000的整数,M和N。
请按报数顺序输出特战队员的编号列表(N2的二维数组)。
输入描述:入参是两个整数M和N,值范围为:[10,1000],单空格分隔。
输出描述:请按报数顺序输出特战队员的编号列表(N2的二维数组),非法输入请返回内容为空的数组。
输入样例:10 10
输出样例:[[7,9],[1,1],[8,2],[7,5],[4,4]]
给出二叉树上每个节点的深度,请你计算满足条件的二叉树共有多少种。
输入描述:第一行包含一个整数N,表示二叉树上节点的数量(1<=N<=1000)。
输出描述:输出满足条件的二叉树数量,因为答案可能非常大,你只需要输出答案除以(10^9+7)后得到的余数。即如果最终答案为answer,你只需要输出answer mod(10^9+7)。
第二行包含N个整数,d1,d2,...,dN,表示每个节点的深度(0<=di<=N-1)。
输入样例:
4
1 0 2 2
输出样例:
2
使用一个字符串frame表明当前的方块状态;如“2122”,表明这个俄罗斯方块最多4列(“2122”的长度);并且第一列有2个方块,第二列有1个方块,第三列有2个方块,第四列有2个方块;另外一个字符串brick表示从上方下落的方块,如“121”;方块从高处下落,方块可能左右移动,但是不能旋转,不能超出边界;最终稳定落在frame的方块上面;如果某一行全部都有方块,那么这一行消除;计算这个方块下落稳定后,可能的最小未消行数;
其他说明:
1.本题下落方块都是向下凸出,向上凸出的方块不用考虑,也不可能存在空方块;
2.frame字符串中只会用一个字符表示方块的个数,可能个数范围为[0,9];
3.brick字符串中同样使用一个字符表示方块的个数,可能个数范围为[1,9]。
输入描述:两行字符串,第一行字符串表示frame,第二行表示brick;
输出描述:最小的未消行数
输入样例:
2202
2
输出样例:
0