| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1229 人关注过本帖
标题:各位大神。这是一段归并排序的函数。在编译的时候除了一个问题
只看楼主 加入收藏
qq472739119
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2017-1-1
结帖率:75%
收藏
已结贴  问题点数:18 回复次数:3 
各位大神。这是一段归并排序的函数。在编译的时候除了一个问题
程序代码:
#ifndef _MERGESORT_H_
#define    _MERGESORT_H_

#include <iostream>
#include <algorithm>
#include <string>
using namespace std;

template<typename T>
void __merge(T *arr, int l, int mid, int r)
{
    T aux[r - l + 1];
    for (int i = l; i <= r; ++i)
        aux[i - l] = arr[l + i];
    int i = l, j = mid +1;
    for (int k = l; k <= r; ++k)
    {
        if (i > mid){
            arr[k] = aux[j - l];
            ++j;
        }
        else if (j > r)    {
            arr[k] = aux[i - l];
            ++i;
        }
        else if (aux[i - l] < aux[j - l]){
            arr[k] = aux[i - l];
            ++i;
        }
        else{
            arr[k] = aux[j - l];
            ++j;
        }
    }
}

template<typename T>
void __mergeSort(T *arr, int l, int r)
{
    
    if (l >= r)
        return;
    int mid = (l + r) / 2;
    __mergeSort(arr, l, mid);
    __mergeSort(arr, mid + 1, r);
    __merge(arr, l, mid, r);
}

template<typename T>
void mergeSort(T *arr, int n)
{

    __mergeSort(arr, 0, n - 1);
}

#endif //_MERGESORT_H_


在测试文件中已经将各函数值正确的调用,但是编译的时候,在__merge函数中,提示aux[]大小未知,说它的大小不是常量表达式。这是为什么呢?
我用的是VS2013。
搜索更多相关主题的帖子: color 
2017-03-13 22:47
qq472739119
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2017-1-1
收藏
得分:0 
我明白了,VS并不支持数组大小是变量表达式,将这个代码这样写“T *aux = T [r-l+1];”就可以了,最后记着在__merge函数中,将这个new出来的空间deleted掉。
2017-03-14 08:58
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9030
专家分:54050
注 册:2011-1-18
收藏
得分:18 
建议你参考一下 std::merge 的实现(你的算法竟然需要另开一个数组)。
另外,下标用int,说实话,我没见过。
收到的鲜花
  • qq4727391192017-03-14 09:46 送鲜花  3朵   附言:我很赞同
2017-03-14 09:29
qq472739119
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2017-1-1
收藏
得分:0 
回复 3楼 rjsp
奥!是的,是的。感谢大神鞭策指导!
2017-03-14 09:45
快速回复:各位大神。这是一段归并排序的函数。在编译的时候除了一个问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.040897 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved