c语言(7.21)

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

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

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

int main()

{

int arr[5] = { 0 };
//录入5个数
//原版:scanf_s("%d %d %d %d %d", &arr[0], &arr[1], &arr[2], &arr[3], &arr[4]);
//修正:

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

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

{

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

scanf_s("%d", &arr[i]);//给数组赋值

}

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

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

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

{

int temp = arr[i];

arr[i] = arr[len - 1 - i];//注意:这个过程不是双向的,arr[0]=arr[4],此时arr[4]还是arr[4]

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

//因为这样arr[len - 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", arr[i]);

}

}

打乱数组中的数据

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

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

}
return 0;
}

相关推荐
liu****21 小时前
一.脚手架介绍以及部分工具使用
开发语言·数据结构·c++·手脚架开发
Hello娃的21 小时前
【量子力学】Hohenberg-Kohn 定理
人工智能·算法
老马啸西风1 天前
成熟企业级技术平台 MVE-010-IGA(Identity Governance & Administration,身份治理与管理)平台
人工智能·深度学习·算法·职场和发展
老马啸西风1 天前
成熟企业级技术平台 MVE-010-app 管理平台
人工智能·深度学习·算法·职场和发展
lzh_200110121 天前
树状数组理解
算法
R-G-B1 天前
哈希表(hashtable),哈希理论,数组实现哈希结构 (C语言),散列理论 (拉链发、链接发),散列实现哈希结构,c++ 实现哈希
c语言·哈希算法·散列表·哈希表·数组实现哈希结构·散列实现哈希结构·c++ 实现哈希
历程里程碑1 天前
C++ 6 :string类:高效处理字符串的秘密
c语言·开发语言·数据结构·c++·笔记·算法·排序算法
蓝色汪洋1 天前
luogu迷宫寻路
算法
xu_yule1 天前
算法基础-(数据结构)
数据结构
玩转数据库管理工具FOR DBLENS1 天前
DBLens:开启数据库管理新纪元——永久免费,智能高效的国产化开发利器
数据结构·数据库·测试工具·数据库开发