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

embedded/2024/9/24 21:19:29/

题目描述

有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;
}


http://www.ppmy.cn/embedded/45532.html

相关文章

算法(十三)回溯算法---N皇后问题

文章目录 算法概念经典例子 - N皇后问题什么是N皇后问题&#xff1f;实现思路 算法概念 回溯算法是类似枚举的深度优先搜索尝试过程&#xff0c;主要是再搜索尝试中寻找问题的解&#xff0c;当发生不满足求解条件时&#xff0c;就会”回溯“返回&#xff08;也就是递归返回&am…

C++ ─── string的完整模拟实现

本博客实现了string的常见接口实现 下面是用到的一些函数&#xff0c;供大家回顾复习 改进1&#xff1a;流提取的改进 原来的代码中流提取中是一个一个字符提取&#xff0c;扩容频率太快&#xff0c;消耗太多 采用buff的方式&#xff0c;buff在栈上&#xff0c;开空间快。 ist…

【开发日记】ElementUI表单使用原生@submit提交表单数据

使用submit.native.prevent为el-form设置提交方法。 使用native-type为el-button设置原生按钮类型。 示例如下&#xff1a; <el-form class"search" submit.native.prevent"submitSearch"><div classsearch-item>人员ID :<el-input sizemi…

msgpack-c使用指南

msgpack MessagePack 是一种高效的二进制序列化格式&#xff0c;可在多种语言之间交换数据&#xff0c;但它更快、更小。小整数被编码为单个字节&#xff0c;而短字符串除了字符串本身之外只需要一个额外的字节。 msgpackcxx使用指南 msgpackcxx是一个纯头文件库。 安装指南…

新浪测试社招要个25K,第一次面大厂挂了

一面 1、讲下被测系统和你负责测试的模块功能&#xff1f; 2、为什么选择这个测试框架&#xff0c;这个测试框架有什么优缺点&#xff1f; 3、测试文件的目录&#xff0c;包含哪些包&#xff0c;这些之间是怎么调用的&#xff1f; 4、UI自动化和接口自动化都是怎么做的&…

K8S中Prometheus+Grafana监控

1.介绍 phometheus:当前一套非常流行的开源监控和报警系统。 运行原理&#xff1a;通过HTTP协议周期性抓取被监控组件的状态。输出被监控组件信息的HTTP接口称为exporter。 常用组件大部分都有exporter可以直接使用&#xff0c;比如haproxy,nginx&#xff0c;Mysql,Linux系统信…

基于翔云C#语言的身份证实名认证接口开发示例

现如今&#xff0c;安全与便捷成为了互联网服务的两大关键词。为了进一步提升用户体验并加强网络安全管理&#xff0c;国内多家主流App近日宣布完成一项重要功能升级——集成身份证实名认证系接口。这一举措标志着用户在进行App注册时&#xff0c;将享受到更加高效、安全的身份…

【杂项】几个快捷键提高你的办公效率(装13使用)

前言 其实在Windows下不同的IDE也支持在文本编辑的时候&#xff0c;让你不需要使用鼠标也能够快速的操作。下面以VSCODE为例子 从当前位置开始选中 shift 键盘下键多行插入 ctrl alt 鼠标下键 退出多行插入esc回到一行文字开头 Home 键&#xff0c;回到一行文字结尾 End。…