C语言数组练习以及场景练习题

写了那么久的知识点梳理,今天来写点自己觉得不错的练习题来分享,顺便来巩固自己的知识点,和加强题型的解决方法的记忆。今天给大家带来的有数组的找数字题目,以及场景找凶手的题目,下面让我们来看看今天的第一道题目。

目录

有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,请编写程序在这样的矩阵中查找某个数字是否存在。要求:时间复杂度小于O(N)。

一个数组中只有两个数字是出现一次,其他所有数字都出现了两次。编写一个函数找出这两个只出现一次的数字。例如:有数组的元素是:1,2,3,4,5,1,2,3,4,6只有5和6只出现1次,要找出5和6.

日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个嫌疑犯的一个。以下为4个嫌疑犯的供词:A说:不是我。B说:是C。C说:是D。D说:C在胡说已知3个人说了真话,1个人说的是假话。现在请根据这些信息,写一个程序来确定到底谁是凶手。



有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,请编写程序在这样的矩阵中查找某个数字是否存在。要求:时间复杂度小于O(N)。

大家看到题目是否有了自己的思路了呢?下面我展示一下答案。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

int Find_Num(int p[][4], int i, int j, int key)
{
	int x = 0;
	int y = j - 1;
	while (x < i && y < j)
	{
		if (p[x][y] > key)
		{
			y--;
		}

		if (p[x][y] < key)
		{
			x++;
		}

		if (p[x][y] == key)
		{
			return p[x][y];
		}

	}

	return 0;




}




int main()
{
	int ret = 0;
	int arr[4][4] = { {1,2,3,4},{5,6,7,8,},{11,12,13,14},{22,33,44,55} };
	int key = 0;
	
	printf("请输入你想查找的数字\n");
	scanf("%d", &key);

	ret=Find_Num(arr, 4, 4,key);
	if (ret != 0)
	{
		printf("数组中存在这个数字\n");

	}
	else
	{
		printf("数组中不存在这个数字\n");

	}
	return 0;
}

 

 

首先我们需要借助图来解析我的代码思路

 首先我们从题目知道,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,那我们先按照题目设一些值。首先我们不能从第一行第一列一个一个往下找吧,不然这样就太耗费时间了,就不符合要求了。那怎么办呢,那我们就要想到一个奇妙的位置那就是右上角的位置,为什么要这样呢?首先在这个位置上我们首先对右上角的值,例如图中的4与Key进行对比,因为key大于4,那么就是要找比4大的数,也就是往下一行进行查找,因为在4的左边的数比4还要小。这样我们就可以排除掉一行的值,在下来也类似,8比Key大那么往小里找,8往下的值比8还大,那么舍弃掉这一列。直到找到Key与p[x][y]相等为止。

所以代码中就有这么些代码:

if (p[x][y] > key)
        {
            y--;
        }

        if (p[x][y] < key)
        {
            x++;
        }

        if (p[x][y] == key)
        {
            return p[x][y];
        }

 

接下来我们看第二题:

一个数组中只有两个数字是出现一次,其他所有数字都出现了两次。
编写一个函数找出这两个只出现一次的数字。
例如:
有数组的元素是:1,2,3,4,5,1,2,3,4,6
只有5和6只出现1次,要找出5和6.


看过我前面的文章的是不是觉得似曾相识呢?与前面不同的是,这个题目要找的是两个数这么一看,大家能否有思路解决这道题呢。下面先展示参考答案。

FindNum(int arr[], int* num1, int* num2,int n)
{

	int i = 0;
	int tem=0;
	for (i = 0; i < n; i++)
	{
		tem ^= arr[i];
	}

	int k = 0;
	for (i = 0; i < 32; i++)
	{
		if ((tem >> i) & 1 == 1)
			 k = i;

	}


	for (i = 0; i < n; i++)
	{
		if (((arr[i] >> k) & 1) == 1)
		{
			*num1^= arr[i];
		}

		else
		{
			*num2^=arr[i];
		}
	}

}




int main()
{
	int arr[10] = { 1,2,3,4,76,4,3,2,1,45 };
	int sz = sizeof(arr) / sizeof(arr[2]);
	int num1 = 0;
	int num2 = 0;
	FindNum(arr, &num1, &num2, sz);
	printf("%d %d", num1, num2);


	return 0;
}

 

这道题要解释起来,我们还是得画图来理解: 

解析:首先我们如图解所说要将数分成两部分,然后需要异或操作符。我们前面将过两个公式不知道大家是否记得:

a^a=0;

0^a=a; 

这两个公式就可以让我们区分一个单次出现过的数,但是这里如何将数组的数区分成两部分呢?首先我们将数组中的所有数进行异或,那么我们最终异或得到的值存到tem中,如上方:这时tem=76^45 ,那么大家仔细一想异或操作符,相异为1,这是不是就是两个数的区别了,那么这时我们就可以想一下能否从这个地方找到方法区分两个数和其他数两两分到同一部分呢。这里我们就可以从32位比特上找到tem中为1的那一个比特位,(可看下图理解)然后将数组中的所有数为1的分为一部分,为0的分为一部分,这样我们就可以将数组的数分为两部分,然后不断异或就可以得到两个数,这既是那两个数组中只出现一次的数。如图:

代码解释:

将tem进行异或后,用tem借助>>操作符找到为1的比特位,然后再用>>和^操作符进行分类,最后得到两个数,打印即可。


 最后一道场景题:

日本某地发生了一件谋杀案,警察通过排查确定杀人凶手必为4个嫌疑犯的一个。

以下为4个嫌疑犯的供词:

A说:不是我。
B说:是C。
C说:是D。
D说:C在胡说
已知3个人说了真话,1个人说的是假话。

现在请根据这些信息,写一个程序来确定到底谁是凶手。


根据这个场景各位能否想到方法来找出凶手呢?下面展示参考代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	char Killer;

	for (Killer = 'a'; Killer <= 'd'; Killer++)
	{
		if (((Killer != 'a') + (Killer =='c') + (Killer == 'd') + (Killer != 'd')) == 3)
		{
			break;
		}
	}
	printf("%c是凶手\n", Killer);
	return 0;
}

这么一看是否发现其实代码很简洁,但是这道题却很考验对代码的熟练和思维。

从题目中我们知道四个人中有一个人是凶手,所有四个人中有三个人说的话是真的,只有凶手说假的话。那么我们就需要思考出怎么在代码中确定什么时候是3个人说真话,1个人说假话得场景。

代码中我们就运用到判断语句,我们知道在C语言中判断语句中,真为1,假为0,这时我们可以根据四个人讲的话作为条件,进行判断,最后相加起来,当为3时,就是凶手,这时我们就需要代码轮番将四个人假设为凶手,那我们也要知道字符++,也是根据ASCII码值来储存,++就会得到下一个字符了。这么一解释,相信各位就已经能看懂代码了吧。


文章已到篇尾,能看到这里也谢谢您的支持了,可以的话记得三连哟。

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

一文带你读懂编码和解码

编码和解码 编码&#xff1a;将字符转换为对应的二进制序列的过程叫做字符编码。 解码&#xff1a;将二进制序列转换为对应的字符的过程叫做字符解码。 py文件的创建&#xff1a; 文本编辑器在内容没有保存前&#xff0c;内容以编辑器默认编码形式保存在内存中。pycharm默认…

我要成为嵌入式高手之2月4、5日Linux高编第二天!!

读写函数接口 1、fgetc 语法&#xff1a; 功能&#xff1a;从流中获取一个字符 练习1&#xff1a;编写程序统计文件的行数 #include <stdio.h>int main(void) {FILE *fp NULL;char ch 0;int row 0;fp fopen("file.txt","r");if (NULL fp){pe…

5 分钟让你了解什么是搜索引擎

文章目录 搜索引擎概述基于业务模式分类垂直搜索&#xff08;垂搜&#xff09;通用搜索&#xff08;通搜&#xff09;本地搜索引擎 基于技术实现分类基于关键词的搜索引擎&#xff08;Keyword-based Search Engine&#xff09;语义搜索引擎&#xff08;Semantic Search Engine&…

好用的大学生教材搜题软件?帮助大学生解决问题的实用搜题工具 #知识分享#知识分享#经验分享

对于大学生来说&#xff0c;每天面对各式各样的学习任务和问题&#xff0c;寻找合适的学习资源和工具成了我们的迫切需求。幸运的是&#xff0c;现如今有许多高效且实用的日常搜题和学习软件可以满足我们的需求&#xff0c;助力我们取得更好的学习成果。 1.Forest专注森林 Fo…

力扣:42. 接雨水 84.柱状图中最大的矩形(单调栈,双指针)

这两道题解题思路类似&#xff0c;一个是单调递增栈&#xff0c;一个是单调递减栈。本篇博客给出暴力&#xff0c;双指针和单调栈解法。 42. 接雨水 题目&#xff1a; 给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后…

CIFS(Samba)服务的使用

理论部分 概念&#xff1a; 通用互联网文件系统CIFS使用的是公共的或者开放的SMB协议版本。SMB是在会话层和表示层以及小部分应用层上的 协议&#xff0c;使用了NetBIOS的应用程序接口API。该协议在局域网上用于服务器文件访问和打印。它使用客户/服务器模式&#xff0c;客 户…

ffmpeg的使用,安装,抽帧,加水印,截图,生成gif,格式转换,抓屏等

实际使用中总结的关于ffmpeg对视频的处理的记录文档 具体信息&#xff1a; http://ffmpeg.org/download.html 官网下载ffmpeg 关于ffmpeg的安装详细步骤和说明 装ffmpeg 方式,Linux和windows下的 http://bbs.csdn.net/topics/390519382 php 调用ffmpeg , http://bbs.csdn.net/t…

【算法】利用递归dfs解决二叉树算法题(C++)

文章目录 1. 前言2. 算法题2331.计算布尔二叉树的值129.求根节点到叶节点数字之和LCR047.二叉树剪枝98.验证二叉搜索树230.二叉搜索树中第K小的元素257.二叉树的所有路径 1. 前言 有关 递归 的相关解释与解题 请看下文&#xff1a; 以汉诺塔理解递归、并用递归解决算法题 对于…

关于Linux和消息队列常见的十道面试题

实际工作中如何排查CPU飙升问题&#xff1f; 在实际工作中&#xff0c;我们可以通过以下步骤来排查CPU飙升的问题&#xff1a; 使用系统监控工具&#xff1a;首先&#xff0c;我们可以使用系统监控工具&#xff0c;如top命令&#xff0c;来查看所有进程占系统CPU的排序。这样可…

AI助力农作物自动采摘,基于YOLOv7【tiny/l/x】不同系列参数模型开发构建作物生产场景下番茄采摘检测计数分析系统

去年十一那会无意间刷到一个视频展示的就是德国机械收割机非常高效自动化地24小时不间断地在超广阔的土地上采摘各种作物&#xff0c;专家设计出来了很多用于采摘不同农作物的大型机械&#xff0c;看着非常震撼&#xff0c;但是我们国内农业的发展还是相对比较滞后的&#xff0…

【深度学习】从0完整讲透深度学习第2篇:TensorFlow介绍和基本操作(代码文档已分享)

本系列文章md笔记&#xff08;已分享&#xff09;主要讨论深度学习相关知识。可以让大家熟练掌握机器学习基础,如分类、回归&#xff08;含代码&#xff09;&#xff0c;熟练掌握numpy,pandas,sklearn等框架使用。在算法上&#xff0c;掌握神经网络的数学原理&#xff0c;手动实…

2024数学建模美赛F题Reducing Illegal Wildlife Trade原创论文讲解(含完整python代码)

大家好呀&#xff0c;从发布赛题一直到现在&#xff0c;总算完成了数学建模美赛本次F题目非法野生动物贸易完整的成品论文。 本论文可以保证原创&#xff0c;保证高质量。绝不是随便引用一大堆模型和代码复制粘贴进来完全没有应用糊弄人的垃圾半成品论文。 F题论文共42页&…

MySQL温故篇(一)SQL语句基础

一、SQL语句基础 1、SQL语言分类 DDL&#xff1a;数据定义语言 DCL&#xff1a;数据控制语言 DML&#xff1a;数据操作语言 DQL&#xff1a;数据的查询语言 2、数据类型 3、字符类型 char(11) &#xff1a; 定长 的字符串类型,在存储字符串时&#xff0c;最大字符长度11个&a…

PiflowX新增Apache Beam引擎支持

参考资料&#xff1a; Apache Beam 架构原理及应用实践-腾讯云开发者社区-腾讯云 (tencent.com) 在之前的文章中有介绍过&#xff0c;PiflowX是支持spark和flink计算引擎&#xff0c;其架构图如下所示&#xff1a; 在piflow高度抽象的流水线组件的支持下&#xff0c;我们可以…

【C/C++】C/C++编程——整型(二)

在 C 中&#xff0c;整型数据可以分为有符号数&#xff08;Signed&#xff09;和无符号数&#xff08;Unsigned&#xff09;&#xff0c;这两种类型主要用于表示整数值&#xff0c;但它们在表示范围和用途方面有所不同。默认情况下&#xff0c;整数类型如 int、short、long 都是…

爱上JUC: 面试常考题大总结(线程安全篇)

&#x1f31f;一起备战面试吧&#x1f604;&#xff0c;也是巩固&#x1f4aa;&#xff0c;不再害怕面试&#x1f44a; 文章目录 进程和线程区别并行和并发的区别创建线程的方式有哪些runnable和callable有什么区别run和start区别线程包含哪些状态&#xff0c;是如何转换的&…

【TCP/IP】用户访问一个购物网站时TCP/IP五层参考模型中每一层的功能

当用户访问一个购物网站时&#xff0c;网络上的每一层都会涉及不同的协议&#xff0c;具体网络模型如下图所示。 以下是每个网络层及其相关的协议示例&#xff1a; 物理层&#xff1a;负责将比特流传输到物理媒介上&#xff0c;例如电缆或无线信号。所以在物理层&#xff0c;可…

DockerUI如何部署结合内网穿透实现公网环境管理本地docker容器

文章目录 前言1. 安装部署DockerUI2. 安装cpolar内网穿透3. 配置DockerUI公网访问地址4. 公网远程访问DockerUI5. 固定DockerUI公网地址 前言 DockerUI是一个docker容器镜像的可视化图形化管理工具。DockerUI可以用来轻松构建、管理和维护docker环境。它是完全开源且免费的。基…

基于协同算法的图书信息管理系统(编号V73)

Java精品项目源码基于协同算法的图书信息管理系统(编号V73) 大家好&#xff0c;小辰今天给大家介绍一个图书信息管理系统&#xff0c;演示视频公众号&#xff08;小辰哥的Java&#xff09;对号查询观看即可 文章目录 Java精品项目源码基于协同算法的图书信息管理系统(编号V73…

Pandas.Series.cumsum() 累积和 详解 含代码 含测试数据集 随Pandas版本持续更新

关于Pandas版本&#xff1a; 本文基于 pandas2.2.0 编写。 关于本文内容更新&#xff1a; 随着pandas的stable版本更迭&#xff0c;本文持续更新&#xff0c;不断完善补充。 传送门&#xff1a; Pandas API参考目录 传送门&#xff1a; Pandas 版本更新及新特性 传送门&…