数组基础知识二

特别说明

一维数组的定义(对数组空间进行清理,置0,不会产生随机值):数组在使用前要先定义;告诉编译器数组元素的类型;编译器会给这个数组预先分配连续的存储空间;定义的格式为:元素类型名 数组名[数组长度]。

1、一维数组的遍历:在操作数组时,经常需要依次访问数组中的每个元素,这种操作称作数组的遍历。接下来使用for循环依次遍历数组中的元素。

代码示例

复制代码
#include <stdio.h>

int main()
{
	int x[5] = {1,2,3,4,5};
	int i = 0;
	for(i=0;i<5;i++)
	{
		printf("x[%d]:%d\n",i,x[i]);
	}
	return 0;
}

例题1:输入n(n<=10)及n个整数,将这组整数逆置并输出。

复制代码
#include <stdio.h>

int main()
{
	int a[10];
	int n;
	int i = 0;
	scanf("%d",&n);
	for(i=0;i<n;i++)
		scanf("%d",&a[i]);
	for(i=0;i<n/2;i++)
	{
		int t;
		t=a[i];
		a[i]=a[n-1-i];
		a[n-1-i]=t;
	}
	for(i=0;i<n;i++)
		printf("%d",a[i]);
	return 0;
}

注意:输入的时候以回车作为结束

2、一维数组的最值:在操作时,经常需要获取数组中元素的最值。

例题2:输入n(n<=10)及n个整数,输出最大整数及其位序。

复制代码
#include <stdio.h>

int main()
{
	int n,maxn,maxk;
	int a[10];
	int i;
	
	scanf("%d",&n);
	maxn = 0;
	maxk = 0;
	for(i=0;i<n;i++)
	{
		scanf("%d",&a[i]);
		
		if(a[i]>maxn)
		{
			maxn = a[i];
			maxk = k;
		}
	}
	printf("最大整数为:%d 位序为:%d\n",maxn,maxk);
	return 0;
}

**3、一维数组的排序------选择排序:**选择排序是通过每一趟排序过程中从待排序的记录中选择最大(小)的元素,将其依次放在数组的最前(后)端,来实现数组的排序。

复制代码
#include <stdio.h>

int main()
{
	int x[5] = {9,8,3,5,2};
	int i,j,min,temp;
	
	for(i=0;i<5-1;i++) //循环轮数是确定的 
	{
		min = i; //循环的开始 
		for(j=i+1;j<5;j++) //循环找出最小值 
		{
			if(x[j]<x[min])
			  min = j; 
		}
		if(min!=i)
		{
			temp = x[i];
			x[i] = x[min];
			x[min] = temp;
		}
	}
	for(i=0;i<5;i++)
	{
		printf("%d",x[i]);
	}
	return 0;
}

4、一维数组的排序------冒泡排序:在冒泡排序过程中,不断地比较数组中相邻地两个元素,较小者向上浮,较大者往下沉,整个过程和水中气泡上升地原理相似。

复制代码
#include <stdio.h>

int main()
{
	int x[5] = {9,8,3,5,2};
	int i=0,j=0,temp=0;
	
	for(i=0;i<5-1;i++)
	{
		for(j=0;j<5-1-i;j++)
		{
			if(x[j]>x[j+1])
			{
				temp = x[j];
				x[j] = x[j+1];
				x[j+1] = temp;
			}
		}
	} 
	for(i=0;i<5;i++)
	{
		printf("%d ",x[i]);
	}
	return 0;
}

5、一维数组地排序------插入排序:插入排序就是每一步将一个待排序元素插入到已经排序地元素中的适当位置,直到全部插入完毕。

复制代码
#include <stdio.h>

int main()
{
	int x[5] = {9,8,3,5,2};
	int i=1,j=0,temp=0;
	
	for(i=1;i<5;i++)
	{
		temp = x[i];
		j = i;
		while(j>0&&x[j-1]>temp)
		{
			x[j] = x[j-1];
			j--;
		}
		x[j] = temp;
	}
	for(j=0;j<5;j++)
	{
		printf("%d ",x[j]);
	}
	return 0;
}
相关推荐
CoovallyAIHub5 分钟前
一夜之间,大模型处理长文本的难题被DeepSeek新模型彻底颠覆!
深度学习·算法·计算机视觉
再睡一夏就好10 分钟前
【C++闯关笔记】STL:deque与priority_queue的学习和使用
java·数据结构·c++·笔记·学习·
天选之女wow10 分钟前
【代码随想录算法训练营——Day43(Day42周日休息)】动态规划——300.最长递增子序列、674.最长连续递增序列、718.最长重复子数组
算法·leetcode·动态规划
敲代码的嘎仔39 分钟前
JavaWeb零基础学习Day4——Maven
java·开发语言·学习·算法·maven·javaweb·学习方法
遇印记41 分钟前
网络运维学习笔记
数据结构·笔记·学习
聪明的笨猪猪1 小时前
hot 100 (1)—— 两数之和(哈希)
java·经验分享·算法·哈希算法
_dindong1 小时前
牛客101:链表
数据结构·c++·笔记·学习·算法·链表
wuk9982 小时前
基于位置式PID算法调节PWM占空比实现电机转速控制
单片机·嵌入式硬件·算法
派大星爱吃猫2 小时前
堆的概念、结构与应用详解
c语言·数据结构·
不到满级不改名2 小时前
EM算法 & 隐马尔可夫模型
算法