#include
int oushu(int i)
{
return i - (i >> 1 << 1) - 1;
}
int main()
{
int x[] = {0,1,2,3,4,5,6,7,8,9,100,101};
for(int i=0;i<12;i++)
if (oushu(x[i]))
printf("%d ", x[i]);
}
求讲解,这个函数的意思是什么呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
6条回答
- threenewbee 2016-03-05 10:39关注
return i - (i >> 1 << 1) - 1;
(i >> 1 << 1就是
i / 2 * 2,其中/是整除
如果是偶数,那么这个结果和i相等,否则是i-1
所以如果是偶数,返回-1,如果是奇数,返回0本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 对于相关问题的求解与代码
- ¥15 ubuntu子系统密码忘记
- ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料
- ¥15 使用R语言marginaleffects包进行边际效应图绘制