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

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

相关文章

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

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 开发的打飞机游戏脚本代码解释初始化部