曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 3861|回复: 0
打印 上一主题 下一主题

[字符串] ffs() -- 在一个整数中查找第一个为真的位

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34395
跳转到指定楼层
楼主
发表于 2011-12-21 13:10:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
ffs() 函数的原型如下:
[C++] 纯文本查看 复制代码
 #include <strings.h>
int ffs(int i);

该函数由低到高的扫描参数 i 的每一位,将最先出现的值为 1 的那个位的位置返回。返回值在 1 到 32 之间,如果返回值为 0 ,那么表示没有 1 的位,也就是该参数 i 的值为 0 。

测试代码
[C++] 纯文本查看 复制代码
#include <stdio.h>
#include <string.h>

int main()
{
        int i[] = {1, 2, 4, 8, 16, 32, 64, 0};

        int j;

        for (j = 0; j < 8; j++)
                printf ("%d : %d \n", i[j], ffs(i[j]));

        return 0;
}

运行输出:
./ffs
1 : 1
2 : 2
4 : 3
8 : 4
16 : 5
32 : 6
64 : 7
0 : 0
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-5-4 01:04 , Processed in 0.098661 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表