




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、求一个数的阶乘: /* * 递归算法 * param number 某个数 * return 某个数的阶乘 */public static long recursion(int number) /非法时 if(number 0) return -1; /1,0的阶乘等于1 if(number 2) return 1; return number*recursion(number-1);/* * 非递归算法 * param number 某个数 * return 某个数的阶乘 */public static long noRecursion(int number) /number的阶乘值,默认为1 long result = 1 ; /非法时 if(number 0) return -1; /1,0的阶乘等于1 if(number 2) return 1; for(int i = 1; i=number; i+) result *= i; return result;2、两数交换: /* * 两个数交换:方法一(不用第三方变量) 【注:此方法在不保证在其他语言中有效】 * param x * param y */ public static void toSwap1(int x, int y) y = x - 0 * (x = y); System.out.println(x = + x); System.out.println(y = + y); /* * 两个数交换:方法二(不用第三方变量) * param x * param y */ public static void toSwap2(int x, int y) x = y; y = x; x = y; System.out.println(x = + x); System.out.println(y = + y); /* * 两个数交换:方法三(使用第三方变量) * param x * param y */ public static void toSwap3(int x, int y) int temp; temp = x; x = y; y = temp; System.out.println(x = + x); System.out.println(y = + y);3、排序: /* * 冒泡排序 * param numbers int型数组 */ public static void bubbleSort(int numbers) /交换数时用的临时变量 int temp; /数组长度 int size = numbers.length; for (int i = 0; i size - 1; i+) for (int j = i + 1; j numbersj) temp = numbersi; numbersi = numbersj; numbersj = temp; for (int i = 0; i numbers.length; i+) System.out.println(numbersi); /* * 快速排序 * param numbers int型数组 * param start * param end */ public static void quickSort(int numbers, int start, int end) if (start end) / 选定的基准值(第一个数值作为基准值) int base = numbersstart; / 交换数时用的临时变量 int temp; int i = start, j = end; do while (numbersi base) & (i base) & (j start) j-; if (i = j) temp = numbersi; numbersi = numbersj; numbersj = temp; i+; j-; while (i = j); if (start i) quickSort(numbers, i, end); for (int i = 0; i numbers.length; i+) System.out.println(numbersi); /* * 选择排序 * param numbers int型数组 */ public static void selectSort(int numbers) / 交换数时用的临时变量 int temp; /数组长度 int size = numbers.length; for (int i = 0; i i; j-) if (numbersj numbersk) k = j; temp = numbersi; numbersi = numbersk; numbersk = temp; for (int i = 0; i numbers.length; i+) System.out.println(numbersi); /* * 插入排序 * param numbers int型数组 */ public static void insertSort(int numbers) / 交换数时用的临时变量 int temp; /数组长度 int size = numbers.length; int j; for (int i = 1; i 0 & temp numbersj - 1; j-) numbersj = numbersj - 1; numbersj = temp; for (int i = 0; i numbers.length; i+) System.out.println(numbersi); /* * 归并排序 * param numbers * param left * param right */ public static void mergeSort(int numbers, int left, int right) / 每组元素个数 int t = 1; int size = right - left + 1; while (t size) int s = t;/ 本次循环每组元素个数 t = 2 * s; int i = left; while (i + (t - 1) size) merge(numbers, i, i + (s - 1), i + (t - 1); i += t; if (i + (s - 1) right) merge(numbers, i, i + (s - 1), right); for (int i = 0; i numbers.length; i+) System.out.println(numbersi); /* * 归并算法实现 * param data * param p * param q * param r */ private static void merge(int data, int p, int q, int r) int B = new intdata.length; int s = p; int t = q + 1; int k = p; while (s = q & t = r) if (datas = datat) Bk = datas; s+; else Bk = datat; t+; k+; if (s = q + 1) Bk+ = datat+; else Bk+ = datas+; for (int i = p; i = r; i+) datai = Bi; for (int i = 0; i data.length; i+) System.out.println(datai); 4、数据翻转: /* * 非递归 * param str 需要转换的字符串 * return 翻转好的字符串 */ public static String turn(String str) char ch = str.toCharArray(); char temp; for (int i = 0; i (ch.length+1)/2; i+) temp = chi; chi = chch.length-i-1; chch.length-i-1 = temp; return new String(ch); /* * param str 需要反转的字符串 * return 反转好字符串 */ public static String reverse(String str) /如果小于2位,则返回本身 if(str.length() = 0; i-) sb.append(str.charAt(i); return sb
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 水质净化与再生利用方案
- 联想技术笔试题目及答案
- 戒烟控烟培训知识资料课件
- 中储粮保管考试题及答案
- 2025年宁波慈溪市中西医结合医疗健康集团招聘派遣制工作人员3人模拟试卷及参考答案详解一套
- 工程项目外部协调与管理方案
- 2025贵州传媒职业学院第十三届贵州人才博览会引才1人模拟试卷及完整答案详解一套
- 景观水体景观与净化处理方案
- 医院病房改造提升项目环境影响报告书
- 2025北京昌平区第二批乡村助理员招5人模拟试卷及答案详解(夺冠系列)
- 基孔肯雅病毒(CHIKV)实验活动风险评估报告
- 武汉从业资格证摸拟考试及答案解析
- 小学数学数与代数全学年复习资料
- 2025至2030医药级一氧化氮行业产业运行态势及投资规划深度研究报告
- 2025海康威视安检机用户手册
- 2025 精神障碍患者暴力行为应对护理课件
- 创新驱动人工智能+法律服务研究报告
- 《物联网技术》课件-第3章 无线传感器网络
- 保健行业员工知识培训课件
- 人民调解员培训课件
- 工业机器人基础课件:装配机器人及其操作应用
评论
0/150
提交评论