HDU 1716:排列2 ← next_permutation()

news/2025/3/19 18:57:36/

【题目来源】
http://acm.hdu.edu.cn/showproblem.php?pid=1716

【题目描述】
Ray又对数字的列产生了兴趣:
现有四张卡片,用这四张卡片能排列出很多不同的4位数,要求按从小到大的顺序输出这些4位数。

【输入格式】
每组数据占一行,代表四张卡片上的数字(0<=数字<=9),如果四张卡片都是0,则输入结束。

【输出格式】
对每组卡片按从小到大的顺序输出所有能由这四张卡片组成的4位数,千位数字相同的在同一行,同一行中每个四位数间用空格分隔。
每组输出数据间空一行,最后一组数据后面没有空行。

【输入样例】
1 2 3 4
1 1 2 3
0 1 2 3
0 0 0 0

【输出样例】
1234 1243 1324 1342 1423 1432
2134 2143 2314 2341 2413 2431
3124 3142 3214 3241 3412 3421
4123 4132 4213 4231 4312 4321

1123 1132 1213 1231 1312 1321
2113 2131 2311
3112 3121 3211

1023 1032 1203 1230 1302 1320
2013 2031 2103 2130 2301 2310
3012 3021 3102 3120 3201 3210

【算法代码】

#include <bits/stdc++.h>
using namespace std;int main() {int a[4];while(1) {scanf("%d%d%d%d",&a[0],&a[1],&a[2],&a[3]);if(a[0]+a[1]+a[2]+a[3]==0) break;sort(a,a+4);int flag=0;int t;do {if(a[0]==0) continue;else if(flag==0) {printf("%d%d%d%d",a[0],a[1],a[2],a[3]);flag=1;} else if(t==a[0]) {printf(" %d%d%d%d",a[0],a[1],a[2],a[3]);} else {printf("\n%d%d%d%d",a[0],a[1],a[2],a[3]);}t=a[0];} while(next_permutation(a,a+4));printf("\n\n");}return 0;
}/*
in:
1 2 3 4
1 1 2 3
0 1 2 3
0 0 0 0out:
1234 1243 1324 1342 1423 1432
2134 2143 2314 2341 2413 2431
3124 3142 3214 3241 3412 3421
4123 4132 4213 4231 4312 43211123 1132 1213 1231 1312 1321
2113 2131 2311
3112 3121 32111023 1032 1203 1230 1302 1320
2013 2031 2103 2130 2301 2310
3012 3021 3102 3120 3201 3210
*/



【参考文献】
https://blog.csdn.net/qie_wei/article/details/81068186
https://blog.csdn.net/qq_31741481/article/details/84530287
https://cplusplus.com/reference/algorithm/next_permutation/




 


http://www.ppmy.cn/news/1211842.html

相关文章

C#8.0本质论第十二章--泛型

C#8.0本质论第十二章–泛型 C#通过泛型来促进代码重用&#xff0c;在词义上等价于C模板。 在泛型编程中&#xff0c;数据类型也是一种参数。 12.1如果C#没有泛型 为object的方法使用值类型时&#xff0c;“运行时”将自动对它进行装箱&#xff0c;获取值类型的实例时则需要…

HuggingFace模型头的自定义

在线工具推荐&#xff1a; Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器 在本文中我们将介绍如何使HuggingFace的模型适应你的任务&#xff0c;在Pytorch中建立自定义模型头并将其连接到HF模型的主体&#…

OpenCV入门10:边缘检测

边缘检测是图像处理中常用的操作&#xff0c;用于检测图像中的边缘或轮廓。在OpenCV中&#xff0c;提供了一些函数和方法用于执行边缘提取操作。下面将介绍一些常见的边缘提取方法及其在OpenCV中的实现方式&#xff1a; Canny边缘检测&#xff1a; Canny边缘检测是一种经典的…

Qt 事件循环

引出 UI程序之所叫UI程序&#xff0c;是因为需要与用户有交互&#xff0c;用户交互一般是通过鼠标键盘等的输入设备&#xff0c;那UI程序就需要有能随时响应用户交互的能力。 一个C程序的main函数大概是下面这样&#xff1a; int main() {...return 0; } 我们如何使程序能随…

K8S知识点(八)

&#xff08;1&#xff09;实战入门-Label 通过标签实现Pod的区分&#xff0c;说白了就是一种标签选择机制 可以使用命令是否加了标签&#xff1a; 打标签&#xff1a; 更新标签&#xff1a; 筛选标签&#xff1a; 修改配置文件&#xff0c;重新创建一个pod 筛选&#xff1…

C语言自增自减运算符

自增自减运算符介绍 自增运算符 作用&#xff1a;使得变量 1 int a 10; a; // a 11;自减运算符 – 作用&#xff1a;使得变量 -1 int a 10; a--; // a 9;前置自增和后置自增 前置&#xff08;前缀&#xff09;自增&#xff1a; 在变量前添加符号 a 后置&#xff08;后…

积极应对云网络安全

以下是 IT 领导者需要了解的内容&#xff0c;才能在云网络安全方面占据上风。 如果您的组织尚未主动解决云网络安全问题&#xff0c;则将面临灾难的风险。等待攻击发生根本没有意义。 主动云安全会采取积极措施来发现潜在威胁并在网络攻击发生之前阻止网络攻击。 这是通过持…

Netty第三部

继续Netty第二部的内容 一、ChannelHandler 1、ChannelHandler接口 ChannelHandler是Netty的主要组件&#xff0c;处理所有的入站和出站数据的应用程序逻辑的容器&#xff0c;可以应用在数据的格式转换、异常处理、数据报文统计等 继承ChannelHandler的两个子接口&#xff…