C语言给定数字0-9各若干个。你可以以任意顺序排列这些数字,但必须全部使用。目标是使得最后得到的数尽可能小(注意0不能做首位)

这个题目要求的输出是一串数字!!!

**不是下面:**输入在一行中给出 10 个非负整数,顺序表示我们拥有数字 0、数字 1、......数字 9 的个数。整数间用一个空格分隔。10 个数字的总个数不超过 50,且至少拥有 1 个非 0 的数字。

输入:5 8 5 5 1 1 0 0(输入8个数:两个0,两个1,三个5,一个8)

输出:10015558

代码如下:

#include <stdio.h>

int main()

{

int a100;

int b10={0};

char ch;

int j,i=0;

do

{

scanf("%d", &ai);

i++;

} while ((ch = getchar()) != '\n');

for (j = 0; j < i; j++){

switch(aj){

case 0:b0++;break;

case 1:b1++;break;

case 2:b2++;break;

case 3:b3++;break;

case 4:b4++;break;

case 5:b5++;break;

case 6:b6++;break;

case 7:b7++;break;

case 8:b8++;break;

case 9:b9++;break;

}

}

for(i=1;i<10;i++)

{

if(bi!=0)

{

printf("%d",i);

bi--;

break;

}

}

for(i=0;i<10;i++)

{

for(j=0;j<bi;j++)

{

printf("%d",i);

}

}

return 0;

}

结果如下:

思路:

这道题目首先现将输入的内容放到一个数组里面,然后通过一个switch得到每一个数字出现的个数。然后根据这个个数找到不为0的第一个数字作为首位然后再从小到大输出即可。

相关推荐
Irissgwe6 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白6 小时前
数据容器集合set/frozenset
数据结构
凌波粒6 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle6 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
码云骑士6 小时前
13-列表append的底层真相(上)-listobject源码中的预分配策略
开发语言·python
浦信仿真大讲堂6 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠6 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
卡梅德生物科技小能手6 小时前
卡美德生物科普CD136(RON受体):从基础特性到实验应用
经验分享·深度学习·生活
sweetone6 小时前
SONY老式磁带随身听wm-fx193 之摩机过程(提升重低音音效,改耳放)
经验分享·音视频
代码中介商7 小时前
跳表:高效查找的链表黑科技
数据结构