我与代码的日常:奇数位于偶数之前,杨氏矩阵

本文介绍了一种算法,用于将数组中的奇数元素移至偶数元素之前,以及在杨氏矩阵中搜索特定数值并返回其坐标的方法。提供了C语言实现的代码示例,包括非递归和递归两种搜索方式。

学习不易,需要坚持。

1.有一个数组,编程调整使其奇数位于偶数之前。
解题思路:可以通过数组下标left和right来遍历整个数组,使用while循环,将复合要求的元素借助中间变量tmp进行交换。代码如下:

//调整数组。使奇数位于偶数之前
#include <stdio.h>

void reverse(int arr[], int sz)
{
	int left = 0 ;
	int right = sz - 1 ;
	while(left < right)
	{ 
		//先找偶数
		while((left < right) && (arr[left] % 2 != 0))
		{
			left++ ;
		}
		//找奇数
		while((left < right) && (arr[right] % 2 == 0))
		{
			right-- ;
		}
		if(left < right)
		{
			int tmp = arr[left] ;
			arr[left] = arr[right] ;
			arr[right] = tmp ;
		}
	}
}
int main()
{
	int size = 0 ;
	int i = 0 ;
	int arr[] = {0, 2, 4, 6, 8, 1, 3, 5, 7, 9} ;
	size = sizeof(arr) / sizeof(arr[0]) ;
	printf("调整之前为: ") ;
	for(i=0; i<size; i++)
	{
		printf("%d ", arr[i]) ;
	}

	reverse(arr, size) ;

	printf("\n调整之后为: ") ;
	for(i=0; i<size; i++)
	{
		printf("%d ", arr[i]) ;
	}
	printf("\n") ;
	return 0 ;
}

运行结果:
在这里插入图片描述

2.在杨氏矩阵里寻找一个数,并将其坐标返回。
在这里插入图片描述

//本程序在主函数里定义两个变量,通过传递变量px,py的指针,来对函数内部进行操作,并通过指针解引用的方式来接收函数的返回值
#define ROW 3
#define COL 3

#include <stdio.h>

void Find1(int arr[ROW][COL], int row, int col, int k, int* px, int* py)
{
	//从右上角开始找
	int i = 0 ;
	int j = col - 1 ; //j = 2 
	while( (i < row) && (j >= 0) )
	{
		//若找到k值,则保存其坐标
		if(arr[i][j] == k)
		{
			//因为运行结果给用户看,所以使坐标均加,提高程序的可读性
			*px = i + 1 ;   
			*py = j + 1 ;
			return ;
		}
		//若k值大于当前值,则向下继续找
		else if (arr[i][j] < k)
		{
			i++ ;
		}
		//若k值小于当前值,则向左找
		else
		{
			j-- ;
		}
	}
	//若循环结束后还没找到k值,则返回一个错误值
	*px = -1;
	*py = -1 ;
}

void Find2(int arr[ROW][COL], int row, int col, int k, int* px, int* py)
{
	//从左下角开始找
	int i = row - 1 ;
	int j = 0 ; //j = 2 
	while( (i >= 0) && (j < col) )
	{
		//若找到k值,则保存其坐标
		if(arr[i][j] == k)
		{
			//因为运行结果给用户看,所以使坐标均加,提高程序的可读性
			*px = i + 1 ;   
			*py = j + 1 ;
			return ;
		}
		//若k值大于当前值,则向右继续找
		else if (arr[i][j] < k)
		{
			j++ ;
		}
		//若k值小于当前值,则向上找
		else
		{
			i-- ;
		}
	}
	//若循环结束后还没找到k值,则返回一个错误值
	*px = -1;
	*py = -1 ;
}

int Search1 (int arr[ROW][COL], int row, int col, int k, int x, int y, int* px, int* py)
{
	//递归的出口
	if( (x >= row) || (y < 0) )
	{
		return 0 ;  //返回,表示查找失败
	}

	if(arr[x][y] == k)
	{
		//因为运行结果给用户看,所以使坐标均加,提高程序的可读性
		*px = x +1 ;
		*py = y +1 ;
		return 1 ;  //返回,表示查找成功
	}

	else if (arr[x][y] > k)
	{
		//若当前值大于k,则向左找
		return Search1(arr, row, col, k, x, y-1, px, py) ;
	}

	else
	{
		//若当前值小于k,则向下找
		return Search1(arr, row, col, k, x+1, y, px, py) ;
	}
}

int Search2 (int arr[ROW][COL], int row, int col, int k, int x, int y, int* px, int* py)
{
	//递归的出口
	if( (x < 0) || (y >= col) )
	{
		return 0 ;  //返回,表示查找失败
	}

	if(arr[x][y] == k)
	{
		//因为运行结果给用户看,所以使坐标均加,提高程序的可读性
		*px = x +1 ;
		*py = y +1 ;
		return 1 ;  //返回,表示查找成功
	}

	else if (arr[x][y] > k)
	{
		//若当前值大于k,则向上找
		return Search2(arr, row, col, k, x-1, y, px, py) ;
	}

	else
	{
		//若当前值小于k,则向右找
		return Search2(arr, row, col, k, x, y+1, px, py) ;
	}
}

int main()
{
	int arr[ROW][COL] = {1, 2, 3, 4, 5, 6, 7, 8, 9} ;
	int px1 = 0 ;
	int py1= 0 ;
	int px2 = 0 ;
	int py2= 0 ;
	int px3 = 0 ;
	int py3= 0 ;
	int px4 = 0 ;
	int py4= 0 ;
	int k = 0 ;
	printf("请输入想要搜寻的值: ") ;
	scanf("%d", &k) ;
    Find1(arr, ROW, COL, k, &px1, &py1) ;  //非递归,从右上角开始找
	printf("要找的数字%d的坐标为: %d行%d列\n", k,px1, py1) ;
	Find2(arr, ROW, COL, k, &px2, &py2) ;  //非递归,从左下角开始找
	printf("要找的数字%d的坐标为: %d行%d列\n", k,px2, py2) ;
	Search1(arr, ROW, COL, k, 0, COL-1, &px3, &py3) ; //递归,从右上角开始找
	printf("要找的数字%d的坐标为: %d行%d列\n", k,px3, py3) ;
	Search2(arr, ROW, COL, k, ROW-1, 0, &px4, &py4) ; //递归,从左下角开始找
	printf("要找的数字%d的坐标为: %d行%d列\n", k,px4, py4) ;
	return 0 ;
}

运行结果:
在这里插入图片描述

学习不易,需要坚持。

内容概要:本文详细记录了对一个Android ARM64静态ELF文件中字符串加密机制的逆向分析过程。该ELF文件的所有字符串均被加密,无法通过常规strings命令或IDA直接识别。作者通过分析发现,加密字符串存储在.rodata段,其解密所需信息(包括密文地址、长度和16位密钥)保存在.data.rel.ro段的40字节描述符中。核心解密函数sub_10F408采用自反的双pass流密码算法,结合固定密钥KEY_TERM(由.data段24字节数据计算得出),实现字节级非线性、位置长度相关的加密。文章还复现了完整的Python解密脚本,并揭示了该保护机制的本质为代码混淆而非强加密,最终成功批量解密全部956条字符串,暴露程序真实行为,如shell命令模板、设备标识篡改、网络重置等操作。此外,文中还提及未启用的自定义壳框架及其反dump设计。; 适合人群:具备逆向工程基础的安全研究人员、二进制分析人员及对ELF保护技术感兴趣的开发者。; 使用场景及目标:①学习ELF二进制中字符串加密的典型实现方式逆向突破口;②掌握从结构识别、函数追踪到算法还原的完整逆向流程;③理解“绑定二进制”的完整性校验设计及其局限性;④实践编写IDAPython脚本自动化提取解密敏感数据。; 阅读建议:此资源以实战案例驱动,不仅展示技术细节,更强调逆向思维验证方法,建议读者结合IDA调试环境,逐步跟随文中步骤进行动态分析算法验证,深入理解每一步的推理依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值