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换成题目当中的绝对地址就行!