标题:宏定义求数组的最大维数
只看楼主
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
结帖率:94.12%
已结贴  问题点数:20 回复次数:11 
宏定义求数组的最大维数
定义一个宏 DIM(a)
int a[10];
int b[4][5];
double c[7][9][4];
调用宏后结果
DIM(a) = 10;
DIM(b) = 5;
DIM(c) = 9;
也就是算出多维数组里面维度最大的那个值  并且数组类型不确定
搜索更多相关主题的帖子: double 最大的 
2011-06-23 10:56
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
得分:4 
很难写出来,而且要用到循环,用宏怎么取值?

My life is brilliant
2011-06-23 11:44
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
得分:0 
回复 2楼 lz1091914999
总有办法的,一起想一想呵
2011-06-23 11:50
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
得分:0 
sizeof(**c)  / sizeof(***c) //数组维数
求数组维数除了用sizeof外还有什么方法
2011-06-23 11:53
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
得分:0 
悲催,以前的高手挺多的呀
网上看到的,使用c++模板好像
程序代码:
#include<iostream>

using namespace std;

#define DIM(array) func(array)

template<class T, int size>
int func(const T(&a)[size])
{
    return size > func(a[0]) ? size : func(a[0]);
}

int func(...)
{
    return 0;
}

int main()
{
    int a[10];
    char b[4][5];
    double c[7][9][4];
    cout <<DIM(a) <<endl;
    cout <<DIM(b) <<endl;
    cout <<DIM(c) <<endl; 

    return 0;
}

2011-06-23 22:14
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
得分:0 
...............
2011-06-24 09:05
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
得分:0 
回复 5楼 kelas
这是C吗?

My life is brilliant
2011-06-24 12:06
kelas
Rank: 6Rank: 6
等 级:侠之大者
帖 子:176
专家分:434
注 册:2010-5-28
得分:0 
回复 7楼 lz1091914999
明显是c++
2011-06-24 17:54
cosdos
Rank: 9Rank: 9Rank: 9
来 自:ShangHai
等 级:蜘蛛侠
威 望:6
帖 子:2109
专家分:1385
注 册:2007-6-19
得分:4 
显示值不用计算,用眼看就行了。

—>〉Sun〈<—
2011-06-24 19:33
kemoo
Rank: 2
来 自:四川内江
等 级:论坛游民
帖 子:24
专家分:42
注 册:2011-4-20
得分:4 
看看

No Comment!
2011-06-24 19:44



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-343757-1-1.html




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

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