C语言题目:数字不重复排列

题目描述

有4个互不相同的数字,输出由其中三个不重复数字组成的排列。

输入格式

4个整数。

输出格式

所有排列

样例输入

复制代码
1 2 3 4

样例输出

复制代码
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
1 2 4
1 4 2
2 1 4
2 4 1
4 1 2
4 2 1
1 3 4
1 4 3
3 1 4
3 4 1
4 1 3
4 3 1
2 3 4
2 4 3
3 2 4
3 4 2
4 2 3
4 3 2

代码分析

  1. #include <stdio.h>:包含标准输入输出库,用于进行输入输出操作。

  2. int main(void):定义主函数,void表示不需要任何参数。

  3. int arr[4];:声明一个整型数组arr,大小为4,用于存储用户输入的整数。

  4. for (int i = 0; i < 4; i++):外层循环,用于读取用户输入。

  5. scanf("%d", &arr[i]);:通过scanf函数从标准输入读取一个整数,并将其存储在数组arr的第i个位置。

  6. int m = 3;:声明一个整型变量m并初始化为3,这个变量用于在循环中指定要跳过的元素的索引。

  7. while (m >= 0):定义一个while循环,条件是m大于等于0,循环会执行4次,因为m将从3递减到0。

  8. for (int i = 0; i < 4; i++):第一个嵌套循环,用于遍历数组arr中的元素。

  9. if (i == m) continue;:如果当前索引i等于要跳过的索引m,则跳过当前循环的剩余部分。

  10. for (int j = 0; j < 4; j++):第二个嵌套循环,用于与外层循环中的元素进行配对。

  11. if (j == m) continue;:同上,跳过索引为m的元素。

  12. for (int k = 0; k < 4; k++):第三个嵌套循环,用于与前两个循环中的元素进行配对。

  13. if (k == m) continue;:同上,跳过索引为m的元素。

  14. if (i != j && i != k && j != k):一个条件判断,确保ijk三个索引互不相同,即生成的三元组中没有重复的元素。

  15. printf("%d %d %d \n", arr[i], arr[j], arr[k]);:如果条件满足,则打印三元组arr[i]arr[j]arr[k]

  16. m--;:在while循环的每次迭代结束时,将m减1,这样在下一次迭代中,会跳过数组中的下一个元素。

  17. return 0;:主函数返回0,表示程序正常结束。

整体流程分析

  • 程序首先读取用户输入的4个整数到数组arr中。
  • while循环控制了4次迭代,每次迭代中m的值递减,分别对应数组中索引为3、2、1、0的元素。
  • 在每次while循环中,有三个嵌套的for循环,它们分别遍历数组arr中的元素,但会根据变量m的值跳过一个特定的元素。
  • 通过三层循环的嵌套,程序生成所有可能的三元组(三个不同的元素的组合),并检查这些组合中的元素是否互不相同。
  • 如果三元组中的元素互不相同,则通过printf函数打印出来。

源代码

复制代码
#include <stdio.h>
int main(void)
{
	int arr[4];
	for (int i = 0; i < 4; i++)
	{
		scanf("%d", &arr[i]);
	}
	int m = 3;
	while (m >= 0)
	{
		for (int i = 0; i < 4; i++)
		{
			if (i == m)
				continue;
			for (int j = 0; j < 4; j++)
			{
				if (j == m)
					continue;
				for (int k = 0; k < 4; k++)
				{
					if (k == m)
						continue;
					if (i != j && i != k && j != k)
					{
						printf("%d %d %d \n", arr[i], arr[j], arr[k]);
					}
				}
			}
		}
		m--;
	}
	return 0;
}
相关推荐
Pluchon17 小时前
硅基计划4.0 算法 FloodFill算法
java·算法·leetcode·决策树·逻辑回归·深度优先·图搜索算法
菜鸟233号18 小时前
力扣347. 前k个高频元素 java实现
算法
小许学java18 小时前
数据结构-模拟实现顺序表和链表
java·数据结构·链表·arraylist·linkedlist·顺序表模拟实现·链表的模拟实现
Xの哲學19 小时前
Linux设备管理:从内核驱动到用户空间的完整架构解析
linux·服务器·算法·架构·边缘计算
xinyu_Jina19 小时前
Info Flow:去中心化数据流、跨协议标准化与信息源权重算法
算法·去中心化·区块链
Jac_kie_層樓19 小时前
力扣hot100刷题记录(12.2)
算法·leetcode·职场和发展
稚辉君.MCA_P8_Java20 小时前
Gemini永久会员 C++返回最长有效子串长度
开发语言·数据结构·c++·后端·算法
京东零售技术20 小时前
下一代 Lakehouse 智能未来新引擎 | Apache Hudi Meetup亚洲站活动回顾
算法
京东零售技术20 小时前
NeurIPS 2025 | TANDEM:基于双层优化的数据配比学习方法
后端·算法
zmzb010321 小时前
C++课后习题训练记录Day42
开发语言·c++·算法