C语言问题求助 10

随意输入一个实型数组,再对其实现:(1)添加――即输入要添加的元素值,输入添加的位置下标,把数据添加到相应元素;(2)修改――即输入要修改的元素下标,输入新的值,更改指定... 随意输入一个实型数组,再对其实现:(1)添加――即输入要添加的元素值,输入添加的位置下标,把数据添加到相应元素;(2)修改――即输入要修改的元素下标,输入新的值,更改指定元素值;(3)查找――即输入52查找数组中是否有此数,并输出查找结果; 展开
 我来答
帐号已注销
2019-11-27 · TA获得超过317个赞
知道小有建树答主
回答量:345
采纳率:90%
帮助的人:85.9万
展开全部

二进制11111111代表-127,是按原码规则来算。若按补码规则,二进制11111111算出来是-1。

文中说的是10000000代表-128。

详细描述如下:


[+1] = [00000001]原 = [00000001]反 = [00000001]补

[-1] = [10000001]原 = [11111110]反 = [11111111]补

计算机将第1位作为符号位,0表示正数,1表示负数。

原码:原码很好理解,第1位是符号位,其余位表示数值。

反码:

(1)正数:正数反码是其本身。

(2)负数:去掉原码符号位,其余位按位取反。

补码:

(1)正数:正数补码是其本身。

(2)负数:在反码基础上加1。

由上述定义可知:

[+0] = [00000000]原 = [00000000]反 = [00000000]补

[-0] = [10000000]原 = [11111111]反 = [00000000]补

既然+0和-0的补码一致,所以只需保留一个(+0和-0原码不同,注意看符号位)。

这样一来,“[-0] = [10000000]原”相当于没有使用,于是规定:“[10000000]”为-128。

既然是“规定”,就不能按原码、反码、补码的规则计算了。设计计算机时就在硬件中设置为:10000000代表-128。

之所以引入补码,是为了消除减法,用加负数来替代减法运算,这样让CPU设计更简单。

xuddrr
2017-10-31 · 超过16用户采纳过TA的回答
知道答主
回答量:56
采纳率:0%
帮助的人:27.1万
展开全部
感觉你的题目没有给全,需要给出实型数组的长度,不过要是课本上出得这么不严谨就算了,下面是一个实现:
// 参数:数组,长度,要插入的值,要插入的位置
// 返回:正确0,错误-1
int insert(int *arr, int len, int val, int idx) {
if (idx < 0 || idx >= len)

return -1;

arr[idx] = val;

return 0;

}
// 参数:数组,长度,要修改的值,要修改的位置
// 返回:正确返回0,错误返回-1
int modify(int *arr, int len, int val, int idx) {
if (idx < 0 || idx >= len)

return -1;

arr[idx] = val;

return 0;

}
// 参数:数组,长度,要查找的值;
// 返回:所在位置,找不到返回-1
int find(int *arr, int len, int val) {
int i;
for (i = 0; i < len; ++i)
if (arr[i] == 52)
return i;
return -1;
}
追问
1      掌握数组输入方法:初始化、循环赋值;
2 掌握以下算法:修改元素、添加元素、删除元素,理解元素移位概念与方法.
3.学会用一个变量len记录实际元素个数。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式