“第四十三天”

news2025/1/18 20:06:11

这个是我自己写的,下面那个是看的别人的,其实大致都是一样的,通过四次循环,挨个求和比较,都很麻烦,但重点在于,对于已知变量的运用,当我需要在最内层循环用变量确定a数组组元时,是通过引入新的变量来搞定的,而这个人则是通过对已有变量的处理来表示,这个地方感觉还是蛮差距的。

int main()
{
	int m = 0, n = 0;
	int r = 0, s = 0;
	int a[100][100] = { 0 };
	int b[100][100] = { 0 };
	int i = 0, j = 0;

	scanf("%d %d", &m, &n);
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			scanf("%d", &a[i][j]);
		}
	}

	scanf("%d %d", &r, &s);
	for (i = 0; i < r; i++)
	{
		for (j = 0; j < s; j++)
		{
			scanf("%d", &b[i][j]);
		}
	}
	
	//
	int sum = 0;
	int min = 100000;
	int r2 = 0, c2 = 0;
	int ia1 = 0, ja1 = 0;
	for(int ia=0;ia<m-r+1;ia++)
	{
		for (int ja = 0; ja < n-s+1; ja++)
		{
			ia1 = ia;  
			sum = 0;
			for (int ib = 0; ib < r; ib++)
			{
				ja1 = ja;
				for (int jb = 0; jb < s; jb++)
				{
					if ((a[ia1][ja1] - b[ib][jb]) < 0)
						sum += -(a[ia1][ja1] - b[ib][jb]);
					else
						sum += a[ia1][ja1] - b[ib][jb];
					ja1++;
				}
				ia1++;
			}

			if (min > sum)
			{
				min = sum;	r2 = ia; c2 = ja;
			}
		}
	}
	for ( i = r2; i < r+r2; i++)
	{
		for (j = c2; j < s+c2; j++)
		{
			printf("%d ",a[i][j]);
		}
		printf("\n");
	}
	return 0;
}

参考代码:

#include<stdio.h>

#include<stdlib.h>

#define MAX_INT ~((unsigned int)0)>>1;//输出int型可以表示的最大值

int main()

{

/*

输入函数,注意是二维数组,也就是行列

*/

int m,n,i,j,r,s;

int a[101][101],b[101][101];

scanf("%d %d\n",&m,&n);

for(i=0;i<m;i++)

{

    for(j=0;j<n;j++)

    {

        scanf("%d ",&a[i][j]);

    }

    scanf("\n");

}

scanf("%d %d\n",&r,&s);

for(i=0;i<r;i++)

{

    for(j=0;j<s;j++)

    {

        scanf("%d ",&b[i][j]);

    }

    scanf("\n");

}

int drow,dcol,min;

min =MAX_INT;

for(i=0;i<m-r+1;i++)//注意行列和矩形

{

    for(j=0;j<n-s+1;j++)//上面两个for选定了一个值(左上角元素),然后从该值出发进行选择矩形

    {

       int k,l,sum=0;

       for(k=0;k<r;k++)//执行要选择出来的矩形

       {

           for(l=0;l<s;l++)

           sum=sum+abs(abs(a[i+k][j+l]-b[k][l]));

       }

       if(sum<min)//要取最小的,行列

       {

           drow=i;dcol=j;min=sum;//drow和dcol是在大矩形当中的起始值

       }

    }

}

    for (i = 0; i < r; i++) {

        for (j = 0; j < s; j++)

            printf("%d ", a[drow + i][dcol + j]);

            printf("\n");

}

return 0;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1107403.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据库备份与恢复(实战mysqldump+bin-log)

一、为什么要进行数据库备份&#xff1f; 常见数据库备份的应用场景如下&#xff1a; 数据丢失应用场景&#xff1a; 人为操作失误造成某些数据被误操作 软件 BUG 造成部分数据或全部数据丢失 硬件故障造成数据库部分数据或全部数据丢失 安全漏洞被入侵数据恶意破坏 非数据丢…

基于骑手优化优化的BP神经网络(分类应用) - 附代码

基于骑手优化优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码 文章目录 基于骑手优化优化的BP神经网络&#xff08;分类应用&#xff09; - 附代码1.鸢尾花iris数据介绍2.数据集整理3.骑手优化优化BP神经网络3.1 BP神经网络参数设置3.2 骑手优化算法应用 4.测试结果…

【STM32】---存储器,电源核时钟体系

一、STM32的存储器映像 1 文中的缩写 2 系统构架&#xff08;原理图&#xff09; 3. 存储器映像 &#xff08;1&#xff09;STM32是32位CPU&#xff0c;数据总线是32位的 &#xff08;2&#xff09;STM232的地址总线是32位的。&#xff08;其实地址总线是32位不是由数据总线是…

MultiPlayerShoot----C++学习记录02人物

获取人物和动画 可以再Mixamo下载你想要的人物&#xff0c;将文件全部导入&#xff08;不做更改&#xff09; 再在网站里选到动画&#xff0c;下载一些动画左转&#xff0c;右转&#xff0c;起跳&#xff0c;跳中&#xff0c;落下 导入动画&#xff0c;此时不用选择导入骨骼&a…

【机器学习】聚类算法Kmeans

文章目录 聚类Kmeans时间复杂度 sklearn.cluster.KMeansn_clusters模型评估指标轮廓系数卡林斯基-哈拉巴斯指数 init & random_state & n_init&#xff1a;初始质心max_iter & tolk_means函数 聚类 聚类就是按照某个特定标准(如距离准则)把一个数据集分割成不同的类…

PhotoShop批量压缩图片

打开photoshop&#xff0c;在顶部的菜单栏选择文件》脚本》图像处理器。 选择合适的参数&#xff0c;运行即可。

【Linux】:权限

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;本期来给大家解读一下有关Linux的基础知识点&#xff0c;如果看完之后对你有一定的启发&#xff0c;那么请留下你的三连&#xff0c;祝大家心想事成&#xff01; C 语 言 专 栏&#xff1a;C语言&#xff1a;从入门到精通 数…

【excel】列转行

列转行 工作中有一些数据是列表&#xff0c;现在需要转行 选表格内容&#xff1a;在excel表格中选中表格数据区域。点击复制&#xff1a;在选中表格区域处右击点击复制。点击选择性粘贴&#xff1a;在表格中鼠标右击点击选择性粘贴。勾选转置&#xff1a;在选择性粘勾选转置选…

OSI网络分层模型

OSI英文全文是Open System Interconnection Reference Model&#xff0c;翻译成中文就是开放式系统互联通信参考模型。 OSI模型分成了七层&#xff0c;部分层次与 TCP/IP 很像&#xff0c;从下到上分别是&#xff1a; 第一层&#xff1a;物理层&#xff0c;网络的物理形式&…

通讯协议学习之路:IIC协议理论

通讯协议之路主要分为两部分&#xff0c;第一部分从理论上面讲解各类协议的通讯原理以及通讯格式&#xff0c;第二部分从具体运用上讲解各类通讯协议的具体应用方法。 后续文章会同时发表在个人博客(jason1016.club)、CSDN&#xff1b;视频会发布在bilibili(UID:399951374) 序&…

PyCharm运行python测试,报错“没有发现测试”/“空套件”

问题描述&#xff1a;没有发现测试/空套件 当时没截图&#xff0c;可惜了&#xff01; 解决办法 把python测试文件的文件名改为非test开头的&#xff01; &#xff08;虽然pytest的官方说要以test开头&#xff0c;但是他这样会有错误&#xff0c;就很…

节流防抖

节流&#xff1a;wait时间内只能执行一次func 防抖&#xff1a;触发后延迟wait秒调用func 代码对比&#xff1a;&#xff08;建议自己手敲一遍&#xff0c;不要养成直接cv的坏习惯&#xff09; 节流&#xff1a; 其中的apply函数是 apply() 是 JavaScript 函数的一个方法…

Python 编程基础 | 第六章-包与模块管理 | 1、包与模块简介

一、模块 在程序开发过程中&#xff0c;文件代码越来越长&#xff0c;维护越来越不容易。可以把很多不同的功能编写成函数&#xff0c;放到不同的文件里&#xff0c;方便管理和调用。在Python中&#xff0c;一个.py文件就称之为一个模块&#xff08;Module&#xff09;。 1、简…

Acwing 3306.装珠饰(十一届蓝桥java/py组J题)

分析&#xff1a; 6件装备作为一个整体去看待&#xff01;&#xff01;&#xff01;加的效果是看总的装备数目 分组背包的一个特点&#xff1a;每一个组里面只能取出一个物品&#xff0c;这里是把抽象成不同的方案数(有点多重背包的二进制处理方法的感觉。) 代码实现&#xff1…

vue-cli脚手架创建项目时报错Error: command failed: npm install --loglevel error

项目背景 环境&#xff1a;vue-cli 5.x 在工程文件中&#xff0c;后端模块wms已经创建完成&#xff0c;现在想新建一个名为vue-web的前端模块 执行命令vue create vue-web时&#xff0c; 报错Error: command failed: npm install --loglevel error 问题分析及解决 排查过程…

2023各版本JDK下载链接

Java Archive | Oracle Java Archive | Oraclehttps://www.oracle.com/java/technologies/downloads/archive/

音乐播放器蜂鸣器AX301开发板verilog,视频/代码

名称&#xff1a;音乐播放器蜂鸣器播放音乐按键切歌 软件&#xff1a;Quartus 语言&#xff1a;Verilog 代码功能&#xff1a; 设计一个音乐播放器&#xff0c;使用板子上的蜂鸣器播放歌曲&#xff0c;可以播放三首歌&#xff08;歌曲任选&#xff09;&#xff0c;通过按键控…

ESP RainMaker 客户案例 #2|PitPat

PitPat 是美国领先的健身品牌&#xff0c;致力于通过游戏化的方式改变人们的锻炼习惯&#xff0c;增强健康。该品牌通过智能设备和相关的移动应用程序为从事家庭锻炼的个人提供虚拟跑步体验。目前&#xff0c;PitPat 针对不同受众群体&#xff0c;开发了Superun&#xff0c;Dee…

JMM-多线程先行发生原则happens-before

5.6 JMM规范下多线程先行发生原则之happens-before 在JVM中&#xff0c;如果一个操作执行的结果需要对另一个操作可见或者代码重排序&#xff0c;那么这两个操作之间 必须存在happens-before&#xff08;先行发生&#xff09;原则&#xff0c;逻辑上的先后关系。 5.6.2 先行并…

9章【同余】

蒙特卡罗算法【和一个模型联系起来】 舍伍德算法【】 拉斯维加斯算法【最不靠谱&#xff0c;思路&#xff1a;把该算法和固有算法相结合】 随机数 学习目标&#xff1a; 利用数据序列的随机性和概率 分布等点&#xff0c;设计解决问题的算法或提高 已有算法的效率。 随机性…