设置在最小数目的阵列

简介:

称号:输入一个正整数数组,所有的数字拼接在一起阵列形成了几个,打印出所有的数字可以拼接在最低限度,例如,输入数组。{32,321},则打印出这个3个数字能排成的最小数字32132.

通过比較组合的字符串的大小来排序原来的整数数组,比如 32和321比較的结果是 ”32321“>"32132" 所以觉得 32是大于321的。利用冒泡排序的方法解决之。

int compare2int(int a,int b){//比較字符串a+b与b+a的大小
	char s1[10],s2[10],tmp1[10];
	sprintf(s1,"%d",a);
	sprintf(tmp1,"%d",a);
	sprintf(s2,"%d",b);
	strcat(tmp1,s2);
	strcat(s2,s1);
	int result=strcmp(tmp1,s2);//比較ab与ba的大小
	return result;
}
void bubbleSort(int a[],int len){
	int tmp;
	for(int i=0;i<len;i++){
		for(int j=1;j<len-i;j++){
			if(compare2int(a[j-1],a[j])==1){//假设a[j-1]a[j]大于a[j]a[j-1],则觉得a[j-1]大于a[j]交换它们
				tmp=a[j];
				a[j]=a[j-1];
				a[j-1]=tmp;
			}
		}
	}
	for(int k=0;k<len;k++){
		printf("%d ",a[k]);
	}
	printf("\n");
}
int main()
{
	int test[]={3,32,321};
	bubbleSort(test,3);
	return 0;
}


版权声明:本文博客原创文章。博客,未经同意,不得转载。






本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4678559.html,如需转载请自行联系原作者


相关文章
|
2月前
|
算法
7-6 连续因子
7-6 连续因子
30 0
|
2月前
和最小的K个数对
和最小的K个数对
|
2月前
1679.K和数对的最大数目
1679.K和数对的最大数目
18 0
|
2月前
连通块中点的数量
连通块中点的数量
25 0
|
机器学习/深度学习 人工智能 算法
【算法 | 实验8】分配最小页数(数组划分和最大值最小化问题)
【算法 | 实验8】分配最小页数(数组划分和最大值最小化问题)
224 0
【算法 | 实验8】分配最小页数(数组划分和最大值最小化问题)
|
机器学习/深度学习
f(n)+n,求第k次的结果。f(n)为n的最小公因数
f(n)+n,求第k次的结果。f(n)为n的最小公因数
42 0
L1-006 连续因子 (20 分)
L1-006 连续因子 (20 分)
117 0
7-8 连续因子 (20 分)
7-8 连续因子 (20 分)
93 0
输出2000-3000之间所有十位数是m且是n的倍数的数的个数
输出2000-3000之间所有十位数是m且是n的倍数的数的个数
105 0

热门文章

最新文章

  • 1
    流量控制系统,用正则表达式提取汉字
    26
  • 2
    Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推
    26
  • 3
    Redis08命令-Hash类型,也叫散列,其中value是一个无序字典,类似于java的HashMap结构,Hash结构可以将对象中的每个字段独立存储,可以针对每字段做CRUD
    27
  • 4
    Redis07命令-String类型字符串,不管是哪种格式,底层都是字节数组形式存储的,最大空间不超过512m,SET添加,MSET批量添加,INCRBY age 2可以,MSET,INCRSETEX
    28
  • 5
    S外部函数可以访问函数内部的变量的闭包-闭包最简单的用不了,闭包是内层函数+外层函数的变量,简称为函数套函数,外部函数可以访问函数内部的变量,存在函数套函数
    24
  • 6
    Redis06-Redis常用的命令,模糊的搜索查询往往会对服务器产生很大的压力,MSET k1 v1 k2 v2 k3 v3 添加,DEL是删除的意思,EXISTS age 可以用来查询是否有存在1
    31
  • 7
    Redis05数据结构介绍,数据结构介绍,官方网站中看到
    22
  • 8
    JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
    20
  • 9
    JS数组操作---删除,arr.pop()方法从数组中删除最后一个元素,并返回该元素的值,arr.shift() 删除第一个值,arr.splice()方法,删除指定元素,arr.splice,从第一
    20
  • 10
    定义好变量,${age}模版字符串,对象可以放null,检验数据类型console.log(typeof str)
    19