选择排序&冒泡排序&折半查找
//选择排序
void test2(int a[],int len){
//每次找出一个最小值,最小值依次与原数组交换位置,通过下标来完成交换,最小值下标每次都在变,变量存储
// 假如第一个是最小值
int mine=0;
int teamp=0;
// 外层负责趟数
for (int i=0; i<len; i++) {
// 假如每一次的第一个是最小值
mine=i;
// 内层负责寻找每趟的最小值
// 每次起始比较值都不一样所以j=i+1,改变次数
for (int j=i+1; j<len; j++) {
// 最小值下标赋给mine
if (a[mine]>a[j]) {
mine=j;
}
//
}
// 交换 mine!=i表示最小值不是假设的值
if (mine!=i) {
teamp=a[i];
a[i]=a[mine];
a[mine]=teamp;
}
// 每次打印的都是最小值
printf("%d\t",a[i]);
}
}
//冒泡排序
void test3(int a[],int len){
int temp=0;
//外层负责趟数
for (int i=0; i<len; i++) {
// 内层负责每趟交换,起始值j=0不变,len-i-1控制次数
for (int j=0; j<len-i-1; j++) {
// 相邻值进行比较
if (a[j]>a[j+1]) {
//交换
temp=a[j+1];
a[j+1]=a[j];
a[j]=temp;
}
}
printf("%d\t",a[len-i-1]);
}
printf("\n");
}
//折半查找,针对有序数组
int test4(int a[],int len,int key){
// 指向最高,最低,以及中间下标的变量
int hight=len-1,low=0,mid=0;
// 当low,hight,mid指向同一个时,就可以找到值
while (low<=hight) {
mid=(hight+low)/2;
// 在右边
if (key>a[mid]) {
low=mid+1;
// 在左边
}else if (key<a[mid]){
hight=mid-1;
}
// 刚好是
else{
return mid;
}
}
return -1;
}
选择排序&冒泡排序&折半查找的更多相关文章
- Java学习笔记day07_琐碎知识_水仙花数_ASCII码_冒泡排序_简单选择排序_折半查找
		
琐碎知识: 水仙花数, ASCII码, 冒泡排序, 简单选择排序, 折半查找 1.水仙花数 每位数的平方的和等于本身. 如100到999之间的水仙花数满足: 个位的平方+十位的平方+百位的平方 = 本 ...
 - C语言之冒泡排序、选择排序、折半查询、进制查表
		
菜单导航 1.冒泡排序 2.选择排序 3.折半查询 4.进制查表(十进制转二进制.八进制.十六进制) 一.冒泡排序 //1.冒泡排序 /** 一组无序数字,进行从小到大排序 冒泡排序的过程:就是每个循 ...
 - Java基础【冒泡、选择排序、二分查找】
		
冒泡排序的思路就是前一个和后一个进行比较,如果大的就交换位置 大的数字后浮 如 12 8 5 31 第一轮 8 5 12 31 第二轮 5 8 ...
 - StringBuffer、StringBuilder、冒泡与选择排序、二分查找、基本数据类型包装类_DAY13
		
1:数组的高级操作(预习) (1)数组:存储同一种数据类型的多个元素的容器. (2)特点:每个元素都有从0开始的编号,方便我们获取.专业名称:索引. (3)数组操作: A:遍历 public stat ...
 - C语言数组之冒泡排序+折半查找法(二分查找)
		
冒泡排序算法 将相邻的元素进行两两比较,大的向后"冒", 小的向前"赶". 口诀: N个数字来排队,两两比较小靠前 外层循环N-1(控制需要比较的轮数). 内层 ...
 - java-冒泡排序、选择排序、二分查找
		
1.冒泡排序 public void bubbleSort(int[] arr) { for (int i = 0; i < arr.length - 1; i++) { //外循环只需要比较a ...
 - Java ——数组 选择排序 冒泡排序
		
本节重点思维导图 数组 public static void main(String[] args) { int a ; a=3; int[] b; b = new int[3];//强制开辟内存空间 ...
 - [Java]数组排序-选择排序 冒泡排序 插入排序
		
1 选择排序 原理:a 将数组中的每个元素,与第一个元素比较 如果这个元素小于第一个元素, 就将这个 两个元素交换. b 每轮使用a的规则, 可以选择出 ...
 - [模板]选择排序&&冒泡排序&&插入排序
		
#include<iostream> #include<cstdio> #include<bits/stdc++.h> using namespace std; v ...
 
随机推荐
- JS制作简易的考试答题管理系统
			
答题卡系统: 网站运行效果 代码区域: HTML 代码: <style type="text/css"> body { font-size: 30px; backgro ...
 - Java核心技术(卷一)读书笔记——第二章(JAVA/JDK环境配置)
			
JDK 配置:自行百度. 存在多个JDK 版本并且需要指定某版本时,注意更改注册表JavaSoft项以及相关子项,同时删除system32目录下相关的Java可执行文件xxx.exe. IDEA打开项 ...
 - R语言学习笔记——C#中如何使用R语言setwd()函数
			
在R语言编译器中,设置当前工作文件夹可以用setwd()函数. > setwd("e://桌面//")> setwd("e:\桌面\")> s ...
 - java课堂 动手动脑3
			
(1) 该函数没有赋初值再就是如果类提供一个自定义的构造方法,将导致系统不在提供默认的构造方法. (2) public class test { public static void main(Str ...
 - 使用RedisMQ 做一次分布式改造
			
引言 熟悉TPL Dataflow博文的朋友可能记得这是个单体程序,使用TPL Dataflow 处理工作流任务, 在使用Docker部署的过程中, 有一个问题一直无法回避: 在单体程序部署的瞬间会有 ...
 - Android buildType混淆代码
			
[话题引入] ①在Android开发完成,我们会将代码打包成APK文件.选择 菜单栏 Build --> Build APK ②将查看视图切换到 Project 模式,文件夹下有一个debug模 ...
 - Altium Designer16设置GND和VCC线宽规则的一种操作方法及注意事项
			
昨天看到学弟在画电路板,看到他设置电源线线宽时出了一点问题,设置的规则最开始有作用,后来重新从原理图导入更新PCB时,电源线变绿,规则设置点更新也没有用.接下来是操作步骤: 第一步:点击Design- ...
 - SpringBoot配置web访问H2
			
[**前情提要**]最近开始搭建博客,在本地调试的时候使用的数据库是h2,但是调试的时候需要查看数据库,本文也由此而来. --- 下面是我用到的方法: 1. 使用IDEA的Database连接工具,具 ...
 - java并发编程(十四)----(JUC原子类)对象的属性修改类型介绍
			
今天我们介绍原子类的最后一个类型--对象的属性修改类型: AtomicIntegerFieldUpdater,AtomicLongFieldUpdater,AtomicReferenceFieldUp ...
 - 转载 | CSS图片下面产生间隙的  6种解决方案
			
在进行页面的DIV+CSS排版时,遇到IE6(当然有时Firefox下也会偶遇)浏览器中的图片元素img下出现多余空白的问题绝对是常见的对於 该问题的解决方法也是「见机行事」,根据原因的不同要用不同的 ...