趣味算法------拼数

题目描述

设有 n 个正整数 a 1...a n ,将它们联接成一排,相邻数字首尾相接,组成一个最大的整数。

输入格式
第一行有一个整数,表示数字个数 n。

第二行有 n 个整数,表示给出的 n 个整数 a i。

输出格式
一个正整数,表示最大的整数。

输入输出样例
输入 1

3
13 312 343
输出 1
34331213

输入 2
4
7 13 4 246
输出 2
7424613
输入第一行表示输入数字个数为 3,第二行再给出 3 个整数;首先将 3 个整数进行首尾相接,一个整数位置不变的情况下,将其他整数进行连接组成最大的整数。例如输出 34331213:343 为其中数字最大的值,其次时 312,最后接上 13 即可得出最大整数。

思路解析:

简单来说这道题目的就是将n个数组合拼接求出组合的最大值。这道题有许多不同的方法,比图第一个是暴力求解,也就是将所有的可能都枚举出来,然后一个一个比较,第二是使用深度优先搜索来解决,但是当数据太多时,这两种浪费的时间太多,所以我们需要另一种方法。

假如数据只有7,12时呢?有712和127来比较,如果有7,12,13呢?我们先比较前两个数字,712,127,发现712大,7和12不需要交换位置,然后比较12,13,发现1213<1312,需要交换位置变为7,13,12,最后组合就是71312。

现在按照这个思路我给大家出一组数据。(请在草稿纸上演练)

7,12,13,42,56,53,31。

有没有发现比较熟悉。。。。。。。

这就是我们在早期说过的冒泡排序,可以在往期文章中了解,只不过交换位置判定条件从两个数字之间的大小变成两个数字组合方案的最大值决定。

具体代码:

#include<stdio.h>

#include<math.h>

int fun(int n)

{

int count = 0;

while (n)

{

count++;

n /= 10;

}

return count;

}//求数字的位数。

int check(int n, int m)

{

int count1 = n * pow(10, fun(m)) + m;//count1的值是nm组合

int count2 = m * pow(10, fun(n)) + n;//count2的值是mn组合

if (count1 > count2)

return 1;

return 0;

}

int main(void)

{

int n;

int arr100 = { 0 };

scanf("%d", &n);

for (int i = 0; i < n; i++)

scanf("%d", &arri);//数据输入。

for(int i = 0;i<n;i++)

for (int j = 0; j < n - i - 1; j++)

if (check(arrj+1, arrj))

{

int t = arrj + 1;

arrj + 1 = arrj;

arrj = t;

}//"冒泡"排序

for (int i = 0; i < n; i++)

printf("%d", arri);//按顺序逐个打印。

}

注意:

pow()函数"属于"math.h,传入两个参数,比如pow(n,m)的返回值是n的m次幂,但是要注意返回值非整型。

我们为什么最后不直接打印一个整数呢(组合),而是要按数组顺序打印?这是因为在正常情况下刷题和比赛网站判断正确与否是看显示屏上输出的内容和答案是不是一样,换而言之,

答案打印1213和依次打印1,2,1,3没有什么区别。

实际上我们判断数字需不需要交换还可以看两个相同位上的数字,比如7,17。7显然比1大,所以直接是717,但是逐位判断时间复杂度还会增加,不过当数据量太多时相比起优先搜索和暴力枚举还是很快的。

相关推荐
liulilittle10 小时前
拥塞控制:排水终止的两种决策:OR 与 AND
网络·tcp/ip·计算机网络·算法·信息与通信·tcp·通信
花间相见10 小时前
【LeetCode02】—— 两数之和:哈希表入门经典详解
数据结构·散列表
weixin_3077791310 小时前
从脚本执行到智能体协作:AI辅助测试能力的范式重构
运维·开发语言·人工智能·算法·测试用例
量化君也10 小时前
从回测到全自动实盘交易,全天候策略需要经历哪些改造?
大数据·人工智能·python·算法·金融
fox_lht11 小时前
第十五章 函数式语言:迭代器和闭包
开发语言·后端·学习·算法·rust
lpl31290550911 小时前
skynet 共享数据原理
服务器·c语言·lua
zhengzhouliuhaha12 小时前
智能医疗设备控费系统:以全院一体化管控,筑牢医疗资源“安全阀”
大数据·数据结构·人工智能·算法·安全·机器学习·软件需求
June`12 小时前
CUDA程序效率如何计算以及工具如何使用
算法·cuda
兰令水12 小时前
leecodecode【树形DP】【2026.6.11打卡-java版本】
java·算法·深度优先
装不满的克莱因瓶12 小时前
RLHF中的PPO算法——大语言模型对齐优化的核心引擎
人工智能·python·深度学习·算法·机器学习·语言模型·自然语言处理