代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
CSharp
】
调整数组顺序,让奇数位于偶数前面的算法
作者:
垚溯
/ 发布于
2014/10/10
/
877
#region 调整数组顺序使奇数位于偶数前面 /// <summary> /// 输入一个 整数数组,实现一个函数来调整该数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半部分 /// Reorder中array为待排序的数组,使用组合的方式调用使用何种方法进行排序(如奇数在前,偶数在后,或能被3整除的数在前,不能被3整除的数在后) /// </summary> class Reorder { private List<int> _array; private RecorderOperator _op; public List<int> array { get { return _array; } set { _array = value; } } public RecorderOperator op { get { return _op; } set { _op = value; } } public Reorder(List<int> array, RecorderOperator op) { _array = array; _op = op; } public Reorder() { } public void ReorderArray() { int length = array.Count; int start = 0, end = length - 1; while (start < end) { while (start < end && !op.Operator(array[start])) start++; while (start < end && op.Operator(array[end])) end--; if (start < end) { int temp = array[start]; array[start] = array[end]; array[end] = temp; } } } public void Print() { array.ForEach(a=>Console.Write(a+" ")); Console.WriteLine(); } } class RecorderOperator { public virtual bool Operator(int n) { return false; } } class ConcreteRecorderOperator1:RecorderOperator { public override bool Operator(int n) { return (n & 0x1)==0; } } class ConcreteRecorderOperator2 : RecorderOperator { public override bool Operator(int n) { return n%3!=0; } } #endregion class Test{ public void ReorderTest() { RecorderOperator op1 = new ConcreteRecorderOperator1(); Reorder reorder = new Reorder(new List<int>{2,3,4,9,5},op1); Console.WriteLine("所有奇数位于数组的前半部分,所有偶数位于数组的后半部分"); reorder.Print(); reorder.ReorderArray(); reorder.Print(); RecorderOperator op2 = new ConcreteRecorderOperator2(); reorder.op = op2; reorder.ReorderArray(); Console.WriteLine("能被3整除的数在前,不能被3整除的数在后"); reorder.Print(); } } class Program { static void Main(string[] args) { Test t = new Test(); t.ReorderTest(); } }
试试其它关键字
调整数组
同语言下
.
文件IO 操作类库
.
Check图片类型[JPEG(.jpg 、.jpeg),TIF,GIF,BMP,PNG,P
.
机器名和IP取得(IPV4 IPV6)
.
Tiff转换Bitmap
.
linqHelper
.
MadieHelper.cs
.
RegHelper.cs
.
如果关闭一个窗体后激活另一个窗体的事件或方法
.
创建日志通用类
.
串口辅助开发类
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
垚溯
贡献的其它代码
(
1
)
.
调整数组顺序,让奇数位于偶数前面的算法
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3