news 2026/6/23 10:45:58

笨人小白的温故知新——排序(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/23 0:30:56

基于python的RSA加密算法软件的研究设计(源码+文档)

项目简介RSA加密算法软件的研究设计实现了以下功能&#xff1a;通过设计的软件中的固定模块来进行输入内容的添加&#xff0c;并且在线能够通过快速的、几乎不耗费资源的提供加密的内容实现。对于加密后的内容&#xff0c;从表面上看就是一长串无规则的字符串&#xff0c;没有任…

作者头像 李华
网站建设 2026/6/23 1:17:52

Excalidraw界面原型设计:产品经理快速出稿方案

Excalidraw&#xff1a;让产品经理用“一句话”画出界面原型 想象这样一个场景&#xff1a;在一次产品需求评审会上&#xff0c;开发同事皱着眉头问&#xff1a;“你说的这个流程跳转&#xff0c;能不能画个图&#xff1f;”你手头没有现成的设计稿&#xff0c;Figma打开太重&a…

作者头像 李华
网站建设 2026/6/20 9:28:31

Excalidraw价值流图:精益生产流程优化

Excalidraw价值流图&#xff1a;精益生产流程优化 在一场跨厂区的精益改善会议上&#xff0c;工艺工程师小李将一个链接发到群里&#xff1a;“大家点开看看&#xff0c;这是我刚用一句话生成的当前产线VSM草图&#xff0c;咱们边看边调。”不到十分钟&#xff0c;六名分布在不…

作者头像 李华
网站建设 2026/6/23 6:59:48

嵌入式多线程从“能跑“到“稳定“的关键一步!

关注星标公众号&#xff0c;不错过精彩内容来源 | 嵌入式大杂烩做嵌入式开发&#xff0c;多线程比较常见&#xff0c;今天就来聊聊多线程从"能跑"到"稳定"的关键一步!一、并发的本质1. 并发≠并行先弄清楚两个概念&#xff1a;并发&#xff08;Concurrency…

作者头像 李华