冒泡排序不存在正宗不正宗。 思想是相同的,实现方法不同而已。
冒泡排序有好多种写法。维基百科上面也给出了助记码:
i∈[0,N-1) //循环N-1遍
j∈[0,N-1-i) //每遍循环要处理的无序部分
swap(j,j+1) //两两排序(升序/降序)
i∈[N-1,0) //循环N-1遍
j∈[N-1,N-i-1) //每遍循环要处理的无序部分
swap(j,j-1) //两两排序(升序/降序)
i∈[0,N-1) //循环N-1遍
j∈[i+1,N) //每遍循环要处理的无序部分
swap(i,j) //两两排序(升序/降序)
另外,你的两数交换的写法并不好,有可能会导致溢出。要么老老实实用第三方变量,要么用异或。 |