<<编程珠玑>>读书笔记 NO. 11章 Qsort1

 

用了一天时间终于调试成功了

理解算法思路卡了一下,实现时大大的卡了一下,尝试了各种方法,桌上摆道具重复算法过程,用圆珠笔,手机,纸飞机,愤怒小鸟胶皮玩具演习排序过程,

 

后来Debug跟踪发现 watch 变量中 ++m会导致诡异的效果

后来跟踪入swap函数终于发现,没有考虑到 待交换的两个元素 同一索引,即同一个元素,这是不能用^交换,会导致清0效果!!!!!!

 

 

思路不写了,饿了吃饭去了,自我记录一下,不要用我的这篇当学习文档

 

这里有一个GIF动画展示过程

http://en.wikipedia.org/wiki/Quicksort#Simple_version

 

package org.algorithm;
/**
 * Qsort
 * @author Administrator
 *
 */
public class Qsort1 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		 int[] arr = {58,43,29,69,2,123,32,1,-2,432,31,44};
		Qsort1 myqsort = new Qsort1();
		myqsort.qsort1(arr,0,arr.length-1);
//		swapByIndex(arr, 1,0 );
		for(int i=0;i<arr.length;i++){
			System.out.print(arr[i]);
			System.out.print(",");
			
		}
	}
	public  void qsort1(int[] _arr,int startIdx,int endIdx){
		System.out.println("qsort ==== "+_arr);
		//结束条件
		if(startIdx>=endIdx){
			return;
		}
		int mid = startIdx;//中心索引  随判断动态移动
		//第一个元素作为比对的元素 ,目标是以他为中心左右分布
		/**
		 * 核心思想:
		 * 以第一个元素为参照左右分割
		 * 第一个元素a1位置不变,第二个元素a2(<=a1)担当巡视职责去分割左右
		 * 最后再交换a1 a2
		 * 左右两部分分别递归
		 */
		int tmp = 0;
		for(int i=startIdx+1;i<=endIdx;i++){
			if(_arr[i]<_arr[startIdx]){
				mid++;
				swapByIndex(_arr,i,mid);
//				tmp = _arr[i];
				mid++;
//				_arr[i]= _arr[++mid];
//				_arr[mid] = tmp;
			}
		}//end for
		//交换a1,a2  
		swapByIndex(_arr,startIdx,mid);
//		tmp = _arr[mid];
//		_arr[mid] = _arr[startIdx];
//		_arr[startIdx] = tmp;
		//左右两个部分递归
		qsort1(_arr,startIdx, mid-1);
		qsort1(_arr,mid+1,endIdx);
		
	}
	/**
	 * swap value
	 * elegant haha
	 * @param a
	 * @param b
	 */
	private  void swapByIndex(int[] _arr,int indexA,int indexB){
		/**
		 * 一定要判断,否则 会把元素清0
		 */
		if(indexA==indexB){
			return;
		}
		_arr[indexA]^=_arr[indexB];
		_arr[indexB]^=_arr[indexA];
		_arr[indexA]^=_arr[indexB];
		
	}
}


 

优化这段代码<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>图书购物车</title> <style> </style> <script src="js/vue.js"></script> </head> <body> <div id="demo"> <table border="1"> <tr> <td></td> <td>书籍名称</td> <td>出版日期</td> <td>价格</td> <td>购买数量</td> <td>操作</td> </tr> <tr> <td></td> <td>{{books1.name}}</td> <td>{{books1.date}}</td> <td>¥{{books1.price}}</td> <td><button @click="down(books1)">-</button>{{books4.count}}<button @click="up(books1)">+</button></td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books2.name}}</td> <td>{{books2.date}}</td> <td>¥{{books2.price}}</td> <td> <button @click="down(books2)">-</button>{{books4.count}}<button @click="up(books2)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books3.name}}</td> <td>{{books3.date}}</td> <td>¥{{books3.price}}</td> <td> <button @click="down(books3)">-</button>{{books4.count}}<button @click="up(books3)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books4.name}}</td> <td>{{books4.date}}</td> <td>¥{{books4.price}}</td> <td> <button @click="down(books4)">-</button>{{books4.count}}<button @click="up(books4)">+</button> </td> <td><button @click="del">移除</button></td> </tr> </table> <div>总价: ¥{{sum}}</div> </div> <!-- js部分 --> <script> const vm = new Vue({ el: "#demo", data: { books1: { name: '《算法导论》', date: '2006-9', price: 85.00, count: 1 }, books2: { name: '《UNIX编程艺术》', date: '2006-2', price: 59.00, count: 1 }, books3: { name: '《编程珠玑》', date: '2008-10', price: 39.00, count: 1 }, books4: { name: '《代码大全》', date: '2006-3', price: 128.00, count: 1 } }, computed: { sum () { return this.books1.price * this.books1.count + this.books2.price * this.books2.count + this.books3.price * this.books3.count + this.books4.price * this.books4.count } }, methods: { down (books1) { this.books1.count = books1.count - 1; } } }) </script> </body> </html>
04-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值