复制代码 代码如下:
l = [6, 2, 4, 1, 98, 34, 5, 9, 23, 8, 10, 32]
//冒泡排序
/*function bubbleSort(arr) {
newarr = arr.slice()
if (newarr.length <= 2) return newarr
for (var i = 0; i < newarr.length - 1; i++) {
for (var j = 0; j < newarr.length - i - 1; j++) {
if (newarr[j] > newarr[j + 1]) {
newarr[j] = [newarr[j + 1], newarr[j + 1] = newarr[j]][0]
}
}
}
return newarr
}
console.log(l)
result = bubbleSort(l)
console.log(result)*/
//快速排序
/*function quickSort(arr) {
if (arr.length <= 1) return arr;
var left = [],
right = [],
middle = [];
var mid = arr[Math.floor(arr.length / 2)]
for (var i = 0; i < arr.length; i++) {
if (arr[i] < mid) {
left.push(arr[i]);
} else if (arr[i] > mid) {
right.push(arr[i]);
} else {
middle.push(mid);
}
}
return [].concat(quickSort(left), middle, quickSort(right))
}
var results = quickSort(l)
console.log(results)
*/
//选择排序
/*function selectSort(arr) {
var min = 9999,
minindex = 0;
var left = [],
right = arr.slice();
if (arr.length <= 1) return arr;
for (var i = 0; i < arr.length; i++) {
if (arr[i] <= min) {
min = arr[i];
minindex = i;
}
}
left.push(min);
right.splice(minindex, 1);
return [].concat(left, selectSort(right))
}
var results = selectSort(l)
console.log(results)*/
//插入排序
/*function insertSort(arr) {
var tmp;
for (var i = 1; i < arr.length; i++) {
tmp = arr[i];
for (var j = i; j > 0; j--) {
if (arr[j - 1] > tmp) {
arr[j] = arr[j - 1];
} else {
break;
}
}
arr[j] = tmp;
}
return arr;
}
var results = insertSort(l)
console.log(results)*/
//木桶排序
/*function bucketSort(arr){
var bucket = [];
var newarr = [];
for (var i = 0; i < arr.length; i++) {
bucket[arr[i]] = arr[i];
}
for (var i = 0; i < bucket.length; i++) {
if (bucket[i] !== undefined){
newarr.push(bucket[i])
}
}
return newarr;
}
var results = bucketSort(l)
console.log(results)*/
//鸽巢排序,非负整数
/*function pigeonholeSort(arr){
var tempArr = [];
for(var i=0,l=arr.length;i<l;i++){
tempArr[arr[i]] = (tempArr[arr[i]]+1)||1 ;
}
var result = [],count;
for(var k=0;k<tempArr.length;k++){
count = tempArr[k];
if(count){
for(var i=0;i<count;i++){
result.push(k);
}
}
}
return result;
}
var results = pigeonholeSort(l)
console.log(results)*/
//归并排序
/*function mergeSort(arr) {
if (arr.length <= 1) return arr;
var mid = Math.floor(arr.length / 2);
var left = MergeSort(arr.slice(0, mid));
var right = MergeSort(arr.slice(mid));
var result = [];
while (left.length && right.length) {
if (left[left.length - 1] <= right[0]) {
result = result.concat(left);
left = [];
} else if (right[right.length - 1] < left[0]) {
result = result.concat(right);
right = [];
} else {
if (right[0] < left[0]) {
result.push(right.shift());
} else {
result.push(left.shift());
}
}
}
result = result.concat(left, right);
return result;
}*/
/*function mergeSort(arr) {
var merge = function(left, right) {
var result = [];
while (left.length > 0 && right.length > 0) {
if (left[0] < right[0]) {
result.push(left.shift());
} else {
result.push(right.shift());
}
}
return result.concat(left).concat(right);
}
if (arr.length == 1) return arr;
var middle = Math.floor(arr.length / 2),
left = arr.slice(0, middle),
right = arr.slice(middle);
return merge(mergeSort(left), mergeSort(right));
}
var results = mergeSort(l)
console.log(results)
*/
//堆排序
/*function heapSort(arr) {
var findRoot = function(arr, p, length) {
p = p || 0;
length = length || arr.length;
var self = arguments.callee;
var l = p * 2 + 1;
var r = (p + 1) * 2;
var left, right;
if (l < length) left = self(arr, l, length);
if (r < length) right = self(arr, r, length);
if (left > arr[p]) arr[p] = [left, arr[l] = arr[p]][0];
if (right > arr[p]) arr[p] = [right, arr[r] = arr[p]][0];
return arr[p];
};
for (var i = arr.length; i > 0; i--) {
findRoot(arr, 0, i);
arr[i - 1] = [arr[0], arr[0] = arr[i - 1]][0];
}
return arr;
}
var results = heapSort(l)
console.log(results)*/
//奇偶排列
/*function oddEvenSort(arr) {
var swaped = true,
k = 0;
while (swaped) {
if (k > 0) swaped = false;
for (var i = k; i < arr.length - 1; i += 2) {
if (arr[i]>arr[i+1]) {
arr[i] = [ arr[i+1], arr[i+1]=arr[i] ][0];
swaped = true;
}
}
k = [1, 0][k]
}
return arr;
}
var results = oddEvenSort(l)
console.log(results)*/
function oddEvenSort(arr) {
var swaped = true;
while (swaped) {
swaped = false;
for (var i = 0; i < arr.length; i += 2) {
if (arr[i] > arr[i + 1]) {
arr[i] = [arr[i + 1], arr[i + 1] = arr[i]][0];
swaped = true;
}
}
for (var i = 1; i < arr.length; i += 2) {
if (arr[i] > arr[i + 1]) {
arr[i] = [arr[i + 1], arr[i + 1] = arr[i]][0];
swaped = true;
}
}
}
return arr;
}
var results = oddEvenSort(l)
console.log(results)
相关推荐:
SEO检测,让网站排名飞升的秘密武器,高端快消食品营销推广
SEO新站优化指南:快速提升排名的必备技巧,海珠网站推广哪家有名
OpenAI银行卡扣款的公司是哪家?揭秘背后的支付流程与安全保障,AI素描相片
seo要学会什么,seo要学多长时间 ,NTU AI 录取
SEO关键词的选择步骤:让你的网站在搜索引擎中脱颖而出,ai书法化
SEO定价策略:如何根据企业需求定制最佳价格方案,教育培训抖音营销推广
seo线索收集是什么,seo线索收集是什么意思 ,ai生活ai童童
SEO包含的秘密:让你的网站轻松排上首页,新媒体营销推广方案目录
SEO教育:搜索引擎优化,开启成功职业之路,搜狗SEO排名接单
AI网页生成:轻松构建智能网站,提升品牌竞争力,杭州专业ai智能教育
SEO到底怎么做?揭秘从零到精通的完整SEO优化攻略,鸟瞰ai
为什么要监控SEO效果,国家为什么要监控个人 ,抚顺ai系统
SEO结构优化:助力网站提升排名与流量的关键策略,杭州小网站推广哪家好做
seo词库优化,搜索词条优化 ,ai点选择
GPT版本全解:从基础到高级,如何选择最适合你的方案?,韩国ai人工智能
为什么选择收录网站是企业在线营销的必备策略,全网营销与推广
ChatGPT免费订阅的使用限制:其潜力与挑战,ai辅助线无法对齐画板
SEO怎么设置:让你的网站快速登上搜索引擎首页的秘密,Ai压印分色
SEO合作:让你的网站在搜索引擎中脱颖而出,惠州抖音seo策划公司
ChatGPT常见问题汇总:解答你关于AI的一切疑惑,松鼠ai智能教适应教育
文章AI扩写:突破创作瓶颈,提升写作效率的秘密武器
OpenAI新产品与现有技术的完美结合:赋能未来的智能变革,培训 ai
AI免费文章解读:智能写作新篇章,小店AI
seo简报什么意思,seo工作汇报 ,万花筒 ai
ChatGPT:基于Transformer技术的语言模型,开创人工智能未来,AI独战OK
ChatGPT页面无法访问?解决方案,让你轻松摆脱困扰!,ai染发颜色
ChatGPT付款被拒?如何应对与解决常见支付问题,掉包ai
SEO导航:助力网站提升流量与排名的必备工具,荣昌建筑网站建设
SEO站外优化策略:提升网站排名的关键因素,遵义公司网站推广
智能AI生成文章释放创作新可能
ChatGPT怎么有梯子?突破网络限制,轻松畅享AI智能,ai对唱音响
AI自动帮写,轻松应对内容创作挑战,赋能写作新未来,嘿科技ai
AI的两个主要发展阶段:从起步到突破,如何重塑未来,wps ai写作去哪里
SEO详解:如何优化你的网站提升排名,获得更多流量,伊春湖南网站优化推广
chatai写作免费一键生成,轻松解决写作难题!,陈逗逗ai换脸在线看
seo营销方法是什么,seo营销模式 ,ai山海
SEO是什么意思?揭秘SEO的真正含义与重要性,公司推广网站询问d火18星来
优化综合:引领高效发展的智慧之道,电影营销的推广方式
SEO优化:如何让网站更具有吸引力,散文ai写作咒语是什么
SEO就业前景如何?打造数字时代的职业新风口,常州武进区水产网站建设
seo灰帽是什么,灰帽是指什么 ,ai绘画六边形
WP原创:打造属于你的独特网站,从这里开始!,一个网站推广一个月需要多少钱
自动写文章的AI,提升效率的创作利器
SEO做好,企业网站流量翻倍的关键,seo白帽技术有哪些
SEO发明:引领数字时代营销革命的力量,速卖通外贸推广网站
seo类文章是什么,seo技术文章 ,ai3.5-ai聊天
AI人工智能:改变未来的科技革命
SEO深度解析:如何通过深度优化提升网站排名,带来流量和转化,咸宁网站建设大概费用
seo网站反链是什么,网站反链怎么做 ,ai插画头像卡通
Chat免费,让沟通无界限,尽享智能对话时代,ai没办法置顶