免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: _mystic
打印 上一主题 下一主题

[C] 看看这两个面试题 [复制链接]

论坛徽章:
0
21 [报告]
发表于 2009-08-05 22:44 |只看该作者
函数指针数组

论坛徽章:
0
22 [报告]
发表于 2009-08-06 00:35 |只看该作者
原帖由 mjus 于 2009-8-5 22:30 发表
void (*fun[8])(void);
index=hash=N%10;
set fun[2]=fun[5]=NULL

done !


我看的有点晕。。。解释一下,可以吗?

论坛徽章:
0
23 [报告]
发表于 2009-08-06 02:56 |只看该作者
OK. see
N=33,   index=hash=33%10=3
N=67,   index=hash=67%10=7
N=150  index=hash=150%10=0
N=274  index=hash=274%10=4
N=331  index=hash=331%10=1
N=556  index=hash=556%10=6


fun[0]=[150%10]=func2;
fun[1]=[331%10]=func4;
fun[2]=NULL;
fun[3]=[33%10]=func0;
fun[4]=[274%10]=func3;
fun[5]=NULL;
fun[6]=[556%10]=func5;
fun[7]=[67%10]=func1;

Basically, it is just a hash mapping !

Strictly speaking, given a set of data, using perfect hashing is better. Of course,
this can't be done in a limited time in a test.

论坛徽章:
1
白羊座
日期:2014-01-03 23:26:39
24 [报告]
发表于 2009-08-06 17:44 |只看该作者
原帖由 mjus 于 2009-8-6 02:56 发表
OK. see
N=33,   index=hash=33%10=3
N=67,   index=hash=67%10=7
N=150  index=hash=150%10=0
N=274  index=hash=274%10=4
N=331  index=hash=331%10=1
N=556  index=hash=556%10=6


fun[0]=[150%10 ...


Are you a 外国人?

论坛徽章:
0
25 [报告]
发表于 2009-08-07 16:50 |只看该作者
原帖由 mjus 于 2009-8-6 02:56 发表
OK. see
N=33,   index=hash=33%10=3
N=67,   index=hash=67%10=7
N=150  index=hash=150%10=0
N=274  index=hash=274%10=4
N=331  index=hash=331%10=1
N=556  index=hash=556%10=6


fun[0]=[150%10 ...


嗯 好像明白了~~
要是对10取余后,有两个一样的怎么办?
33%10 = 3
要是还有有93哪? 93 % 10 = 3

论坛徽章:
0
26 [报告]
发表于 2009-08-07 17:08 |只看该作者
第二题大家想多了吧?

你再建立一个数组 a[] = { 63, 41, 145,..};
fun[0] = func0;
fun[1] = func1;
.........
以上内容在函数外面初始化  否则谈不上效率。。。每次都执行。。。如果只执行一次 应该可以不算时间的。。。

for (i = 0; a[i] != N; i++);
fun[i];


不过 我不觉得函数指针会比直接用if else快  (除非你是把我说的那些初始化代码放到外面。。否则还不如直接if else)
因为函数指针要2次 * 才能找到函数入口地址。。。。


[ 本帖最后由 snyh 于 2009-8-7 17:10 编辑 ]

论坛徽章:
0
27 [报告]
发表于 2009-08-07 17:15 |只看该作者
不过这个还是O(n) ...
hash 是O(1)
只是 几个数还好 。多了找一个合适的哈西函数 似乎比较难。。。。少了的话。。。我觉得这个n就跟1差不多了

论坛徽章:
0
28 [报告]
发表于 2009-08-08 20:03 |只看该作者
为什么执行不是(*fun[N])()这样的指针放那边就会执行吗?

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
29 [报告]
发表于 2009-08-08 21:14 |只看该作者
原帖由 _mystic 于 2009-8-5 14:06 发表
昨天去了的笔试题,这是最后两个题。


1.
void func0(void);
void func1(void);
void func2(void);
void func3(void);
void func4(void);
void func5(void);

int MAIN(int N)
{
  &nb ...


1.

  1. int MAIN(int N){
  2. typedef void(*DispatchFun)(void);
  3. static DispatchFun funarray[]={
  4.   fun0,fun1,fun2,fun3,fun4,fun5
  5. };
  6. if(N>=0&&N<sizeof(funarray)/sizeof(funarray[0])) funarray[N]();
  7. else return -1;
  8. returun 0;
  9. }
复制代码


2.

  1. void nop(void){}
  2. int MAIN(int N){
  3. typedef void(*DispatchFun)(void);
  4. static DispatchFun funarray[]={
  5.   func2, //150%10
  6.   func4, //331%10
  7.   nop,   //none
  8.   func0, //33%10
  9.   func3, //274%10
  10.   nop,   //none
  11.   func5 //556%10
  12.   func1 //67%10
  13. };
  14. if(N>=0&&N<sizeof(funarray)/sizeof(funarray[0])) funarray[N]();
  15. else return -1;
  16. returun 0;
  17. }
复制代码

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
30 [报告]
发表于 2009-08-08 21:19 |只看该作者

没有

但你可以自已做一个~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP