寒假 6

1.现有无序序列数组为{23,24,12,5,33,5,34,7},请使用以下排序实现编程。

函数1:请使用冒泡排序实现升序排序

函数2︰请使用简单选择排序实现升序排序

函数3:请使用直接插入排序实现升序排序

函数4∶请使用插入排序实现升序排序


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <unistd.h>
void bubble(int a[],int n);
void simple(int b[],int n);
void dir_insert(int c[],int n);
void quick(int d[],int low,int high);int main(int argc, const char *argv[])
{//冒泡排序int a[]={23,24,12,5,33,5,34,7};int n=sizeof(a)/sizeof(a[0]);bubble(a,n);//简单选择排序int b[]={23,24,12,5,33,5,34,7};simple(b,n);//直接插入排序int c[]={23,24,12,5,33,5,34,7};dir_insert(c,n);//快速排序int d[]={23,24,12,5,33,5,34,7};puts("排序前为:");for(int i=0;i<n;i++){printf("%d ",d[i]);}puts("");puts("快速排序后结果为:");quick(d,0,n-1);for(int i=0;i<n;i++){printf("%d ",d[i]);}puts("");return 0;
}
//冒泡排序
void bubble(int a[],int n)
{puts("排序前为:");for(int i=0;i<n;i++){printf("%d ",a[i]);}puts("");puts("冒泡排序后结果为:");for(int i=1;i<n;i++){for(int j=0;j<n-i;j++){if(a[j]> a[j+1]){int t=a[j];a[j]=a[j+1];a[j+1]=t;}}}for(int i=0;i<n;i++){printf("%d ",a[i]);}puts("");
}
//简单选择排序
void simple(int b[],int n)
{puts("排序前为:");for(int i=0;i<n;i++){printf("%d ",b[i]);}puts("");puts("简单选择排序后结果为:");for(int i=0;i<n-1;i++){int min=i;for(int j=i+1;j<n;j++){if(b[min]>b[j]){min=j;}}if(min!=i){int t=b[min];b[min]=b[i];b[i]=t;}}for(int i=0;i<n;i++){printf("%d ",b[i]);}puts("");
}
//直接插入排序
void dir_insert(int c[],int n)
{puts("排序前为:");for(int i=0;i<n;i++){printf("%d ",c[i]);}puts("");puts("直接插入排序后结果为:");int j;for(int i=1;i<n;i++){int temp=c[i];for(j=i-1;j>=0&&c[j]>temp;j--){c[j+1]=c[j];}c[j+1]=temp;}for(int i=0;i<n;i++){printf("%d ",c[i]);}puts("");
}int one_sort(int d[],int low,int high)
{int key=d[low];while(low<high){while(low<high&&key<=d[high])high--;d[low]=d[high];while(low<high&&key>=d[low])low++;d[high]=d[low];}d[low]=key;return low;                              
}
//快速排序
void quick(int d[],int low,int high)
{if(low>=high)return;int mid=one_sort(d,low,high);quick(d,low,mid-1);quick(d,mid+1,high);
}


int DigitSum(int num)
{if(num==0){return 0;}else{return num%10+DigitSum(num/10);}
}
int main(int argc, const char *argv[])
{int num;printf("please enter num:");scanf("%d",&num);int sum=DigitSum(num);printf("sum=%d\n",sum);return 0;
}

#define Exchange(num) (((num & 0x55555555) << 1 )|((num & 0xaaaaaaaa) >> 1 ))

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/470530.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

找负环(图论基础)

文章目录 负环spfa找负环方法一方法二实际效果 负环 环内路径上的权值和为负。 spfa找负环 两种基本的方法 统计每一个点的入队次数&#xff0c;如果一个点入队了n次&#xff0c;则说明存在负环统计当前每个点中的最短路中所包含的边数&#xff0c;如果当前某个点的最短路所…

Visual Studio Code连接远程MS Azure服务器的方法

1. 开启远程MS Azure服务器 Step 1.1. 登录MS Azure账号&#xff0c;https://azure.microsoft.com/en-us/get-started/azure-portal Step 1.2. 开启远程MS Azure服务器 2. 通过Visual Studio Code连接MS Azure远程服务器 Step 2.1. 安装Remote-SSH Extension Step 2.2. 选择…

使用REQUESTDISPATCHER对象调用错误页面

使用REQUESTDISPATCHER对象调用错误页面 问题陈述 InfoSuper公司已经创建了一个动态网站。发生错误时,浏览器中显示的堆栈跟踪很难理解。公司的系统分析师David Wong让公司的软件程序员Don Allen创建自定义错误页面。servlet引发异常时,应使用RequestDisapatcher对象向自定义…

【教程】Kotlin语言学习笔记(二)——数据类型(持续更新)

写在前面&#xff1a; 如果文章对你有帮助&#xff0c;记得点赞关注加收藏一波&#xff0c;利于以后需要的时候复习&#xff0c;多谢支持&#xff01; 【Kotlin语言学习】系列文章 第一章 《认识Kotlin》 第二章 《数据类型》 文章目录 【Kotlin语言学习】系列文章一、基本数据…

【计算机网络】网络层之IP协议

文章目录 1.基本概念2.协议头格式3.网段划分4.特殊的IP地址5.IP地址的数量限制6.私有IP地址和公网IP地址7.路由 1.基本概念 IP地址是定位主机的&#xff0c;具有一个将数据报从A主机跨网络可靠的送到B主机的能力。 但是有能力就一定能做到吗&#xff0c;只能说有很大的概率。…

讲解用Python处理Excel表格

我们今天来一起探索一下用Python怎么操作Excel文件。与word文件的操作库python-docx类似&#xff0c;Python也有专门的库为Excel文件的操作提供支持&#xff0c;这些库包括xlrd、xlwt、xlutils、openpyxl、xlsxwriter几种&#xff0c;其中我最喜欢用的是openpyxl&#xff0c;这…

【论文解读】TS2Vec: Towards Universal Representation of Time Series

TS2Vec: Towards Universal Representation of Time Series 摘要 这篇论文介绍了TS2Vec&#xff0c;这是一个用于在任意语义级别上学习时间序列表示的通用框架。与现有方法不同&#xff0c;TS2Vec以层次化方式在增强的上下文视图上执行对比学习&#xff0c;从而为每个时间戳提…

【c语言】字符串常见函数 下

&#x1f388;个人主页&#xff1a;甜美的江 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;c语言 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步&a…

混合键合(Hybrid Bonding)工艺解读

随着半导体技术的持续演进&#xff0c;传统的二维芯片缩放规则受到物理极限的挑战&#xff0c;尤其是摩尔定律在微小化方面的推进速度放缓。为了继续保持计算性能和存储密度的增长趋势&#xff0c;业界开始转向三维集成电路设计与封装技术的研发。混合键合技术就是在这样的背景…

Git基础使用

Git 要想了解Git&#xff0c;首先需要我们了解一下VCS——版本控制系统&#xff08;version control system&#xff09; VCS 版本控制是一种记录一个或若干文件内容变化&#xff0c;以便将来查阅特定版本修订情况的系统。版本控制系统不仅可以应用于软件源代码的文本文件&a…

python调用智谱ai 大模型的完整步骤 (国内的 AI 大模型 对话)

要使用Python调用智谱AI的API进行异步调用&#xff0c;您需要遵循以下步骤&#xff1a; 1. **获取API密钥**&#xff1a; - 您需要从智谱AI平台获取一个API密钥&#xff08;API Key&#xff09;&#xff0c;这个密钥将用于所有API请求的身份验证。 2. **安装…

机器学习网格搜索超参数优化实战(随机森林) ##4

文章目录 基于Kaggle电信用户流失案例数据&#xff08;可在官网进行下载&#xff09;数据预处理模块时序特征衍生第一轮网格搜索第二轮搜索第三轮搜索第四轮搜索第五轮搜索 基于Kaggle电信用户流失案例数据&#xff08;可在官网进行下载&#xff09; 导入库 # 基础数据科学运…