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

已知数组A[1..n]中元素类型为非负整数,设计算法将其调整为左右两部分,左边所有为奇数,右边所有为偶数,并要求算法的时间复杂度为O(n)

//左边奇数右边偶数
void Swap(int* a, int* b) {int tmp = *b;*b = *a;*a = tmp;
}
void LeftRight(int arr[],int n) {int i = 0;int j = n - 1;while(i<j){if (arr[i] % 2 == 0 && arr[j] % 2 == 1) {Swap(&arr[i], &arr[j]);i++;j--;}else if (arr[i] % 2 == 1 && arr[j]%2== 1) {i++;}else if (arr[i] % 2 == 0 && arr[j]%2== 0) {j--;}else if (arr[i] % 2 == 1 && arr[j]%2== 0) {i++;j--;}}
}
int main()
{int arr[20] = { 0 };//默认最大输入长度不超过20int n = 0;printf("请输入数组长度n:");scanf("%d", &n);int i = 0;printf("\n请输入数组数据:");for (i = 0;i < n;i++){scanf("%d", &arr[i]);}printf("\n调整后的数组为:");LeftRight(arr, n);for (i = 0;i < n;i++){printf("%d ", arr[i]);}
}

在这里插入图片描述

http://www.lryc.cn/news/250694.html

相关文章:

  • ssm+vue的罪犯信息管理系统(有报告)。Javaee项目,ssm vue前后端分离项目。
  • Java/Android 各类型数据构造和各类型数据解析
  • Linux系统---环境变量+内核进程调度队列(选学)
  • Kubernetes 使用插件扩展 kubectl
  • 前端面试题09
  • 网站更换IP的四大注意事项
  • 策略模式与简单工厂模式:终结if-else混乱,让代码更清爽
  • TCP三次握手过程
  • 04-配置远程仓库的SSH免密登陆
  • 【中文编码】利用bert-base-chinese中的Tokenizer实现中文编码嵌入
  • 一文解决msxml3.dll文件缺失问题,快速修复msxml3.dll
  • 《React 知识点》第一篇 大括号使用{}
  • kafka入门(二): 位移提交
  • PG时间计算
  • 基于51单片机的交通灯_可调时间_夜间+紧急模式
  • 网络通信原理,进制转化总结
  • 西南科技大学(数据结构A)期末自测练习三
  • 【halcon】裁剪
  • vue+less+style-resources-loader 配置全局颜色变量
  • 第二次量子化
  • (三)Pytorch快速搭建卷积神经网络模型实现手写数字识别(代码+详细注解)
  • 【代码】多种调度模式下的光储电站经济性最优 储能容量配置分析matlab/yalmip
  • 深度学习今年来经典模型优缺点总结,包括卷积、循环卷积、Transformer、LSTM、GANs等
  • ChatGPT成为“帮凶”:生成虚假数据集支持未知科学假设
  • c#利用Forms.Timer定时检测Tcp连接状态
  • 空间注意力:改变我们理解图像的方式
  • 【模型报错记录】‘PromptForGeneration‘ object has no attribute ‘can_generate‘
  • mysql学习记录
  • Hdoop学习笔记(HDP)-Part.11 安装Kerberos
  • 浅谈UML的概念和模型之UML九种图