塘里不喜糖 2021-06-17 13:06 采纳率: 100%
浏览 792
已采纳

写一个函数,对任意一维数组进行降序 排序。

写一个函数,对任意一维数组进行降序
排序。在主函数中随机生成一有n个元
素的一维数组(元素的取值范围载10-90
之间),调用排序函数对该数组进行排
序,并输出排序结果。

  • 写回答

1条回答 默认 最新

  • 抬头见山 2021-06-17 14:32
    关注
    #include <stdio.h>
    #include <random>
    #include <iostream>
    #include <string>
    #include <time.h>
    
    using namespace std;
    
    void InsertSort(int a[], int n)
    {
    	for (int i = 1; i<n; i++) {
    		if (a[i] < a[i - 1]) {               //若第i个元素大于i-1元素,直接插入。小于的话,移动有序表后插入  
    			int j = i - 1;
    			int x = a[i];        //复制为哨兵,即存储待排序元素  
    			a[i] = a[i - 1];           //先后移一个元素  
    			while (x < a[j]) {  //查找在有序表的插入位置  
    				a[j + 1] = a[j];
    				j--;         //元素后移  
    			}
    			a[j + 1] = x;      //插入到正确位置  
    		}
    	}
    }
    
    int main()
    {
    	cout << "请输入产生多个随机数:";
    	int ranNum[100],num = 0;
    	srand((unsigned)time(NULL));//time()用系统时间初始化种。为rand()生成不同的随机种子
    	cin >> num;
    	cout << "随机数组:";
    	for (int i = 0; i < num; i++)
    	{
    		ranNum[i] = 10 + (rand() % 80);
    		cout << " " << ranNum[i];
    	}
    	cout << endl;
    	InsertSort(ranNum, num);
    	cout << "排序后整数序列:";
    	for (int j = num-1; j >= 0; j--) {
    		cout << ranNum[j] << " ";
    	}
    	cout << endl;
    	system("pause");
    	return 0;
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 unity从3D升级到urp管线,打包ab包后,材质全部变紫色
  • ¥50 comsol温度场仿真无法模拟微米级激光光斑
  • ¥15 上传图片时提交的存储类型
  • ¥15 Ubuntu开机显示器只显示kernel,是没操作系统(相关搜索:显卡驱动)
  • ¥15 VB.NET如何绘制倾斜的椭圆
  • ¥15 arbotix没有/cmd_vel话题
  • ¥15 odoo17的分包重新供应路线如何设置?可从销售订单中实时直接触发采购订单或相关单据
  • ¥15 用C语言怎么判断字符串的输入是否符合设定?
  • ¥15 通信专业本科生论文选这两个哪个方向好研究呀
  • ¥50 我在一个购物网站的排队系统排队,这个排队到号后重新定向到目标网站进行购物,但是有技术牛通过技术方法直接跳过排队系统进入目标网址购物,有没有什么软件或者脚本可以用