c语言(7.21)

今天学习了反转数组,打乱数组中的数据

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

void printarr(int arr\[\], int len);

int main()

{

int arr5 = { 0 };
//录入5个数
//原版:scanf_s("%d %d %d %d %d", &arr0, &arr1, &arr2, &arr3, &arr4);
//修正:

int len = sizeof(arr) / sizeof(int);

for (int i = 0; i < len; i++)

{

printf("请输入第%d个数\n", i + 1);

scanf_s("%d", &arri);//给数组赋值

}

printf("第一次遍历数组\n");

printarr(arr, len);//遍历数组

for (int i = 0; i < len/2; i++)//翻转数组

{

int temp = arri;

arri = arrlen - 1 - i;//注意:这个过程不是双向的,arr0=arr4,此时arr4还是arr4

arrlen - 1 - i = temp;//一定要注意到底是谁等于谁,顺序不一样会导致结果天翻地覆,这里千 万不能写成temp=arrlen - 1 - i

//因为这样arrlen - 1 - i的值并没有变,变的是temp的值

}

printf("第二次遍历数组\n");

printarr(arr, len);//遍历数组

return 0;

}

//由于要多次遍历数组,所以定义一个函数

void printarr(int arr\[\], int len)

{

for (int i = 0; i < len; i++)

{

printf("%d\n", arri);

}

}

打乱数组中的数据

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
//定义一个数组,存入1,2,3,4,5,然后打乱数组中所有数据的顺序(本质上是随机交换两个变量)
int arr5 = { 1,2,3,4,5 };
int len = sizeof(arr) / sizeof(int);

srand(time(NULL));
for (int i = 0; i < len; i++)
{
int temp = arri; //交换前,先保存
int index = rand() % 5; //随机数的范围正好是数组索引的范围
arri = arrindex; //交换:你给我,我给你
arrindex = temp;
}
for (int i = 0; i < len; i++)//遍历数组
{
printf("%d\n", arri);

}
return 0;
}

相关推荐
刘马想放假11 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
05Kevin13 小时前
lk每日冒险题--数据结构6.27
算法
To_OC1 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安1 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者1 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠1 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
kisshyshy2 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范