深入理解计算机系统 作业1 2.61 2.65 2.73 2.76解答

2.61


A !(~x)

B !x

C !(~ (x | 0x00ffffff))

D !(~ (x | 0xffffff00))




2.65

分析:因为本题受12次操作的限制,故不能按位计算是否该位为1。考虑到本题只需要判断1的个数的奇偶性,而并不需要计算一共有多少个1。那么我们考虑到如果能去掉偶数个1对结果并不会产生影响,这需要快速的去掉偶数个1。因为异或运算恰好可以把同为1时变成0。然后在利用分治的方法,整体异或来减少操作次数。

操作:1

1.16和后16位对齐后异或,那么这时候原来32位的奇偶性和目前异或出来的16位的结果一致。

2.同理前8位和后8位对齐异或。

3.同理前4位和后4位对齐异或。

4.同理前2位和后2位对齐异或。

5.同理前1位和后1位对齐异或。

最后只需要判断最后那一位上是1还是0即可。

 

int even_ones(unsigned x)
{
	unsigned  y = x >> 16; x ^= y;
	y = x >> 8; x ^= y;
	y = x >> 4; x ^= y;
	y = x >> 2; x ^= y; 
	y = x >> 1; x ^= y; 

	return !(x & 1);
	
}


 



2.73

【分析】首先判断是否有无溢出,因为不能用判断符号(<>),因此我们可以考虑符号位,如果(x+y)的符号位和xy的符号位都不同,则发生溢出。这个可以用两次异或和一次与操作完成。

ans= x+y

ALL= (( x ^ ans) & (y ^ ans)) >> ( intBitCnt - 1);显然当算术溢出时,ALL32个位上的值均为1111.....111),否则ALL= 0Ps:因为是算术右移。


然后继续判断是正溢出还是负溢出,只需要看x或者y的符号位即可判断。

x_sign= x >> (intBitCnt – 1); 如果正溢出则x_sign= 0 否则各个数位上的值均为1(111....111)

对于返回的结果,ans| ALL 之后,如果溢出则结果为全1,否则结果仍为x+y。如果正溢出我们只需要令其减去(1<<(intBitCnt – 1))即可,如果负溢出令其减去(1<<(intBitCnt-1)) ^ 111....111(全部1)即可,则否减去0

这样只要上面参与运算的1与是否溢出,是否正负溢出有关就可以了。


ALL& 1 = 1 是溢出的判断条件。

x_sign& ALL = 111.....111(1)是负溢出的条件,0则可能正溢出,也可能不溢出。


int saturating_add(int x,int y)
{
	int intBitCnt = sizeof(int) << 3;
	int ans = x + y;
	int ALL = (( x ^ ans) & (y ^ ans)) >> ( intBitCnt - 1);
	int x_sign = x >> ( intBitCnt  - 1);
	return (ans | ALL) - ( (ALL & 1) << ( intBitCnt - 1))^ (x_sign & ALL);
}




2.76

AK = 5 codex<<2+x

Bk = 9 codex<<3+x

Ck = 30codex<<5-x<<1

Dk = -56 codex<<3- x << 6

 

用MATLAB计算波动率,股票历史价格为3.64 3.61 3.58 3.6 3.59 3.57 3.58 3.6 3.57 3.52 3.49 3.48 3.45 3.43 3.46 3.47 3.49 3.54 3.53 3.5 3.52 3.55 3.42 3.42 3.43 3.44 3.39 3.38 3.41 3.42 3.37 3.44 3.4 3.42 3.41 3.42 3.42 3.39 3.26 3.16 3.18 3.21 3.16 3.24 3.25 3.26 3.26 3.23 3.27 3.32 3.3 3.26 3.25 3.26 3.18 3.22 3.18 3.11 3.14 3.18 3.2 3.13 3.16 3.15 3.14 3.21 3.2 3.21 3.25 3.28 3.25 3.24 3.29 3.28 3.23 3.19 3.17 3.2 3.16 3.16 3.19 3.25 3.25 3.25 3.23 3.3 3.31 3.3 3.33 3.31 3.33 3.27 3.29 3.29 3.31 3.35 3.35 3.33 3.29 3.29 3.3 3.29 3.25 3.22 3.24 3.24 3.23 3.22 3.21 3.28 3.26 3.26 3.26 3.24 3.21 3.25 3.25 3.26 3.27 3.25 3.22 3.18 3.16 3.18 3.19 3.21 3.22 3.25 3.3 3.35 3.35 3.35 3.34 3.3 3.32 3.27 3.24 3.26 3.24 3.28 3.27 3.27 3.29 3.22 3.25 3.26 3.25 3.24 3.19 3.21 3.22 3.2 3.22 3.17 3.12 3.13 3.17 3.17 3.21 3.21 3.19 3.13 3.14 3.11 3.04 3.1 3.1 3.12 3.13 3.12 3.09 3.1 3.12 3.12 3.14 3.13 3.08 3.1 3.04 3.06 3.06 3.11 3.09 3.08 3.05 2.95 2.91 2.89 2.91 2.92 2.83 2.69 2.81 2.86 2.89 2.87 2.88 2.9 2.88 2.84 2.84 2.82 2.9 2.88 2.92 2.91 2.88 2.91 2.83 2.88 2.87 2.91 2.91 2.87 2.84 2.82 2.78 2.8 2.66 2.66 2.71 2.75 2.79 2.78 2.7 2.68 2.7 2.72 2.7 2.73 2.7 2.74 2.73 2.73 2.79 2.76 2.72 2.72 2.72 2.74 2.76 2.79 2.78 2.78 2.81 2.83 2.86 2.85 2.89 2.84 2.87 2.91 2.89 2.93 2.92 2.93 2.9 2.94 2.98 3.02 3.04 3.02 3.07 3.06 3.06 3.06 3.01 3 3.01 2.96 2.94 2.93 2.91 2.87 2.91 2.9 2.91 2.87 2.89 2.88 2.89 2.87 2.87 2.83 2.82 2.77 2.75 2.78 2.82 2.8 2.8 2.77 2.83 2.84 2.82 2.81 2.82 2.8 2.79 2.79 2.77 2.75 2.79 2.79 2.77 2.77 2.8 2.78 2.75 2.74 2.76 2.75 2.75 2.8 2.81 2.79 2.78 2.72 2.72 2.71 2.69 2.67 2.67 2.65 2.68 2.65 2.65 2.65 2.59 2.58 2.59 2.56 2.63 2.62 2.61 2.56 2.54 2.53 2.44 2.43 2.44 2.42 2.37 2.33 2.44 2.46 2.42 2.51 2.52 2.5 2.48 2.48 2.56 2.58 2.63 2.62 2.6 2.59 2.56 2.57 2.58 2.56 2.59 2.54 2.65 2.64 2.63 2.62 2.68 2.69 2.67 2.68 2.71 2.68 2.68 2.7 2.68 2.69 2.65 2.61 2.61 2.63 2.62 2.61 2.64 2.65 2.63 2.65 2.65 2.66 2.71 2.72 2.75 2.74 2.75 2.75 2.8 2.85 2.84 2.82 2.83 2.85 2.85 2.82 2.83 2.82 2.78 2.74 2.75 2.74 2.77 2.76 2.78 2.79 2.76 2.75 2.72 2.8 2.81 2.78 2.77 2.74 2.73 2.75 2.78 2.78 2.78 2.75 2.72 2.7 2.68 2.64 2.67 2.65 2.65 2.63 2.64 2.62 2.65 2.66 2.67 2.66 2.64 2.64 2.64 2.67 2.67 2.67 2.68 2.67 2.69 2.69 2.68 2.67 2.67 2.68 2.74 2.75 2.72 2.71 2.66 2.62 2.62 2.62 2.66 2.68 2.69 2.69 2.72 2.71 2.67 2.67 2.63 2.68 2.67 2.65 2.64 2.63 2.66 2.62 2.58 2.57 2.56 2.55 2.54 2.5 2.51
最新发布
06-10
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值