数组基础知识二

特别说明

一维数组的定义(对数组空间进行清理,置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;
}
相关推荐
ゞ 正在缓冲99%…40 分钟前
leetcode101.对称二叉树
算法
YuTaoShao1 小时前
【LeetCode 每日一题】3000. 对角线最长的矩形的面积
算法·leetcode·职场和发展
2zcode1 小时前
基于Matlab可见光通信系统中OOK调制的误码率性能建模与分析
算法·matlab·php
纵有疾風起2 小时前
数据结构中的排序秘籍:从基础到进阶的全面解析
c语言·数据结构·算法·排序算法
纪元A梦2 小时前
贪心算法应用:推荐冷启动问题详解
算法·贪心算法
听风说雨的人儿2 小时前
腾讯面试题之编辑距离
算法
Lululaurel2 小时前
机器学习系统框架:核心分类、算法与应用全景解析
人工智能·算法·机器学习·ai·分类
愚润求学2 小时前
【贪心算法】day8
c++·算法·leetcode·贪心算法
递归尽头是星辰3 小时前
双指针与滑动窗口算法精讲:从原理到高频面试题实战
算法·双指针·滑动窗口·子串/子数组问题
_OP_CHEN3 小时前
数据结构(C语言篇):(十三)堆的应用
c语言·数据结构·二叉树·学习笔记·堆排序··top-k问题