用数组给三个数排序从小到大
怎么用数组给三个数排序从小到大 排序的方法现在的就有很多种。要用哪种,你可以先了解下,然后再自己敲代码。
参考:
https://blog.csdn.net/mwj327720862/article/details/80498455 temp = (23,54,23)
num = list(temp)
b = sorted(num)
print(b)
这样,大小就排好啦 本帖最后由 bin554385863 于 2019-10-16 23:11 编辑
#include <iostream>
#include <algorithm>
#include <vector>
void _sort()
{
int n = 1;
std::cout << "请输入数字的个数" << std::endl;
std::cin >> n;
std::vector<int> vec;
char arg;
std::cout << "升序请输入l, 降序请输入g" << std::endl;
std::cin >> arg;
if (arg != 'l' && arg != 'g')
{
std::cout << "参数错误";
exit(1);
}
std::cout << "请输入要排序的数字" << std::endl;
for (size_t i = 0; i < n; i++)
{
int t = 0;
std::cin >> t;
vec.push_back(t);
}
switch (arg)
{
case 'l':
sort(vec.begin(), vec.end(), std::less<int>()); //升序排序
break;
case 'g':
sort(vec.begin(), vec.end(), std::greater<int>()); //降序排序
default:
break;
}
for (int i : vec)
{
std::cout << i << "";
}
std::cout << std::endl;
}
int main(int argc, char const *argv[])
{
_sort();
return 0;
}
---------------------------------------------------------------------------------------------------------
E:\Users\86184\Documents\Code>c:\Users\86184\.vscode\extensions\ms-vscode.cpptools-0.25.1\debugAdapters\bin\WindowsDebugLauncher.exe --stdin=Microsoft-MIEngine-In-0ukibrgw.dct --stdout=Microsoft-MIEngine-Out-1gtvnay5.w3q --stderr=Microsoft-MIEngine-Error-akvbthh3.ems --pid=Microsoft-MIEngine-Pid-cwckpbd2.ods "--dbgExe=E:\My Program\MinGW\bin\gdb.exe" --interpreter=mi
请输入数字的个数
9
升序请输入l, 降序请输入g
l
请输入要排序的数字
20 36 65 98 10 0 32 56 9
0910203236566598
E:\Users\86184\Documents\Code> 其实,最简单的冒泡排序法就很容易了,比如
4,6,2这三个数
先用前两个比较,把大的数6放右边,这里4,6就不用交换了,然后6,2比较,把6放2右边,这一次遍历就把最大的值放右边了,总共遍历N-1次就好,代码如下
int i,temp;
for(k = 9;k >0;k--)
{
for(n = 0;n<k;n++)
{
if(i > i)
{
temp = i;
i = i;
i = temp;
}
}
}
页:
[1]