国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

位運算例題2

2019-11-14 09:14:43
字體:
來源:轉載
供稿:網友

1. 題目:輸入一個整數a,再輸入兩個整數p1,p2(p1,p2<32),輸出該整數的二進制表示

方法中從右端開始的p1到p2位.

#include<stdio.h>int exchange(int num)     //將整數以二進制形式輸出{	int i;	i = num % 2;	if(num != 0 )	{		num /= 2;		exchange(num);     //采用遞歸方法	}	PRintf("%d",i);}int main(){	int num,p1,p2,temp;	int mask = ~0;        //掩碼補充位	int len = 0;	printf("Please enter an integer:/n");	scanf("%d",&num);   	printf("Please enter two integer:/n");	scanf("%d%d",&p1,&p2);	temp = num;	while(temp)               //判斷輸入的數有幾位	{		temp /= 10;		len++;	}	len = 8 * len;           //總的位數	mask <<= (len - p2);      //將掩碼p2左邊置0	mask >>= (len - p2);	mask >>= (p1 - 1);       //將掩碼p1右邊置0,得到p1~p2段為1	mask <<= (p1 - 1);	num &= mask;            	num >>= (p1 - 1);          //將區間移至最低位	exchange(num);}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通化县| 栖霞市| 潮州市| 宜州市| 米脂县| 西林县| 察雅县| 开化县| 肇源县| 瑞金市| 竹山县| 广昌县| 海宁市| 娱乐| 察雅县| 汝州市| 贵南县| 和林格尔县| 静乐县| 栾川县| 禹城市| 巴青县| 玛沁县| 鄂托克旗| 广丰县| 建宁县| 内丘县| 尚义县| 汶川县| 高青县| 阿克苏市| 汕头市| 万盛区| 田林县| 宜宾市| 搜索| 嘉荫县| 临潭县| 特克斯县| 清原| 陕西省|