Java经典算法大全
java 经典笔试算法题

java 经典笔试算法题一、排序算法1. 实现一个基于Java的快速排序算法。
答:快速排序是一种常用的排序算法,其核心思想是分治法。
首先选择一个基准元素,将数组分成两部分,一部分小于基准元素,一部分大于基准元素。
然后递归地对这两部分继续进行快速排序,直到整个数组有序。
2. 实现一个稳定的冒泡排序算法。
答:冒泡排序是一种简单的排序算法,通过重复地遍历待排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。
稳定的冒泡排序算法是指在排序过程中,相同元素的相对位置不会改变。
3. 实现一个选择排序算法。
答:选择排序是一种简单直观的排序算法。
其工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。
二、字符串操作算法1. 实现一个函数,将一个字符串反转。
答:可以使用StringBuilder类的reverse()方法来实现字符串的反转。
2. 实现一个函数,将一个字符串中的所有大写字母转换为小写字母,其余字符保持不变。
答:可以使用String类的replaceAll()方法和toLowerCase()方法来实现。
3. 实现一个函数,将一个字符串按空格分割成单词数组,并删除空字符串和null字符串。
答:可以使用split()方法和Java 8的流来处理。
三、数据结构算法1. 实现一个单向链表,并实现插入、删除、查找和打印链表的功能。
答:单向链表是一种常见的数据结构,可以通过定义节点类和链表类来实现。
插入、删除、查找和打印链表的功能可以通过相应的方法来实现。
2. 实现一个二叉搜索树(BST),并实现插入、查找、删除节点的功能。
答:二叉搜索树是一种常见的数据结构,它具有唯一的高度特性。
插入、查找和删除节点的功能可以通过相应的方法来实现,如左旋、右旋、递归等。
3. 实现一个哈希表(HashMap),并实现插入、查找和删除键值对的功能。
答:HashMap是一种基于哈希表的映射数据结构,它通过哈希码的方式将键映射到对应的值上。
JAVA经典算法50题(3)【面试+工作】

JAVA经典算法50题(3)【面试+工作】JAVA经典算法50题(3)【面试+工作】【程序21】题目:求1+2!+3!+...+20!的和。
1.程序分析:此程序只是把累加变成了累乘。
public class Demo21 {public static void main(String[] args) {long sum = 0;long fac = 1;for (int i = 1; i <= 20; i++) {fac = fac * i;sum += fac;}System.out.println(sum);}}【程序22】题目:利用递归方法求5!。
1.程序分析:递归公式:f(n)=f(n-1)*4!import java.util.Scanner;public class Demo22 {public static long fac(int n) {long value = 0;if (n == 1 || n == 0) {value = 1;} else if (n > 1) {value = n * fac(n - 1);}return value;}public static void main(String[] args) {System.out.println("请输入一个数:");Scanner in = new Scanner(System.in);int n = in.nextInt();System.out.println(n + "的阶乘为:" + fac(n));}}【程序23】题目:有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。
问第4个人岁数,他说比第3个人大2岁。
问第三个人,又说比第2人大两岁。
问第2个人,说比第一个人大两岁。
最后问第一个人,他说是10岁。
请问第五个人多大?1.程序分析:利用递归的方法,递归分为回推和递推两个阶段。
java中数学函数

java中数学函数Java中的数学函数是开发者们在编写数学计算程序和算法时必不可少的基础,提供了一系列常用的数学计算函数,能够方便、高效地实现数字计算和数据处理,包括基本数学操作、三角函数、指数和对数函数、绝对值、向上取整、向下取整、舍入等数值运算。
本文将围绕这些数学函数介绍Java中常用的数学运算方法,帮助读者深入学习和了解这一领域。
一、基本数学运算方法在Java中,基本数学运算是计算机程序中最重要和最基础的运算方法,常见的包括加减乘除、取模、幂次等运算,Java内置了许多基本数学运算的函数以支持开发者进行数值计算。
下面分别介绍几个常用的基本数学运算方法:1. 取模运算:取模运算符为%,用于计算两个数相除的余数。
示例代码:int a = 20;int b = 7;int remainder = a % b;System.out.println(remainder); 输出62. 幂次运算:幂次运算使用符号或者Math.pow() 函数进行计算。
示例代码:int base = 2;int exponent = 4;int result = (int) Math.pow(base, exponent);System.out.println(result); 输出16int result2 = base exponent;System.out.println(result2); 输出163. 四舍五入:四舍五入是将一个数值按照特定规则四舍五入到最接近的整数,可以使用Math.round()函数实现。
示例代码:double number = 3.45;long rounded = Math.round(number);System.out.println(rounded); 输出34. 随机数:在Java中,可以使用Math.random()函数生成一个0.0到1.0之间的随机数,也可以指定上、下界生成范围内的随机整数。
java 编程统计类算法

Java编程统计类算法介绍Java是一种强大的编程语言,它提供了丰富的编程工具和功能,用于解决各种不同的问题。
在Java编程中,统计类算法是一种很常用的方法,它可以帮助我们实现各种统计功能,例如求和、均值、众数、方差和绝对平均偏差等。
这些方法都是通过简单的数学公式实现的,所以很容易被理解和使用。
本文将对Java编程中的统计类算法进行简要介绍,同时提供一些Java代码示例,以帮助读者更好地理解和使用这些方法。
Java编程中常见的统计类算法包括以下几种:1. 求和:求和是统计类算法中最基础的一种,它可以帮助我们计算一组数据的总和。
在Java中,可以通过以下代码实现求和:```int sum = 0;for (int num : numbers) {sum += num;}```在上面的代码中,我们定义了一个变量sum,然后遍历numbers 数组中的每个元素,对其进行累加,最终将结果存储在sum中。
2. 均值:均值是指一组数据的平均值,它可以帮助我们了解数据的集中趋势。
在Java中,可以通过以下代码实现均值的计算:```double mean = 0;for (int num : numbers) {mean += num;}mean /= numbers.length;```在上面的代码中,我们首先定义了一个变量mean,然后遍历numbers数组中的每个元素,对其进行累加,最后除以numbers的长度,以计算出均值。
3. 众数:众数是指一组数据中出现次数最多的数。
在Java中,可以通过以下代码实现众数的计算:```int mode = numbers[0];int count = 0;for (int num : numbers) {if (num == mode) {count++;} else {if (count > 0) {mode = num;}}}```在上面的代码中,我们首先将numbers[0]作为初始值设置为众数,然后遍历numbers数组中的每个元素。
java算法总结

java算法总结一、排序1、冒泡排序:t冒泡排序是一种简单的排序算法,它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。
走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
2、选择排序:t选择排序是一种简单直观的排序算法,无论什么数据进去都是O(n)的时间复杂度。
所以用到它的时候,数据规模越小越好。
唯一的好处可能就是不占用额外的内存空间了吧。
3、插入排序:t插入排序(Insertion-Sort)的算法描述是一种简单直观的排序算法。
它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
4、希尔排序:t希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。
希尔排序是非稳定排序算法。
该方法的基本思想是:先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录“基本有序”时,再对全体记录进行依次直接插入排序。
二、查找1、线性查找:t线性查找又称顺序查找,是一种最简单的查找算法。
从数据结构线形表的一端开始,顺序扫描,依次将扫描到的结点关键字与给定值k相比较,若相等则查找成功;若扫描结束仍没有找到关键字等于k的结点,则表示表中不存在关键字等于k的结点,查找失败。
2、二分查找:t二分查找又称折半查找,要求待查找的序列有序。
每次取中间位置的值与待查关键字比较,如果中间位置的值更大,则在前半部分循环这个查找的过程,如果中间位置的值更小,则在后半部分循环这个查找的过程。
3、二叉查找树:t二叉查找树(Binary Search Tree,简称BST),又被称为二叉搜索树、有序二叉树。
它是一棵空树或者是具有下列性质的二叉树:若任意节点的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若任意节点的右子树不空,则右子树上所有结点的值均大于它的根结点的值;任意节点的左、右子树也分别为二叉查找树;没有键值相等的节点三、字符串处理1、KMP算法:tKMP算法是由Donald E.Knuth、Vaughn R. Pratt和James H.Morris三人于1977年提出的一种改进的字符串匹配算法,它利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。
JAVA经典算法案例(42个)

t=t*10+n;
s=s+t;
System.out.println(t);
}
System.out.println(s);
//下面的方法是求出最大公约数 public static int gcd(int m, int n) { while (true) { if ((m = m % n) == 0) return n; if ((n = n % m) == 0) return m; } } public static void main(String args[]) throws Exception { //取得输入值 //Scanner chin = new Scanner(System.in); //int a = chin.nextInt(), b = chin.nextInt(); int a=23; int b=32; int c = gcd(a, b); System.out.println("最小公倍数:" + a * b / c + "\n最大公约数:" + c); } } 【程序 7】 题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。 1.程序分析:利用 while 语句,条件为输入的字符不为 '\n '. import java.util.Scanner; public class ex7 {
学习编程的十大经典算法

学习编程的十大经典算法学习编程是现代社会中一个非常重要的技能,而掌握经典算法是成为一个优秀的程序员的必备条件之一。
下面将介绍十大经典算法,详细解释它们的原理和应用。
1. 二分查找算法(Binary Search)二分查找算法是一种在有序数组中快速查找特定元素的算法。
它将查找范围不断缩小一半,直到找到目标元素或确定目标元素不存在。
二分查找算法的时间复杂度为O(log n)。
2. 冒泡排序算法(Bubble Sort)冒泡排序算法是一种简单但效率较低的排序算法。
它通过多次遍历数组,将相邻的元素进行比较并交换位置,使得较大(或较小)的元素逐渐移动到数组的末尾。
冒泡排序的时间复杂度为O(n^2)。
3. 快速排序算法(Quick Sort)快速排序算法是一种高效的排序算法。
它通过选择一个基准元素,将数组分为左右两个子数组,并对子数组进行递归排序。
快速排序算法的时间复杂度为O(n log n),在大多数情况下具有较好的性能。
4. 归并排序算法(Merge Sort)归并排序算法是一种分治思想的排序算法。
它将数组一分为二,递归地对子数组进行排序,然后将排好序的子数组合并成一个有序的数组。
归并排序算法的时间复杂度为O(n log n),稳定且适用于大规模数据的排序。
5. 插入排序算法(Insertion Sort)插入排序算法是一种简单且稳定的排序算法。
它通过将未排序的元素逐个插入已排序的序列中,以达到整体有序的目的。
插入排序的时间复杂度为O(n^2),但对于小规模数据或基本有序的数组,插入排序具有较好的性能。
6. 选择排序算法(Selection Sort)选择排序算法是一种简单但效率较低的排序算法。
它通过多次遍历数组,选择出最小(或最大)的元素,并放置到已排序的序列中。
选择排序的时间复杂度为O(n^2),但它适用于小规模数据或交换成本较高的情况。
7. 堆排序算法(Heap Sort)堆排序算法是一种高效的排序算法。
java面试题经典算法

java面试题经典算法经典算法在Java面试中经常被问及,因为它们可以展示面试者对基本数据结构和算法的理解程度。
以下是一些经典算法,我会逐个介绍它们。
1. 冒泡排序(Bubble Sort),这是一种简单的排序算法,它重复地走访要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。
时间复杂度为O(n^2)。
2. 快速排序(Quick Sort),快速排序使用分治法策略来把一个序列分为两个子序列。
它是一种分而治之的算法,时间复杂度为O(nlogn)。
3. 二分查找(Binary Search),二分查找是一种在有序数组中查找某一特定元素的搜索算法。
时间复杂度为O(logn)。
4. 递归算法(Recursion),递归是指在函数的定义中使用函数自身的方法。
递归算法通常用于解决可以被分解为相同问题的子问题的情况。
5. 动态规划(Dynamic Programming),动态规划是一种在数学、计算机科学和经济学中使用的一种方法。
它将问题分解为相互重叠的子问题,通过解决子问题的方式来解决原始问题。
6. 深度优先搜索(Depth-First Search)和广度优先搜索(Breadth-First Search),这两种搜索算法通常用于图的遍历和搜索。
深度优先搜索使用栈来实现,而广度优先搜索则使用队列来实现。
以上是一些常见的经典算法,当然还有很多其他的算法,如贪心算法、Dijkstra算法、KMP算法等等。
在面试中,除了了解这些算法的原理和实现方式之外,还需要能够分析算法的时间复杂度、空间复杂度以及适用场景等方面的知识。
希望这些信息能够帮助你在Java面试中更好地准备算法相关的问题。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Java经典问题算法大全/*【程序1】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析:兔子的规律为数列1,1,2,3,5,8,13,21....*/package .flywater.FiftyAlgorthm;public class FirstRabbit {public static final int MONTH = 15;public static vo id main(String[] args) {long f1 = 1L, f2 = 1L;long f;for(int i=3; i<MONTH; i++) {f = f2;f2 = f1 + f2;f1 = f;System.out.print("第" + i +"个月的兔子对数: ");System.out.println(" " + f2);}}}/*【程序2】* 作者若水飞天题目:判断101-200之间有多少个素数,并输出所有素数。
1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。
*/package .flywater.FiftyAlgorthm;public class SecondPrimeNumber {public static int count = 0;public static void main(String[] args) {for(int i=101;i<200;i++){boolean b = true;//默认此数就素数for(int j=2;j<=Math.sqrt(i);j++){if(i%j==0){b = false; //此数不是素数break;}}if(b){count++;System.out.print(i+" ");}}System.out.println("\n素数的个数:"+count);}}/*【程序3】作者若水飞天题目:打印出所有的"水仙花数(narcissus number)",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
*/ package .flywater.FiftyAlgorthm;public class ThirdNarcissusNum {static int b, bb, bbb;public static void main(String[] args) {for(int num=101; num<1000; num++) {ThirdNarcissusNum tnn = new ThirdNarcissusNum();tnn.f(num);}}public void f(int m) {bbb = m / 100;bb = (m % 100) / 10;b = (m % 100) % 10;if((bbb * bbb * bbb + bb * bb * bb + b * b * b) == m) {System.out.println(m);}}}/*【程序4】作者若水飞天题目:将一个正整数分解质因数。
例如:输入90,打印出90=2*3*3*5。
程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。
*/package .flywater.FiftyAlgorthm;import java.util.Scanner;public class FourthPrimeFactor {static int n, k = 2;public static void main(String[] args) {Scanner s = new Scanner(System.in);n = s.nextInt();System.out.print(n + "=" );FourthPrimeFactor fpf = new FourthPrimeFactor();fpf.f(n);}public void f(int n) {while(k <= n) {if(k == n) {System.out.println(n);break;} else if(n > k && n % k == 0) {System.out.print(k + "*");n = n / k;f(n);break;} else if(n > k && n % k != 0) {k++;f(n);break;}}}}/*【程序5】作者若水飞天题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。
1.程序分析:(a>b)?a:b这是条件运算符的基本例子。
*/package .flywater.FiftyAlgorthm;import java.util.Scanner;public class FifthCondition {//public static final int S1 = 90;//public static final int S2 = 60;static int grade;public static void main(String[] args) {Scanner str = new Scanner(System.in);int s = str.nextInt();FifthCondition fc = new FifthCondition();grade = pare(s);if(grade == 1) {System.out.print('A');} else if(grade == 2) {System.out.print('B');} else {System.out.println('C');}}public int compare(int s) {return s > 90 ? 1: s > 60 ? 2:3;}}/*【程序6】作者若水飞天题目:输入两个正整数m和n,求其最大公约数和最小公倍数。
1.程序分析:利用辗除法。
*//** 在循环中,只要除数不等于0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,取得的余数作为下一轮循环的较小的数,如此循环直到较小的数的值为0,返回* 较大的数,此数即为最小公约数,最小公倍数为两数之积除以最小公倍数。
* */package .flywater.FiftyAlgorthm;import java.util.Scanner;public class SixthCommonDiviser {public static void main(String[] args) {int a, b;Scanner s1 = new Scanner(System.in);Scanner s2 = new Scanner(System.in);a = s1.nextInt();b = s2.nextInt();SixthCommonDiviser scd = new SixthCommonDiviser();int m = scd.division(a, b);int n = a * b / m;System.out.println("最大公约数: " + m);System.out.println("最小公倍数: " + n);}public int division(int x, int y) {int t;if(x < y) {t = x;x = y;y = t;}while(y != 0) {if(x == y) return 1;else {int k = x % y;x = y;y = k;}}return x;}}/*【程序7】作者若水飞天题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
1.程序分析:利用while语句,条件为输入的字符不为'\n '. */package .flywater.FiftyAlgorthm;import java.util.*;public class SeventhCharacterStatistics {static int digital = 0;static int character = 0;static int other = 0;static int blank = 0;public static void main(String[] args) {char[] ch = null;Scanner sc = new Scanner(System.in);String s = sc.nextLine();ch = s.toCharArray();for(int i=0; i<ch.length; i++) {if(ch[i] >= '0' && ch[i] <= '9') {digital ++;} else if((ch[i] >= 'a' && ch[i] <= 'z') || ch[i] > 'A' && ch[i] <= 'Z') { character ++;} else if(ch[i] == ' ') {blank ++;} else {other ++;}}System.out.println("数字个数: " + digital);System.out.println("英文字母个数: " + character);System.out.println("空格个数: " + blank);System.out.println("其他字符个数:" + other );}}/*【程序8】作者若水飞天题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。