news 2026/6/15 14:57:09

笨人小白的温故知新——排序(3)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
笨人小白的温故知新——排序(3)

我来啦!今天依旧是1177:奇数单增序列的一题多解。

(不厌其烦地附上题目)

【题目描述】

给定一个长度为N(不大于500)的正整数序列,请将其中的所有奇数取出,并按升序输出。

【输入】

第1行为 N;

第2行为 N 个正整数,其间用空格间隔。

【输出】

增序输出的奇数序列,数据之间以逗号间隔。数据保证至少有一个奇数。

【输入样例】

10 1 3 2 6 5 4 9 8 7 10

【输出样例】

1,3,5,7,9

方法四:冒泡排序

我在大佬源代码的基础上,将q[j]与q[j+1]的复制与赋值换成了swap()函数!嘻嘻,我会a little bit举一反三了!

这个flag是用来判断当前数组是否已经有序的,其实没有flag也不影响理解哒!

#include <iostream> #include <algorithm> using namespace std ; void bubblesort(int q[] , int n){ for(int i = 0 ; i < n - 1 ; i ++){ bool flag = true ; //用一个flag来判断当前数组是否已经有序,有序则推退出循环 for(int j = 0 ; j < n - 1 ; j ++){ if(q[j] > q[j+1]){ swap(q[j] , q[j+1]) ; flag = false ; } } if(flag) break ; } } int main(){ int n , len , k = 0 ; cin >> n ; len = n ; int* a = new int[n] ; while(n --) scanf("%d" , &a[k++]) ; bubblesort(a , len) ; int first = 1 ; for(int i = 0 ; i < len ; i ++){ if(a[i] % 2 == 1){ if(first == 1){ first = 0 ; printf("%d", a[i]) ; continue ; } else printf(",%d" , a[i]) ; } } return 0 ; }

方法五:希尔排序

看了希尔排序的动画后,就觉得这玩意儿 和插入排序怎么那么像,看到它的模板代码后发现,这俩真的超级像!

希尔排序比插入排序多的一个地方是增量gap。希尔排序每次都选择gap/2作为它的步长(初始的gap为n/2),根据这个步长分组进行排序,使得每次排序的工作量都比较小。

#include <iostream> #include <algorithm> using namespace std ; void shellsort(int q[] , int n){ for(int gap = n/2 ; gap >= 1 ; gap/=2){ for(int i = gap ; i < n ; i += gap){ int temp = q[i] ; int pre = i - gap ; while(pre >= 0 && q[pre] > temp){ q[pre+gap] = q[pre]; pre -= gap ; } q[pre + gap] = temp ; } } } int main(){ int n , len , k = 0 ; cin >> n ; len = n ; int* a = new int[n] ; while(n --) scanf("%d" , &a[k++]) ; shellsort(a , len) ; int first = 1 ; for(int i = 0 ; i < len ; i ++){ if(a[i] % 2 == 1){ if(first == 1){ first = 0 ; printf("%d", a[i]) ; continue ; } else printf(",%d" , a[i]) ; } } return 0 ; }

方法五:选择排序

#include <iostream> #include <algorithm> using namespace std ; void selectionsort(int q[] , int n){ for(int i = 0 ; i < n ; i ++){ int min = i ; for(int j = i+1 ; j < n ; j ++){ if(q[j] < q[min]) min = j ; } int temp = q[min] ; q[min] = q[i] ; q[i] = temp ; } } int main(){ int n , len , k = 0 ; cin >> n ; len = n ; int* a = new int[n] ; while(n --) scanf("%d" , &a[k++]) ; selectionsort(a , len) ; int first = 1 ; for(int i = 0 ; i < len ; i ++){ if(a[i] % 2 == 1){ if(first == 1){ first = 0 ; printf("%d", a[i]) ; continue ; } else printf(",%d" , a[i]) ; } } return 0 ; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 13:38:46

Excalidraw园艺种植图:植物生长周期规划

Excalidraw园艺种植图&#xff1a;植物生长周期规划 在智慧农业逐步走向精细化管理的今天&#xff0c;一个番茄从种子入土到果实采摘&#xff0c;背后往往涉及数十个关键节点——何时催芽、几日移栽、温湿度如何调控、病虫害预警时间点……这些信息若仅靠Excel表格或口头传达&a…

作者头像 李华
网站建设 2026/6/15 10:37:50

AI赋能Excalidraw:一句话生成产品原型草图

AI赋能Excalidraw&#xff1a;一句话生成产品原型草图 在产品设计的日常中&#xff0c;你是否经历过这样的场景&#xff1f;产品经理在会议中提出一个新功能逻辑&#xff0c;刚说完“我们想要一个用户注册流程”&#xff0c;旁边的工程师已经开始默默打开 Figma 或 Draw.io&…

作者头像 李华
网站建设 2026/6/15 12:25:57

Excalidraw状态机可视化:软件设计新模式

Excalidraw状态机可视化&#xff1a;软件设计新模式 在一次远程架构评审会议中&#xff0c;团队正为一个复杂的订单流程争论不休。产品经理指着PPT上的UML图说&#xff1a;“这里用户支付失败后应该能重试三次&#xff0c;而不是直接取消。”开发却回应&#xff1a;“代码里确…

作者头像 李华
网站建设 2026/6/15 13:39:19

Excalidraw情绪日记:心理状态趋势观察

Excalidraw情绪日记&#xff1a;心理状态趋势观察 在心理咨询室的角落&#xff0c;一张手绘的情绪变化图贴在墙上——线条歪斜、颜色斑驳&#xff0c;却真实记录着来访者一周以来的情绪起伏。这种朴素的表达方式&#xff0c;正被数字工具重新诠释。如今&#xff0c;越来越多的人…

作者头像 李华
网站建设 2026/6/15 11:46:46

Excalidraw车辆维修手册:故障排查流程图

Excalidraw车辆维修手册&#xff1a;故障排查流程图 在一家连锁汽修厂的早会上&#xff0c;一名新技师面对“发动机无法启动”的工单显得手足无措。老师傅递给他一张泛黄的手写流程图&#xff0c;边画边讲&#xff1a;“先看电瓶&#xff0c;再听马达声……”这样的场景每天都在…

作者头像 李华
网站建设 2026/6/15 12:11:15

Excalidraw商业模式画布:创业团队战略讨论

Excalidraw&#xff1a;当手绘白板遇上AI&#xff0c;创业团队如何重塑战略协作&#xff1f; 在一场深夜的远程会议中&#xff0c;四位分散在三个时区的创始人正试图敲定他们的产品架构。有人打开PPT&#xff0c;开始拖拽框框&#xff1b;有人发来一段文字描述&#xff1b;还有…

作者头像 李华