我爱OJ 2023-02-26 18:39 采纳率: 78.8%
浏览 48
已结题

关于##include#的问题,如何解决?

题目描述
给出N个数,你的任务就是把这n个数从小到大排序^_^
输入
第一行一个整数,N(1<=n<=200000),表示有N个数 接下来有N行,每行一个数
输出
输出N行,表示已经排序的N个数
样例输入
5
2
3
1
4
5
样例输出
1
2
3
4
5
OJ:段错误,检查是否有数组越界,指针异常,访问到不应该访问的内存区域
代码:

#include <bits/stdc++.h>
using namespace std;
int n,t;
int minn=1e9,maxn=-1e9;
int a[200005];
int main(){
    cin>>n;
    for(int i=1; i<=n; i++){
        cin>>t;
        a[t]++;
        minn=min(minn,t);
        maxn=max(maxn,t);
    }
    for(int i=minn; i<=maxn; i++){
        for(int j=1; j<=a[i]; j++){
            cout<<i<<" ";
        }
    }
    return 0;
}
  • 写回答

3条回答 默认 最新

  • a5156520 2023-02-26 19:03
    关注

    如果输入的数大于等于200005,则使用这个数作为下标访问数组a会数组越界;

    从小到大排序,如果要求不高简单使用选择排序或冒泡排序即可,如果时间要求高可以使用希尔排序,下面的例子更改为使用希尔排序:

    修改如下:

    参考链接:


    #include <bits/stdc++.h>
    
    using namespace std;
    int n,t;
    int minn=1e9,maxn=-1e9;
    int a[200005];
    
    
    
    
    
    int main(){
    
        cin>>n;
    
         for(int i=0; i<n; i++){
           // cin>>a[i];
           // a[t]++;
           // minn=min(minn,t);
            //maxn=max(maxn,t);
            cin>>a[i];
        }
        
    // https://blog.csdn.net/tjw316248269/article/details/105207710/
           
           int size = n;
           int gap = n;
           int *arr=a;
        while (gap > 1)
        {
            gap = gap / 3 + 1;    //调整希尔增量
            int i = 0;
            for (i = 0; i < size - gap; i++)    //从0遍历到size-gap-1
            {
                int end = i;
                int temp = arr[end + gap];
                while (end >= 0)
                {
                    if (arr[end] > temp)
                    {
                        arr[end + gap] = arr[end];
                        end -= gap;
                    }
                    else
                    {
                        break;
                    }
                }
                arr[end + gap] = temp;    //以 end+gap 作为插入位置
            }
        }
    
     
       
    
         
      
        
        
        for(int i=0;i<n;i++){
            cout<<a[i]<<endl;
        }
        
    
        return 0;
    }
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月13日
  • 已采纳回答 3月5日
  • 创建了问题 2月26日

悬赏问题

  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的