一年十二月  誰主春秋
關注:基礎系統工程 密碼學 人工智能
C++博客
首頁
新隨筆
聯系
聚合
管理
隨筆-161 評論-223 文章-30 trackbacks-0
判斷整數的正負零特性
原為某軟件公司試題,大意如下:對于給定的有符號32位整數,寫一個函數,當該數為正數時返回1,為負數時返回-1,為零時返回零,
要求不能使用任何的條件判斷分支跳轉語句
。在這里,稍微擴展了一下,給出了對應無符號32位整數的情形。解決思路是符號位和值分開處理,對于有符號32位整數,
符號位右移31位即
得a,
若為非負數
則a=0x00000000,
否則a=
0xFFFFFFFF;然后
將值部分各位的值(0或1
)
不斷縮小
合并到一位中去得到b
,這
是針對0和正數的情況處理,
再將a和b位
或
即可
。C++代碼
描述如下
1
//
若val為0則返回0, val為負數則返回-1, 為正數返回1
2
int32_t
check32(
int32_t
val)
3
{
4
int32_t
a
=
val
>>
31
;
5
int32_t
b
=
(val
&
0x0000FFFF
)
|
((val
>>
16
)
&
0x0000FFFF
);
6
b
=
(b
&
0x000000FF
)
|
((b
>>
8
)
&
0x000000FF
);
7
b
=
(b
&
0x0000000F
)
|
((b
>>
4
)
&
0x0000000F
);
8
b
=
(b
&
0x00000003
)
|
((b
>>
2
)
&
0x00000003
);
9
b
=
(b
&
0x00000001
)
|
((b
>>
1
)
&
0x00000001
);
10
return
a
|
b;
11
}
12
13
//
若val為0則返回0, 否則返回1
14
uint32_t
check32(
uint32_t
val)
15
{
16
uint32_t
a
=
(val
&
0x0000FFFF
)
|
((val
>>
16
)
&
0x0000FFFF
);
17
a
=
(a
&
0x000000FF
)
|
((a
>>
8
)
&
0x000000FF
);
18
a
=
(a
&
0x0000000F
)
|
((a
>>
4
)
&
0x0000000F
);
19
a
=
(a
&
0x00000003
)
|
((a
>>
2
)
&
0x00000003
);
20
a
=
(a
&
0x00000001
)
|
((a
>>
1
)
&
0x00000001
);
21
return
a;
22
}
若哪位有更好的解法,還望多多分享
posted on 2011-06-18 23:50
春秋十二月
閱讀(3402)
評論(0)
編輯
收藏
引用
所屬分類:
Algorithm
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
一個歐拉數整除問題的兩種證法
有限域上的特征與指數和之擴展
二元二次型的相似變換、正定性與正交分解
關于群的一些結論及應用
不定方程的代數數論解法
關于橢圓曲線的驗證計算
不可約多項式判別算法的改正
論證有限域上平方根的求解
求解離散對數問題的Terr算法
簡單私鑰加密構造的驗證及安全性分析
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
本博客所有隨筆均為原創,因為不定期維護更新,所以轉載請注明出處,如有問題和建議,請留言或評論,發表您的寶貴意見,藉此平臺以分享交流、共同進步。
聯系方式:微信math-engineer
<
2023年9月
>
日
一
二
三
四
五
六
27
28
29
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
6
7
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(76)
給我留言
查看公開留言
查看私人留言
隨筆分類
(160)
Algorithm(48)
C/C++(24)
Compiler(25)
Compute Theory(5)
Database(4)
Network(17)
Opensrc(13)
System(24)
隨筆檔案
(161)
2025年6月 (2)
2025年4月 (2)
2024年12月 (1)
2024年11月 (1)
2024年9月 (1)
2024年8月 (2)
2024年6月 (1)
2024年5月 (1)
2024年4月 (1)
2024年3月 (2)
2024年2月 (2)
2023年12月 (1)
2023年11月 (2)
2023年10月 (2)
2023年9月 (37)
2021年12月 (1)
2021年10月 (1)
2021年9月 (1)
2021年2月 (1)
2020年5月 (3)
2020年4月 (1)
2019年11月 (4)
2019年7月 (1)
2018年11月 (1)
2017年12月 (1)
2016年12月 (1)
2016年11月 (2)
2016年10月 (1)
2016年9月 (1)
2016年8月 (3)
2016年7月 (4)
2016年5月 (1)
2015年10月 (2)
2015年9月 (1)
2015年6月 (2)
2015年5月 (3)
2015年2月 (1)
2015年1月 (1)
2014年12月 (2)
2014年4月 (2)
2014年3月 (1)
2014年1月 (1)
2013年10月 (1)
2013年9月 (1)
2013年8月 (3)
2013年5月 (1)
2013年3月 (1)
2012年11月 (1)
2012年9月 (3)
2012年8月 (1)
2012年7月 (1)
2012年6月 (5)
2012年5月 (3)
2011年12月 (5)
2011年11月 (1)
2011年10月 (5)
2011年8月 (7)
2011年7月 (6)
2011年6月 (6)
2010年6月 (1)
2009年12月 (1)
2009年8月 (1)
2009年7月 (1)
2009年6月 (1)
2009年4月 (3)
文章分類
(30)
詩詞作品集(30)
關注的開源項目
LLVM
編譯系統
nginx
高性能Web服務器
OpenSSL
密碼學庫
suricata
網絡IPS引擎
最新隨筆
1.?一個歐拉數整除問題的兩種證法
2.?有限域上的特征與指數和之擴展
3.?二元二次型的相似變換、正定性與正交分解
4.?關于群的一些結論及應用
5.?不定方程的代數數論解法
6.?關于橢圓曲線的驗證計算
7.?不可約多項式判別算法的改正
8.?論證有限域上平方根的求解
9.?求解離散對數問題的Terr算法
10.?簡單私鑰加密構造的驗證及安全性分析
積分與排名
積分 - 416918
排名 - 56
最新評論
1.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
很有前途和很有錢途啊。
--chipset
2.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
@chipset
是的
--春秋十二月
3.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
工作是做網絡安全?
--chipset
4.?re: 一種使用函數指針實現狀態機的方法
函數指針實現狀態機
--linda
5.?re: 多標簽視圖類CTabView的設計實現
為啥代碼缺少一些呢,給新手個完整點的啊
--pekingliu
6.?re: 工作線程與消息循環
從消息隊列取出消息 mark了
--mmocake
7.?re: 一種簡單的跨平臺套接字管道
評論內容較長,點擊標題查看
--IT搬運工
8.?re: 一種簡單的跨平臺套接字管道
windows僅支持af_init和af_init6地址族有錯別字么?
af_init和af_init6
--IT搬運工
9.?re: Shell應用(8):使用awk定位反匯編輸出[未登錄]
厲害
--Chipset
10.?re: TCP分組丟失時的狀態變遷
不錯
--Binky
閱讀排行榜
1.?基于OpenSSL實現的安全連接(14001)
2.?字符串16進制顯示(12881)
3.?基于boost asio實現的ssl socket框架(12342)
4.?Linux套接字與虛擬文件系統(1):初始化和創建(8668)
5.?關于數據庫的一些學習研究心得(8109)
6.?使用CString GetBuffer自適應獲取計算機名稱(7985)
7.?使用正則表達式解析URL(7949)
8.?basic_string內存泄露問題之分析解決(7753)
9.?Shell應用(4): 使用sed刪除行尾的^M字符(7671)
10.?nginx iocp(1):tcp異步連接(7657)
評論排行榜
1.?basic_string內存泄露問題之分析解決(19)
2.?求單向鏈表倒序第m個元素(11)
3.?基于順序存儲實現的多叉樹(1):深度優先存儲(9)
4.?字符大小寫轉換(7)
5.?字符串16進制顯示(6)
6.?面向對象鎖框架的設計與實現(6)
7.?Shell應用(4): 使用sed刪除行尾的^M字符(5)
8.?使用正則表達式解析URL(5)
9.?工作線程與消息循環(5)
10.?十進制整數千位分隔符(4)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 春秋十二月
91久久成人免费
|
亚洲精品美女久久久久99小说
|
99精品久久精品一区二区
|
亚洲女久久久噜噜噜熟女
|
99re这里只有精品热久久
|
99国内精品久久久久久久
|
久久精品中文无码资源站
|
久久免费视频观看
|
久久婷婷国产剧情内射白浆
|
久久免费视频观看
|
亚洲精品乱码久久久久久中文字幕
|
香港aa三级久久三级
|
精品久久亚洲中文无码
|
久久se精品一区二区影院
|
久久久久99精品成人片直播
|
久久午夜综合久久
|
91精品国产91久久久久久青草
|
久久天天躁狠狠躁夜夜不卡
|
狠狠久久综合
|
亚洲国产精品久久久久婷婷老年
|
午夜精品久久久久久毛片
|
久久久久免费视频
|
国内精品久久久久久久coent
|
久久婷婷五月综合97色一本一本
|
一本久久精品一区二区
|
青青热久久国产久精品
|
国产日韩久久久精品影院首页
|
青青草原综合久久
|
丰满少妇人妻久久久久久
|
久久久久亚洲av综合波多野结衣
|
国产精品久久久99
|
丁香久久婷婷国产午夜视频
|
2021精品国产综合久久
|
成人久久久观看免费毛片
|
精品一久久香蕉国产线看播放
|
国产成人无码久久久精品一
|
国产精品久久久久国产A级
|
久久久久AV综合网成人
|
精品蜜臀久久久久99网站
|
久久er99热精品一区二区
|
久久精品九九亚洲精品
|