c语言第四次练习题

1、有一百个整数,其中有负数,找出连续三个数之和最大的部分.
示例:
输入:2 ,-8 ,3,-2 ,4,-10
输出: 5 ({3, -2, 4})
思路提示 :每次保存数组初始的连续三个元素和,注意循环终止条件(防止数组越界)。

#include<stdio.h>
int func(int *arr, int lenth)
{
    int i=0,j=0,temp=0;
    int sum[98];
    int *p = (int *)arr;
    for(i=0;i<lenth-2;i++)
    {   //计算三项的和并且保存到sum数组里面。 
        sum[i]=(p[i])+(p[i+1])+(p[i+2]);    
    }
    //对sum数组进行一次冒泡排序就可以返回数组的最大值 
    for(i=0; i<98; i++)
    {
        if(sum[i]>sum[i+1])
        {
            temp = sum[i];
            sum[i] = sum[i+1];
            sum[i+1] = temp;
        }
    } 
    //排序之后返回最后一个数,也就是最大值。 
    return sum[97];
}


int main(void)
{
    int arr[100]={2,3,-2,8};
    int ret = 0;
    ret = func(arr,100);
    printf("该数组的连续三个元素的最大值是:%d",ret);       
    return 0;
}

2、用<<,>>,|,&实现一个unsigned short型变量(2个字节)的高低位交换!!
例如:0x1234 交换后 0x3412
函数原型:void func(unsigned short *a)
思路提示 :注意指针运算,指针的加减到底是怎么偏移的。

#include<stdio.h>
void func(unsigned short*a)
{
    unsigned short store;
    unsigned short b = 0xff00;
    //保存它的高字节 
    store = b&*a;
    //高字节移动到低字节 
    store = store>>8;
    //低字节向左移动
    (*a) = (*a)<<8; 
    //高低字节相加 
    (*a) = (*a)+store;


}

int main(void)
{
    unsigned short a = 0x1234;
    unsigned short *p = &a; 
    func(p);
    printf("交换后的值:%x",a);
    return 0;   
} 

方法2:
下面这个程序也可以实现高低位的交换(是我自己写的,但是我自己已经看不懂了)

#include<stdio.h>
void func(unsigned short*a)
{
    unsigned char* p = (char*)a;
    unsigned short store; 
    store = *p;//取出高字节按理来说应该是12
    store = store << 8;
    printf("%x",*p);不知道为啥这里打印的*p居然是34
    (*a)=(*a)>>8;
    (*a)=(*a)+store;     
}

int main(void)
{
    unsigned short a = 0x1234;
    unsigned short *p = &a; 
    func(p);
    printf("交换后的值:%x",a);
    return 0;   
} 

3、嵌入式系统经常具有要求程序员去访问某特定的内存位置的特点。在某工程中,要求设置一绝对地址为0x67a9的整型变量的值为0xaa55。编译器是一个纯粹的ANSI编译器。写代码去完成这一任务。
思路提示 :C语言的实质,指针和内存的关系。

#include<stdio.h>


int main(void)
{   int  a = 0x0000;
    int *p = (int *)&a;
    *p = 0xaa55;
    printf("%x\n",a);
    return 0;
}

这里写图片描述

把&a换成题目当中的绝对地址就行!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值