把数组排成最小的数
来源:互联网 发布:手机淘宝卡 编辑:程序博客网 时间:2024/04/29 15:43
题目:输入一个正整数数组,把数组里的所有数字拼接起来排成一个数,打印出能拼接处的所有数字中最小的一个,例如,输入数组,{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;}
0 0
- 把数组排成最小的数--总结
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数--总结
- 把数组排成最小的数--总结
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 把数组排成最小的数
- 分享下:BAT求职经历 B A not T
- Delphi7文件操作常用函数一
- oracle数据库同步技术-高级复制
- ubuntu下minicom的使用
- 王菲穿宽松衣服有孕味
- 把数组排成最小的数
- ui thread
- Android笔记_02
- Android自定义View的实现方法,带你一步步深入了解View(四)
- NYOJ题目460 项链(矩阵相乘最大步数)
- MapReduce初级经典案例实现
- 用Delphi创建各种文件
- leetcode - Binary Tree Level Order Traversal
- 吴超Hadoop7天视频教程