日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

最小数排序

發布時間:2023/12/15 综合教程 25 生活家
生活随笔 收集整理的這篇文章主要介紹了 最小数排序 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目:

給定數字0~9若干個。你可以以任意順序排列這些數字,但必須全部使用。目標是使得最后得到的數盡可能小(注意0不能為首
位)。例如:給定兩個0,兩個1,三個5,一個8,我們得到的最小的數就是:10015558.
現給定數字,請編寫程序輸出能夠組成的最小的數。

輸入樣例1:

0 0 5 8 5 1 5 1

輸出樣例1:

10015558

輸入樣例2:

5 6 4 2 3 6 5 0 0 0 6

輸出樣例2:

20003455666

代碼示例:

#include <iostream>

using namespace std;

int main()
{
	int baseNum[10] = { 0 };
	char theGet;
	int count = 0;

	while ((theGet = getchar()) != '
')
	{
		baseNum[theGet-'0']++;
		count++;
	}

	int n;
	for (n = 1; n < 10; n++)			// 首位判斷
	{
		if (baseNum[n] == 0)
			continue;
		else
		{
			cout << n;
			baseNum[n]--;
			break;
		}
	}

	for (n = 0; n < 10; n++)			// 其他位判斷
	{
		if (baseNum[n] == 0)
			continue;
		else
		{
			cout << n;
			baseNum[n]--;
			if (baseNum[n] != 0)
				n--;
		}
	}

	return 0;
}

總結

以上是生活随笔為你收集整理的最小数排序的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。