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

2024-02-08 12:48

本文主要是介绍我与代码的日常:奇数位于偶数之前,杨氏矩阵,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学习不易,需要坚持。

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 ;
}

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

学习不易,需要坚持。

这篇关于我与代码的日常:奇数位于偶数之前,杨氏矩阵的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/691091

相关文章

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Java Spring ApplicationEvent 代码示例解析

《JavaSpringApplicationEvent代码示例解析》本文解析了Spring事件机制,涵盖核心概念(发布-订阅/观察者模式)、代码实现(事件定义、发布、监听)及高级应用(异步处理、... 目录一、Spring 事件机制核心概念1. 事件驱动架构模型2. 核心组件二、代码示例解析1. 事件定义

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元