当前位置: 首页 > news >正文

服务器出租深圳网站优化推广方案

服务器出租,深圳网站优化推广方案,建设政府信息资源共享网站,网页传奇公益服#include<iostream> #include<cstring> #include<algorithm> using namespace std; const int N1e510; int q[N]; int w[N],s[N]; int n,sz; //直接插入排序 ,对于某一个元素加入到一个有序的序列中&#xff0c;将该元素依次从该位置开始 //从后往前比较&…
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1e5+10;
int q[N];
int w[N],s[N];
int n,sz;
//直接插入排序 ,对于某一个元素加入到一个有序的序列中,将该元素依次从该位置开始
//从后往前比较,
//大于该元素的都往后挪一位,直到找到比他小的元素,将该元素插入到比他小的元素的后面。
//
void insert_sort(){for(int i=0;i<n;i++){   // 这里i=1 开始也对int t=q[i],j=i;while(j>0&&q[j-1]>t){swap(q[j],q[j-1]);  // 这里写成q[j]=q[j-1] 也对j--;}q[j]=t;}
}
//折半插入排序 就是在排序的基础上进行二分优化,就是在“将该元素依次从后往前比较”
//这一步中 直接通过二分找到比他小的最大元素 
void binary_search_insert_sort(){for(int i=0;i<n;i++){int t=q[i];if(t>=q[i-1]){q[i]=t;continue;}int l=0,r=i;while(l<r){int mid=l+r>>1;if(q[mid]>t) r=mid;else l=mid+1;}for(int j=i-1;j>=r;j--){q[j+1]=q[j];}q[r]=t;}
}
//冒泡排序  a,b,c,d 从后往前依次做 if c > d 交换二者位置,这样每遍历一次,可以将
//第 i 小的数 放在第i个位置 一共只需要做n-1次。
//y总写的这个是把小的往前冒
//也可以把大的往后冒
void bubble_sort(){for(int i=0;i<n-1;i++){bool has_swap=false;//小优化  如果说当前遍历的过程中,没发生一次交换,说明//当前序列已经是有序的了 可以直接breakfor(int j=n-1;j>i;j--){if(q[j]<q[j-1]) {swap(q[j],q[j-1]);has_swap=true;}}if(!has_swap) break;}
}
//最简单的一集,依次从前往后遍历,每次把后面的最小的一个选出来 放到当前位置。
//总共需要遍历n-1次,因为最后一个位置肯定是符合有序的
void select_sort(){for(int i=0;i<n-1;i++){int k=i;for(int j=i+1;j<n;j++){if(q[j]<q[k]){k=j;}}swap(q[k],q[i]);}
}
//希尔排序:分组+插入排序
void shell_sort(){for(int d=n/3;d;d = d == 2 ? 1 : d / 3){  // 因为希尔排序最后要求公差必须是1//但你每次除三到最后不一定是1 可能是2  2的话我们令公差为1for(int start=0;start<d;start++){for(int i=start+d;i<n;i+=d){int t=q[i],j=i;while(j>start&&t<q[j-d]){swap(q[j],q[j-d]);j=j-d;}q[j]=t;}}}
}
//具体理解 可以参考B站动画演示
void quick_sort(int l,int r){if(l>=r) return;int i=l-1,j=r+1,x=q[(l+r)>>1];while(i<j){do i++;while(q[i]<x);do j--;while(q[j]>x);if(i<j) swap(q[i],q[j]);}quick_sort(l,j);quick_sort(j+1,r);
}
//堆排序要从下标1开始,具体过程可以参考B站动画演示
void down(int t){int u=t;if(u*2<=sz&&q[u*2]>q[t]) t=u*2;if(u*2+1<=sz&&q[u*2+1]>q[t]) t=u*2+1;if(u!=t){ //如果t不是叶子结点 且与儿子结点发生了交换 那么需要递归重新构建儿子的大根堆swap(q[u],q[t]);down(t);//重新构建叶子节点大根堆}
}
void heap_sort(){sz=n;for (int i = n / 2; i; i -- ) down(i);//从最大的非叶子结点开始 将原数组变为一个大根堆for(int i=0;i<n-1;i++){swap(q[1], q[sz]);  // 将堆顶与堆低元素互换 sz -- ;//并且删除堆低元素down(1);//因为发生了交换 破坏了原有的大根堆 需要重新构造大根堆}
}
//归并排序
void merge_sort(int l,int r){if(l>=r) return;int mid=l+r>>1;merge_sort(l,mid),merge_sort(mid+1,r);int i=l,j=mid+1,k=0;while(i<=mid&&j<=r){if(q[i]<=q[j]) w[k++]=q[i++];else w[k++]=q[j++];}while(i<=mid) w[k++]=q[i++];while(j<=r) w[k++]=q[j++];for(i=l,j=0;i<=r;i++,j++) q[i]=w[j];
}
void bucket_sort(){for(int i=0;i<n;i++) s[q[i]]++;for(int i=1;i<N;i++) s[i]=s[i]+s[i-1];for(int i=n-1;i>=0;i--) w[--s[q[i]]]= q[i];// 举个例子  5 3 4 1 1 //s[1]=2  则w[--2]=1  也即w[1]=1 第1个位置应该放后一个1 //s[1]=1  则w[--1]=1  也即w[0]=1 第0个位置应该放前一个1 (先后顺序未发生改变稳定!)//s[4]=4  则w[--4]=4  也即w[3]=4 第三个位置应该放4//s[3]=3  则w[--3]=3  也即w[2]=3 第二个位置应该放3//s[5]=5  则w[--5]=5  也即w[4]=5 第四个位置应该放5//倒着排序可以保证稳定性for(int i=0;i<n;i++) q[i]=w[i];
}
int main(){cin >> n;for(int i=0;i<n;i++){cin >> q[i];}//insert_sort();//binary_search_insert_sort();//bubble_sort();//select_sort();//shell_sort();//quick_sort(0,n-1);//heap_sort();//merge_sort(0,n-1);bucket_sort();for(int i=0;i<n;i++){cout << q[i] << " ";}return 0;
}
http://www.tj-hxxt.cn/news/41464.html

相关文章:

  • 网站开发答辩演讲福建网络seo关键词优化教程
  • 做类似淘宝网站多少钱网站模板库
  • wordpress站点费用西安关键词排名推广
  • 色一把做最好网站138ip查询网域名解析
  • 做网站公司有什么出路推广通
  • 正规的网站建设专业公司电商seo优化
  • 代做土木工程专业毕业设计网站提升排名
  • python培训班丹东网站seo
  • 做网站能设置关键词在百度中搜索到seo怎么优化排名
  • 南京公司网站建设怎么收费今日实时热点新闻事件
  • 网站开发专业就业指导抖音推广运营公司
  • 南京建设企业网站海淀区seo搜索引擎
  • iis搭建网站怎么做前端旺道网站排名优化
  • wordpress主页加音乐我们seo
  • 一个网站做数据分析要多少钱百度sem代运营
  • WordPress开启me北京seo培训机构
  • 静态网站怎么入侵app代理推广合作50元
  • 政府 门户网站 互动平台 方案网站自动收录
  • 做网站的技术盏生活中的网络营销有哪些
  • 要建设一个网站百度企业号
  • 织梦cms怎么做网站地图武汉网站建设方案优化
  • 免费做公司网站能在百度上搜索的到电销名单渠道在哪里找
  • 网站建设优化服务机构微信软文怎么写
  • 网站开发什么语言创建一个网站需要什么
  • 百度提交网站多久收录郑州专业seo首选
  • 网站登录密码忘记免费的seo网站下载
  • o2o网站建设特色百度2022最新版本
  • 北京网站建设费用免费建站的网站哪个好
  • 网站生成软件做百度关键词排名的公司
  • 导购网站怎么做下载百度免费版