yy666624 2021-09-22 18:28 采纳率: 100%
浏览 46
已结题

C++随机数无重复放入数组,为什么最大只能跑到30000左右,再多就跑不出来


#include <iostream>
#include "time.h"
using namespace std;

void algorithm(int arr[], int length, int left, int right)
{
    bool* used = new bool[right + 1];
    for (int i = left; i < right + 1; i++)
    {
        used[i] = false;
    }
    
    int random = randomInt(left, right);
    for (int j = 0; j < length; j++)
    {
        while (used[random])
        {
            random = randomInt(left, right);
        }
        used[random] = true;
        arr[j] = random;
    }
    delete[]used;
}

int main() {

    clock_t start, finish;

    start = clock();
    int* arr = new int[33500];
    algorithm(arr,33500,1, 50000);
    cout << endl;
    finish = clock();
    delete[]arr;
    cout << "用时:" << (double)(finish - start) << "ms" << endl;
    
}

到30000用时20ms,再多就跑不出来,也不报错,这是为什么,求解答。

  • 写回答

1条回答 默认 最新

  • 关注

    img


    可能是因为随机数生成器最多只能生成32768种结果
    你在代码中将上限改为32768还可以正常跑,但是改为32769就不行了,所以推测你的随机数生成只有32768种结果,无法找到第32769种结果,所以陷入死循环.
    有帮助望采纳

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

报告相同问题?

问题事件

  • 系统已结题 9月30日
  • 已采纳回答 9月22日
  • 创建了问题 9月22日

悬赏问题

  • ¥100 连续两帧图像高速减法
  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写