星级:*****
1、顺时针打印矩阵
(学习视频分享:java课程)
【题目】
立即学习“Java免费学习笔记(深入)”;
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下 4 X 4 矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印出数字 1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.
【代码】
public ArrayList登录后复制printMatrix(int [][] matrix) { int width,height,x,y,count,n; height = matrix.length; width = matrix[0].length; // 遍历游标 x = 0; y = 0; count = 0; // 元素个数 n = height * width; boolean[][] flag = new boolean[height][width]; ArrayList list = new ArrayList(); while (count =0 && !flag[x][y]) { list.add(matrix[x][y]); flag[x][y] = true; count ++; y--; } y++; x--; // x变少,y不变 while (x>=0 && !flag[x][y]) { list.add(matrix[x][y]); flag[x][y] = true; count ++; x--; } x++; y++; } return list; }
【思考】
需要注意边界是否越界以及,游标(x,y)经过x++或者y++之后,定位在什么地方,需要进行手动的转弯。
2、数组中出现次数超过一半的数字
【题目】
立即学习“Java免费学习笔记(深入)”;
数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为 9 的数组 {1,2,3,2,2,2,5,4,2}。由于数字 2 在数组中出现了 5 次,超过数组长度的一半,因此输出 2。如果不存在则输出 0。
【代码】
package swear2offer.array; import java.util.Arrays; public class Half { /** * 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。 * 例如输入一个长度为 9 的数组 {1,2,3,2,2,2,5,4,2}。 * 由于数字 2 在数组中出现了 5 次,超过数组长度的一半,因此输出 2。如果不存在则输出 0。 * */ public int MoreThanHalfNum_Solution(int [] array) { int n,count,i,k; n = array.length; if (n == 0) return 0; if (n == 1) return array[0]; // 标记数组 int[] flag = new int[n]; // 给数组排序 Arrays.sort(array); count = 1; flag[0] = 1; for (i=1; i登录后复制n/2 ? array[k] : 0; } }
(相关面试题推荐:java面试题及答案)
【代码2】
不需要的排序的巧妙方法:
用 preValue 记录上一次访问的值,count 表明当前值出现的次数,如果下一个值和当前值相同那么 count++;如果不同 count–,减到 0 的时候就要更换新的 preValue 值了,因为如果存在超过数组长度一半的值,那么最后 preValue 一定会是该值。
public int MoreThanHalfNum_Solution(int [] array) { if(array == null || array.length == 0)return 0; int preValue = array[0];//用来记录上一次的记录 int count = 1;//preValue出现的次数(相减之后) for(int i = 1; i array.length/2)?preValue:0; }登录后复制
【思考】
当i从1而不是0开始的时候,通常需要特殊考虑只有一个元素的情况
3、连续子数组的最大和
【题目】
立即学习“Java免费学习笔记(深入)”;
给一个数组,返回它的最大连续子序列的和,例如:{6,-3,-2,7,-15,1,2,2}, 连续子向量的最大和为 8 (从第 0 个开始,到第 3 个为止)
【代码】
/** * 给一个数组,返回它的最大连续子序列的和 * * 例如:{6,-3,-2,7,-15,1,2,2}, 连续子向量的最大和为 8 (从第 0 个开始,到第 3 个为止) * * 非常典型的dp * * 动规通常分为顺推和逆推两个不同的方向 * 要素:边界,状态转移公式,数组代表含义 * array[] * dp[x],从各个正数开始连续到达x时,最大和,即连续子序列的最大和 * 需要注意:1.从第一个正数开始,2.是连续序列 * 通常情况下,连续序列的复杂度为O(n),非连续序列为O(n*n) * */ public int FindGreatestSumOfSubArray(int[] array) { int n,i,len,res; int[] dp; n = array.length; if (n == 0 || array == null) return 0; if (n == 1) return array[0]; dp = new int[n]; dp[0] = array[0]; len = 0; res = array[0]; for (i=1; i【思路】
从前往后遍历,最大的连续子序列的和是由当前元素和之前的最大连续子序列的和叠加在一起形成的。如果之前的最大连续子序列的和大于零,我们可以继续累加,如果小于零,则需要舍去之前的子序列,重新从当前的数字开始累加。时间复杂度为 O (n)
4、整数中 1 出现的次数
【题目】
立即学习“Java免费学习笔记(深入)”;
求出 1~13 的整数中 1 出现的次数,并算出 100~1300 的整数中 1 出现的次数?为此他特别数了一下 1~13 中包含 1 的数字有 1、10、11、12、13 因此共出现 6 次,但是对于后面问题他就没辙了。ACMer 希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中 1 出现的次数(从 1 到 n 中 1 出现的次数)。
【代码】
public int NumberOf1Between1AndN_Solution(int n) { if (n == 1) return 1; int nCount,i,j; nCount = 0; for (i=1; i 0) { if (j == 1) nCount++; j = j/10; } } return nCount; }登录后复制【思考】
不要用递归写,最简单的循环即可
5、丑数
【题目】
立即学习“Java免费学习笔记(深入)”;
把只包含质因子 2、3 和 5 的数称作丑数(Ugly Number)。例如 6、8 都是丑数,但 14 不是,因为它包含质因子 7。 习惯上我们把 1 当做是第一个丑数。求按从小到大的顺序的第 N 个丑数。
【代码】
/** * 把只包含质因子 2、3 和 5 的数称作丑数(Ugly Number)。 * 例如 6、8 都是丑数,但 14 不是,因为它包含质因子 7。 * 习惯上我们把 1 当做是第一个丑数。求按从小到大的顺序的第 N 个丑数。 * * 从已有的丑数中选取一个,分别*2,*3,*5,再取最小的 * 最小的索引++,并赋值 * */ public int GetUglyNumber_Solution(int index) { if (index == 0) return 0; int p2,p3,p5,i,temp; p2 = p3 = p5 = 0; int[] res = new int[index]; res[0] = 1; for (i=1; i登录后复制【思考】
当特定某些性质的数列排序时,可以考虑这种方法。
相关推荐:java入门
以上就是java面试中常见的数组题目汇总(三)的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » java面试中常见的数组题目汇总(三)
发表评论 取消回复