免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 29011 | 回复: 35
打印 上一主题 下一主题

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

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-05 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)
{
    if(N == 0) 执行func0;
    if(N == 1) 执行func1;
    if(N == 2) 执行func2;
    if(N == 3) 执行func3;
    if(N == 4) 执行func4;
    if(N == 5) 执行func5;
}



不使用 if 或是 switch 判断语句。

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

int MAIN(int N)
{
    if(N == 33) 执行func0;
    if(N == 67) 执行func1;
    if(N == 150) 执行func2;
    if(N == 274) 执行func3;
    if(N == 331) 执行func4;
    if(N == 556) 执行func5;
}

问用什么方法能使得,执行的速度最快。

第一个题,我用的是 条件语句。
出来后想到了用函数指针数组更好。人家考的本意应该也是用函数指针数组吧!!

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

/* An array of 6 pointers to functions that take an void argument and return void */
void (*fun[6])(void)

int MAIN(int N)
{
    fun[0] = func0;
    fun[1] = func1;
    fun[2] = func2;
    fun[3] = func3;
    fun[4] = func4;
    fun[5] = func5;

    fun[N];
}


第二个问题, 想了想没有什么思路,大家有什么高见啊?
其中N== 33 N==67 后面的值是我自己瞎编的!!!忘了。
但我想和这个值应该没什么关系。 我搞不懂他要考的是什么?
有什么东西可以不用判断,就可以选择执行的,而且效率还高?

[ 本帖最后由 _mystic 于 2009-8-5 14:15 编辑 ]

论坛徽章:
0
36 [报告]
发表于 2009-08-10 18:09 |只看该作者
不检查参数啊`就和前面一个人说的一样...
如果数据是99怎么办呢?

论坛徽章:
0
35 [报告]
发表于 2009-08-10 09:56 |只看该作者
用switch就行了,效率能低到哪里去?

论坛徽章:
0
34 [报告]
发表于 2009-08-10 08:30 |只看该作者
这种题目出得可真够无聊的,想必出题的人纯属NC
突然想起,要是偶也遇到这种题目了的话,那就笑了

论坛徽章:
0
33 [报告]
发表于 2009-08-09 09:35 |只看该作者
第一个用数组,第二个用二分法,,

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
32 [报告]
发表于 2009-08-08 23:24 |只看该作者
那个,GNU不是有个prefect hash的程序么?叫啥名字来着?

论坛徽章:
0
31 [报告]
发表于 2009-08-08 23:13 |只看该作者
不用if/else,不检查参数吗?

论坛徽章:
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 |只看该作者

没有

但你可以自已做一个~~

论坛徽章:
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. }
复制代码

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

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP