c语言如何把数组元素前移,如何将一个数组的元素循环左移?

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

#include 

#include 

#define SIZE(a) (sizeof(a)/sizeof(a[0]))

#define HBIT(a) ((a & 0x00000080) != 0)

#define LBIT(a) ((a & 0x00000001) != 0)

int TAB[] = {

0x10, 0x71, 0x12, 0x10, 0x10, 0x7C, 0x00, 0x00,

0x00, 0x00, 0x00, 0x3C, 0x42, 0x42, 0x42, 0x04,

0x04, 0x08, 0x10, 0x20, 0x42, 0x7E, 0x00, 0x00,

0x00, 0x00, 0x00, 0x3C, 0x42, 0x42, 0x04, 0x18,

0x04, 0x02, 0x02, 0x42, 0x44, 0x38, 0x00, 0x00,

0x00, 0x00, 0x00, 0x04, 0x0C, 0x14, 0x24, 0x24,

0x44, 0x44, 0x7E, 0x04, 0x04, 0x1E, 0x00, 0x00,

0x00, 0x00, 0x00, 0x7E, 0x40, 0x40, 0x40, 0x58,

0x64, 0x02, 0x02, 0x42, 0x44, 0x38, 0x00, 0x00,

0x00, 0x00, 0x00, 0x1C, 0x24, 0x40, 0x40, 0x58,

0x64, 0x42, 0x42, 0x42, 0x24, 0x18, 0xC0, 0xDE

};

void Move()

{

int i, j, len;

len = SIZE(TAB);

for(i = 0; i 

{

j = i ? (i - 1) : (len - 1);

if(HBIT(TAB[i]) != LBIT(TAB[j]))

TAB[j] = (unsigned int)TAB[j] ^ 0X00000001;

TAB[i] = (unsigned int)TAB[i] <

TAB[i] = (unsigned int)TAB[i] & 0X000000FF;

TAB[j] = (unsigned int)TAB[j] & 0X000000FF;

}

printf("%#04X, %#04X\n", TAB[0], TAB[1]);

}

int main(void)

{

printf("%#04X, %#04X\n", TAB[0], TAB[1]);

while(TAB[0] != 0XC0 || TAB[1] != 0XDE)

Move();

system("PAUSE");

return EXIT_SUCCESS;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要删除数组的重复元素,可以使用C语言编写一个算法来实现。具体的步骤如下: 1. 定义一个函数,接收一个整型数组数组的大小作为参数。 2. 在函数内部,创建一个数组,并将原数组的第一个元素存入数组。 3. 使用两个嵌套的for循环来遍历原数组。外层循环用于迭代原数组的每个元素,内层循环用于比较当前元素数组元素是否相同。如果相同,则跳过此元素;否则,将该元素添加到数组。 4. 返回数组。 下面是一个示例代码实现: ```c #include <stdio.h> int* removeDuplicates(int arr[], int size) { int* newArr = (int*)malloc(size * sizeof(int)); int newSize = 1; // 数组的大小,默认为1,即保留原数组的第一个元素 newArr[0] = arr[0]; // 将原数组的第一个元素存入数组 for (int i = 1; i < size; i++) { int isDuplicate = 0; for (int j = 0; j < newSize; j++) { if (arr[i] == newArr[j]) { isDuplicate = 1; break; } } if (isDuplicate == 0) { newArr[newSize] = arr[i]; newSize++; } } return newArr; } int main() { int arr[] = {1, 2, 3, 4, 2, 3, 5, 6, 1}; int size = sizeof(arr) / sizeof(arr[0]); int* newArr = removeDuplicates(arr, size); printf("原数组:"); for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n删除重复元素后的数组:"); for (int i = 0; i < newSize; i++) { printf("%d ", newArr[i]); } free(newArr); // 释放内存 return 0; } ``` 这段代码将会输出: ``` 原数组:1 2 3 4 2 3 5 6 1 删除重复元素后的数组:1 2 3 4 5 6 ``` 通过该算法,我们可以删除数组的重复元素,并保留一个

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值