C语言中判断两数组中是否有相同的元素

思路:

首先创建两个数组,分别为a[ ]和b[ ]先拿a数组里的第一个元素和b数组的所有元素比较是否相同,再拿a数组里的第二个元素与b数组所有元素进行比较,以此类推。运用两次for循环来完成,用i循环生成a数组的各个下标,在循环体中用j循环生成b数组下标,j循环中判断a[ i ]是否等于b[ j ],如果条件成立即相同元素。flag用来标记程序运行到某一刻的状态,来加以判断if中的语句是否执行。

system函数的作用是运行以字符串参数的形式传递给他的命令,并且等待该命令的完成,形式:#include <stdlib.h>  int system(const char * string);

代码如下:

#include <stdio.h>
#include <stdlib.h>
int main()
{
	int a[5] = {5,3,2,65,8};
	int b[8] = {78,8,9,56,3,6,0,7};
	int i = 0;
	int j = 0;
	int flag = 0;  //flag用于标记
	for (i = 0; i < 5; i++)
	{
		for (j = 0; j < 8; j++)
		{
			if (a[i] == b[j])
			  flag++;
		}
	}
	if (flag == 0)
	    printf("两数组无相同元素\n");
	else
		printf("两数组有相同元素\n");
	system("pause");
	return 0;
}

为实现代码通用性,下面进行优化,推广到两数组有任意个数的元素,来实现此功能。

代码如下:

#include <stdio.h>
#include <stdlib.h>

int main()
{
	int a[] = {34,24,78,5,3};
	int b[] = {23,7,98,5,23,3};
	int i = 0;
	int j = 0;
	for (i = 0; i < sizeof(a) / sizeof(a[0]); i++)//此时sizeof(a) / sizeof(a[0])=5
	{
		for (j = 0; j < sizeof(b) / sizeof(b[0]); j++)//此时sizeof(b) / sizeof(b[0])=6
		{
			if (a[i] == b[j])
			{
				printf("两数组有相同元素\n");
				system("pause");
				return 0;//存在相同元素就返回,减少循环结构的运行次数
			}
		}
	}
	if (i == sizeof(a) / sizeof(a[0]))
	printf("两数组无相同元素\n");

	system("pause");
	return 0;
}

sizeof( )是一种容量度量函数,功能是返回一个变量或者类型的大小,以字节为单位。

用法:sizeof(类型说明符,数组名或表达式)或sizeof(变量名)。

sizeof(a)是数组a的总大小。整型时sizeof(a[0])=4。因上面代码中数组a中有五个元素,那么此时sizeof(a)=20,sizeof(a[0])=4,所以sizeof(a) / sizeof(a[0])=5。这样无论数组中的元素个数为多少,无论为哪种数据类型,这部分代码都不需要更改了。

下面是其他网友的补充

我们都知道,要判断两个数组中是否有相同的元素,只需要两层for循环,但是在for循环的内部,我们要注意什么时候跳出循环,这个是非常重要的,不能一直输出有,但是也不能既输出有,又输出没有!
下面是第三种方法:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
int main()
{
	int arr1[4] = {0};
	int arr2[5] = {0};
	int i = 0,j=0,k=0;
	printf("请输入数组1(4个元素):\n");
	for(i = 0;i<sizeof(arr1)/sizeof(arr1[0]);i++)
	{
		scanf("%d",&arr1[i]);
	}
	printf("请输入数组2(5个元素):\n");
	for(i=0;i<sizeof(arr2)/sizeof(arr2[0]);i++)
	{
		scanf("%d",&arr2[i]);
	}

	for(j = 0; j<sizeof(arr1)/sizeof(arr1[0]); j++)
	{
		for(k = 0;k<sizeof(arr2)/sizeof(arr2[0]);k++)
		{
			if(arr1[j] == arr2[k])
			{
				printf("有相同元素!\n");
			}
			if(k<sizeof(arr2)/sizeof(arr2[0]))
			{
				break;
			}
		}
		if(j>=sizeof(arr1)/sizeof(arr1[0]))
		printf("没有相同元素!\n");
	}
	return 0;
}

上面的方法就需要判断的多一些了,并且判断的地方也要找准,下面的方法就会简单一些:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
int main()
{
	int arr1[4] = {0};
	int arr2[5] = {0};
	int i = 0,j=0,k=0;
	printf("请输入数组1(4个元素):\n");
	for(i = 0;i<sizeof(arr1)/sizeof(arr1[0]);i++)
	{
		scanf("%d",&arr1[i]);
	}
	printf("请输入数组2(5个元素):\n");
	for(i=0;i<sizeof(arr2)/sizeof(arr2[0]);i++)
	{
		scanf("%d",&arr2[i]);
	}

	for(j = 0; j<sizeof(arr1)/sizeof(arr1[0]); j++)
	{
		for(k = 0;k<sizeof(arr2)/sizeof(arr2[0]);k++)
		{
			if(arr1[j] == arr2[k])
			{
				printf("有相同元素!\n");
				return 0;
			}
		}
	}
	printf("没有相同元素!\n");
	return 0;
}

好了这篇文章先介绍到这了希望大家以后多多支持我们。

(0)

相关推荐

  • C语言中判断两数组中是否有相同的元素

    思路: 首先创建两个数组,分别为a[ ]和b[ ]先拿a数组里的第一个元素和b数组的所有元素比较是否相同,再拿a数组里的第二个元素与b数组所有元素进行比较,以此类推.运用两次for循环来完成,用i循环生成a数组的各个下标,在循环体中用j循环生成b数组下标,j循环中判断a[ i ]是否等于b[ j ],如果条件成立即相同元素.flag用来标记程序运行到某一刻的状态,来加以判断if中的语句是否执行. system函数的作用是运行以字符串参数的形式传递给他的命令,并且等待该命令的完成,形式:#incl

  • C语言中判断两个IPv4地址是否属于同一个子网的代码

    问题描述: 现给定两个IPv4地址,和一个子网掩码,判断是否属于同一个子网,若属于,输出1,否则输出0. 例如输入: 172.16.1.3 172.16.1.35 255.255.255.224 输出: 0 解决方案: 首先将字符串格式的IP地址转化为4字节的IP地址,然后使用与(&)运算,分别将两个IP地址与掩码相与,若最后的值相同,则为同一个子网,否则不是. 以下函数的作用是将字符串格式的IP转化为4字节的IP(因为是4字节,所以使用int,但不同平台的int所占的字节好像不同哈~不太确定)

  • Java与JavaScript中判断两字符串是否相等的区别

    JavaScript是一种常用的脚本语言,这也决定了其相对于其他编程语言显得并不是很规范.在JavaScript中判断两字符串是否相等 直接用==,这与C++里的String类一样.而Java里的等号则是判断两字符串的引用是否一样,判断实体需要用equals()方法,或 者compareTo()方法,这里需要强调的是equals()方法的参数类型,其参数类型绝对不是String类,而是Object类,咱不止一次看 到国内一些教程写的是String类(o(╯□╰)o) 大家可以看看JDK的源码:

  • java 判断一个数组中的数值是否连续相邻的方法

    * 判断一个数组中的数值是否连续相邻 * 满足以下条件: * 1.0是例外可以反复出现 0可以通配任何字符 * 2.相同的数值不会重复出现 * 3.该数组可以是乱序的 * 当数组不含有0时满足最大值-最小值=n(数组长度)-1 * 当数组数组含有0时.满足最大值-最小值<n(数组长度)-1 * 所以,当最大值最大值-最小值>n(数组长度)-1时,一定不是连续相邻数组 package datastruct.usearray; public class JudgeAdjacent { privat

  • 在java中判断两个浮点型(float)数据是否相等的案例

    示例代码: public static void main(String[] args) { float a = 10.222222225f; float b = 10.222222229f; System.out.println("使用==判断是否相等:" + (a == b));// 超出精度范围 System.out.println("使用Math.abs()判断是否相等:" + (Math.abs(a - b) >= 0)); System.out.p

  • 如何在Java中判断两个Long类型是否相等

    目录 一.为什么同样的类型,同样的值,却不相等呢? 1.探索一下源码 二.解决方案 1.可以使用.longValue() 2.equals()进行比较 三.例子 一.为什么同样的类型,同样的值,却不相等呢? 1.探索一下源码 源码中显示,Long中有一个静态的内部类LongCache,专门用于缓存-128至127之间的值,一共256个元素. 如果值在[-128, 127]之间,会放在缓存里面,而超过这个范围就要new一个新的对象,也就是说==不能判断对象是否相等.当然,如果值是在[-128, 1

  • 在python3中实现查找数组中最接近与某值的元素操作

    我就废话不多说了,直接上代码吧! import datetime def find_close(arr, e): start_time = datetime.datetime.now() size = len(arr) idx = 0 val = abs(e - arr[idx]) for i in range(1, size): val1 = abs(e - arr[i]) if val1 < val: idx = i val = val1 use_time = datetime.dateti

  • 在js与java中判断json数据中是否含有某字段的案例

    js中 从服务端传过来一个json数据为data 1.data["key"] != undefined //这种有缺陷,如果这个key定义了,并且就是很2的赋值为undefined,那么这句就会出问题了 2.!("data" in obj) 3.data.hasOwnProperty("key") //后面两种推荐使用 java程序中判断是否存在 data 为从浏览器传回来的json数据 当读取数据的时候最好先加一个判断,不然如果里面不含有该数据

  • 从txt中读入数据到数组中(fscanf)的实现代码

    C-sources: #include<stdio.h> int main() { FILE* fp; //定义一个文件 fp = fopen("p5.txt","r"); if(fp == NULL) { printf("ERROR!\N"); return; } int TwoPointSignal[1000]; int n,k=0,j; while(!feof(fp)) { fscanf(fp,"%d",&a

  • JavaScript中判断两个字符串是否相等的方法

    先将用户的输入值全部转换为大写(或小写),然后再行比较: var name = document.form1.txtUserName.value.toLowerCase(); if(name == "urname") { // statements go here. } JavaScript有两种相等运算符.一种是完全向后兼容的,标准的"==",如果两个操作数类型不一致,它会在某些时候自动对操作数进行类型转换,考虑下面的赋值语句: var strA = "

随机推荐