2 条题解

  • 0
    @ 2022-08-08 15:44:59

    //嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎

    #include<iostream>
    using namespace std;

    class Array
    {
    private:
    int size;
    int n;
    int *a;
    public:
    Array(int set_n)
    {
    size=10000;
    a=new int[size];
    n=set_n;
    }

    void set_array()
    {
    for(int i=0;i<n;i++)
    {
    cin>>a[i];
    }
    }

    void output()
    {
    for(int i=0;i<n;i++)
    {
    cout<<a[i]<<" ";
    }
    cout<<endl;
    }

    int i_find_index(int x)
    {
    for(int i=0;i<n;i++)
    if(a[i]==x)
    return i;
    return -1;
    }

    /*
    错误数值
    5
    1 2 3 4 5
    30
    30 1 2 3 4 5
    */

    void sort_insert(int x)
    {
    n=n+1;//提前增大原数组的空间
    int flag=0;
    if(x>=a[n-2])
    {
    a[n-1]=x;
    return;
    }
    for(int i=0;i<n;i++)
    {
    if(a[i]>x)
    {
    flag=i;//flag为第一个大于x的值的下标
    break;//别忘了跳出循环
    }
    }

    for(int i=n-1;i>flag;i--)
    {
    a[i]=a[i-1];
    }
    a[flag]=x;
    }

    };

    int main()
    {
    int n;
    int x;
    cin>>n;
    Array arr(n);
    arr.set_array();
    cin>>x;
    arr.sort_insert(x);
    //cout<<arr.i_find_index(x)<<endl;
    arr.output();
    return 0;
    }

  • 0
    #include<iostream>
    using namespace std;
    
    class Array
    {
    private:
        int size;
        int n;
        int *a;
    public:
        Array(int set_n)
        {
            size=10000;
            a=new int[size];
            n=set_n;
        }
        
        void set_array()
        {
            for(int i=0;i<n;i++)
            {
                cin>>a[i];
            }
        }
        
        void output()
        {
            for(int i=0;i<n;i++)
            {
                cout<<a[i]<<" ";
            }
            cout<<endl;
        }
        
        int i_find_index(int x)
        {
            for(int i=0;i<n;i++)
                if(a[i]==x)
                    return i;
            return -1;
        }
    
        /*
        错误数值
        5
        1 2 3 4 5
        30
        30 1 2 3 4 5
        */
        
        void sort_insert(int x)
        {
            n=n+1;//提前增大原数组的空间
            int flag=0;
            if(x>=a[n-2])
                {
                    a[n-1]=x;
                    return;
                }
            for(int i=0;i<n;i++)
            {
                if(a[i]>x)
                {
                    flag=i;//flag为第一个大于x的值的下标
                    break;//别忘了跳出循环
                }
            }
            
            for(int i=n-1;i>flag;i--)
            {
                a[i]=a[i-1];
            }
            a[flag]=x;
        }
            
            
        
    };
    
    int main()
    {
        int n;
        int x;
        cin>>n;
        Array arr(n);
        arr.set_array();
        cin>>x;
        arr.sort_insert(x);
        //cout<<arr.i_find_index(x)<<endl;
        arr.output();
        
        system("pause");
        return 0;
    }
    
    • @ 2019-09-23 20:57:17

      之前没有判断输入的值与数组最大值的大小关系,以至于如果输入值大于数组最大值,输入值在插入后会排在数组最前面

  • 1

信息

难度
7
分类
(无)
标签
递交数
3045
已通过
634
通过率
21%
被复制
2
上传者