免费注册 查看新帖 |

Chinaunix

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

[C] NO1贴:在两个数中找较大的那一个 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-28 12:42 |只看该作者 |倒序浏览
随机通过stdin输入两个整数,请在stdout输出这两个数中的较大的那一个。
不得使用 if,  : ? , >, >=, <, <=等等比较远算符和关键字。
求解。
最简单测试用例:
1)输入 0, 1 输出1
2)输入 1, 0 输出1
3)输入 0, -1 输出0
4)输入 -1, 0 输出0
5)输入 1, 1 输出1

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [报告]
发表于 2011-10-28 13:18 |只看该作者
为什么“不得使用 if,  : ? , >, >=, <, <=等等比较远算符和关键字”呢?

把这种无聊的东西当知识点,一般出现在:
    村边一间小饭店,墙外印着一个大大的“拆”
    店里一个满脸油光的老男人,一只脚踩在椅子上,喝着一瓶劣质假酒,吐沫横飞的和周围无赖打屁拉呱
    说到兴奋处,“考考你们,……不得使用 if,  : ? , >, >=, <, <=等等比较远算符和关键字”
    看着一群装着在思考的歪瓜裂枣们,把抠脚丫的臭手放在鼻子下用力一嗅,露出满足的轻蔑笑容,心里想“我的这些知识,教书先生也是不会的”

论坛徽章:
0
3 [报告]
发表于 2011-10-28 13:44 |只看该作者
没办法,一些“牛人”就喜欢在面试的时候考这个

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
4 [报告]
发表于 2011-10-28 14:03 |只看该作者
我知道这"牛人"心里想的什么

  1. #include <limits.h>
  2. #include <stdio.h>

  3. int max(int a, int b)
  4. {
  5.       return (&a)[((a-b) & (INT_MAX^UINT_MAX)) >> (sizeof(int)*CHAR_BIT-1)];
  6. }

  7. int main(void)
  8. {
  9.       int a=0, b=0;
  10.       while (scanf("%d%d", &a, &b)==2)
  11.             printf("%d\n", max(a,b) );
  12.       return 0;
  13. }
复制代码
无力吐槽

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
5 [报告]
发表于 2011-10-28 15:04 |只看该作者
改一下,不依赖参数传递方式,但依然依赖signed的表示法

  1. #include <limits.h>
  2. #include <stdio.h>

  3. int max(int a, int b)
  4. {
  5.       int v[2];
  6.       v[0] = a;
  7.       v[1] = b;
  8.       return v[(unsigned)(a-b) >> (sizeof(int)*CHAR_BIT-1)];
  9. }

  10. int main(void)
  11. {
  12.       int a=0, b=0;
  13.       while (scanf("%d%d", &a, &b)==2)
  14.             printf("%d\n", max(a,b) );
  15.       return 0;
  16. }
复制代码

论坛徽章:
0
6 [报告]
发表于 2011-10-28 15:23 |只看该作者
我知道这"牛人"心里想的什么无力吐槽
OwnWaterloo 发表于 2011-10-28 14:03


看起来函数内部“故意压栈”的
   
   575: int max(int a, int b)
   576: {
0x00000CEA B503      PUSH     {r0-r1,lr}        ; 传参数直接用r0,r1,但是传进来之后压栈了
   577:       return (&a)[((a-b) & (INT_MAX^UINT_MAX)) >> (sizeof(int)*CHAR_BIT-1)];
0x00000CEC 9800      LDR      r0,[sp,#0x00]        ; 取a
0x00000CEE 1A40      SUBS     r0,r0,r1                ; r0=a-b
0x00000CF0 0FC0      LSRS     r0,r0,#31                ; >>操作
0x00000CF2 0080      LSLS     r0,r0,#2                ; &操作
0x00000CF4 4669      MOV      r1,sp                ; r1=&a
0x00000CF6 5808      LDR      r0,[r1,r0]        ; r0=(&a)[...]的值
0x00000CF8 BD0C      POP      {r2-r3,pc}        ; 返回,它好像不关心r1-r3被修改掉
   578: }

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
7 [报告]
发表于 2011-10-28 16:28 |只看该作者
闲得没事做

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
8 [报告]
发表于 2011-10-28 16:52 |只看该作者
回复 6# AD8018

我傻了……  直接复制到数组里面就有确定的布局了……
thx


没人吐槽我就自己吐槽自己……
c99貌似规定(6.2.6.2 2)了signed的表示法必须是:
sign and magnitude
two’s complement
one’s complement
之一, 这样似乎就肯定有sign bit可利用了……

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
9 [报告]
发表于 2011-10-28 20:48 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
2
青铜圣斗士
日期:2015-11-26 06:15:59数据库技术版块每日发帖之星
日期:2016-07-24 06:20:00
10 [报告]
发表于 2011-10-28 22:02 |只看该作者
回复 9# pmerofc

很好,这个理由够充分了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP