C语言练习02-数组

news2024/11/29 4:53:33

一、求最值

已知数组元素为{33,5,22,44,55},找出数组中的最大值并打印在控制台

#include<stdio.h>
#include<math.h>

int main()
{
	int arr[] = {33,5,22,44,55};
	int max = arr[0];
	int len = sizeof(arr) / sizeof(int); 
    //注意:sizeof(arr)计算的是数组所占内存空间的总大小
    //计算数组长度时,应该用数组所占内存空间总大小除以数组类型的内存
    //比如:sizeof(arr)/sizeof(int)
	for(int i = 0; i < len; i++)
	{
		if(arr[i] > max)
		{
			max = arr[i];
		}
	}
	printf("%d\n",max);
	return 0;
}

二、数组求和

生成10个1~100之间的随机数存入数组,要求数据不能重复

1)求出所有数据的和

2)求所有数据的平均数

3)统计有多少个数据比平均值小

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

int main()
{
	int arr[10] = {0};
	int i = 0;
	int sum = 0;
	int num = 0;
	int Num = 0;
	srand((unsigned int) time(NULL));
	
	//存入数据
	for(i = 0; i < 10; i++)
	{
		int ret = rand() % 100 + 1;
		arr[i] = ret;
	}
	
	//打印数据
	for(int j = 0;j < 10;j++)
	{
		printf("%d ",arr[j]);
	}
	printf("\n");
	
	//求和
	for(int j = 0;j < 10;j++)
	{
		sum = sum + arr[j];
	}
	printf("和为%d ",sum);
	
	//求平均数
	num = sum / 10;
	printf("平均数等于%d",num);
	return 0;
	
	//统计
	for(int j = 0;j < 10;j++)
	{
		if(arr[j] < num)
		{
			Num++;
		}
	}
	printf("有%d个数比平均数小",Num);
}

三、反转数组

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

int main()
{
	int arr[] = {2,4,6,8};
	int len = sizeof(arr)/sizeof(int);
	for(int i = len - 1;i >= 0;i--)
	{
		printf("%d ",arr[i]);
	}
	return 0;
}

四、打乱数组中数据的顺序

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

int main()
{
	int arr[] = {2,4,6,8};
	int len = sizeof(arr)/sizeof(int);
	srand(time(NULL));
	int ret = rand() % len;
	for(int i = 0;i < len;i++)
	{
		int temp = arr[i];
		arr[i] = arr[ret];
		arr[ret] = temp;
	}
	for(int i = 0;i < len;i++)
	{
		printf("%d ",arr[i]);
	}
	return 0;
}

五、数组常见算法1-基本查找/顺序查找

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

int main()
{
	//查找8,若存在则返回其索引值,若不存在,则返回-1
	int arr[] = {2,4,6,8,10};
	int len = sizeof(arr)/sizeof(int);
	for(int i = 0;i < len;i++)
	{
		if(arr[i] == 8)
		{
			printf("%d",i);
		}
	}
	return -1;
}

六、数组常见算法2-二分查找

前提:数据必须按顺序排列

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

int BinarySearch(int arr[],int num)
{
	int min = 0;
	int len = sizeof(arr) / sizeof(arr[0]);
	int max = len - 1;
	int mid = (min + max) / 2;
	while(true){
		if(min > max)
		{
			return -1;
		}
		//如果数字在mid的左边,则舍弃右边数字,max变为mid-1
		if(num < arr[mid])
		{
			max = mid - 1;
		}
		//如果数字在mid的右边,则舍弃左边数字,min变为mid+1
		if(num > arr[mid])
		{
			min = mid + 1;
		}
		//如果num和mid索引上的数字相同,则返回mid
		if(num == arr[mid])
		{
			return mid;
		}
	}
	
}

int main()
{
	int arr[] = {2,4,6,8,10};
	int num = 8;
	printf("%d",BinarySearch(arr,num));
	
}


七、冒泡排序法

#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<time.h>

	
int main()
{
	int arr[] = {7,4,9,3,5,1};
	int len = sizeof(arr) / sizeof(int);
	for(int i = 0;i < len - 1;i++)
	{
		for(int j = 0;j < len - 1 - i;j++)
		{
			if(arr[j] > arr[j+1])
			{
				int temp = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = temp;
			}
		}
	}
	for(int i = 0;i < len;i++)
	{
		printf("%d ",arr[i]);
	}
	
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1844524.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

新世纪助力无锡市第二人民医院通过ITSS认证

通过江苏新世纪信息科技有限公司的咨询辅导&#xff0c;无锡市第二人民医院通过合规性审查、复核、评定审核环节&#xff0c;顺利完成ITSS通用要求的认证。近日&#xff0c;评定结果在“ITSS中国电子工业标准化技术协会信息技术服务分会”网站&#xff08;https://www.itss.cn&…

【0基础学爬虫】爬虫基础之自动化工具 Appium 的使用

大数据时代&#xff0c;各行各业对数据采集的需求日益增多&#xff0c;网络爬虫的运用也更为广泛&#xff0c;越来越多的人开始学习网络爬虫这项技术&#xff0c;K哥爬虫此前已经推出不少爬虫进阶、逆向相关文章&#xff0c;为实现从易到难全方位覆盖&#xff0c;特设【0基础学…

推荐系统三十六式学习笔记:原理篇.矩阵分解12|如果关注排序效果,那么这个模型可以帮到你

目录 矩阵分解的不足贝叶斯个性化排序AUC构造样本目标函数训练方法 总结 矩阵分解在推荐系统中的地位非常崇高。它既有协同过滤的血统&#xff0c;又有机器学习的基因&#xff0c;可以说是非常优秀了&#xff1b;但即便如此&#xff0c;传统的矩阵分解无论是在处理显式反馈&…

图解Sieve of Eratosthenes(埃拉托斯特尼筛法)算法求解素数个数

1.素数的定义 素数又称质数。质数是指在大于1的自然数中&#xff0c;除了1和它本身以外不再有其他因数的自然数。一个大于1的自然数&#xff0c;除了1和它自身外&#xff0c;不能被其他自然数整除的数叫做质数&#xff1b;否则称为合数&#xff08;规定1既不是质数也不是合数&…

(day1)数据类型详解及DML语句入门

一、数据类型 1、整型类型 &#xff08;1&#xff09;创建数据库 CREATE DATABASE ql_linux&#xff1b; CREATE SCHEMA IF NOT EXISTS ql_linux&#xff1b; //IF NOT EXISTS如果没有表就创建 SHOW DATABASE; //查看数据库 &#xff08;2&#xff09;创建表 C…

C语言变量、指针的内存关系

1. type p ? 表示从内存地址p开始&#xff0c;开辟一段内存&#xff0c;内存大小为类型type规定的字节数&#xff0c;然后把等号右边的值写入到这段内存中。 因此&#xff0c;这块内存起点位置是p&#xff0c;结束是ptype字节数-1。 2. type* p ?表示从内存地址p开始&…

算法:分治(归并)题目练习

目录 题目一&#xff1a;排序数组 题目二&#xff1a;数组中的逆序对 题目三&#xff1a;计算右侧小于当前元素的个数 题目四&#xff1a;翻转对 题目一&#xff1a;排序数组 给你一个整数数组 nums&#xff0c;请你将该数组升序排列。 示例 1&#xff1a; 输入&#xf…

Tailwindcss 提取组件

背景 随着项目的发展&#xff0c;您不可避免地会发现自己需要重复使用常用样式&#xff0c;以便在许多不同的地方重新创建相同的组件。这在小组件&#xff08;如按钮、表单元素、徽章等&#xff09;中最为明显。在我的项目中是图表标题样式如下&#xff1a; <div class&qu…

14-Kafka-Day03

第 5 章 Kafka 消费者 5.1 Kafka 消费方式 5.2 Kafka 消费者工作流程 5.2.1 消费者总体工作流程 一个消费者组中的多个消费者&#xff0c;可以看作一个整体&#xff0c;一个组内的多个消费者是不可能去消费同一个分区的数据的&#xff0c;要不然就消费重复了。 5.2.2 消费者…

SpringSecurity6从入门到实战之登录后操作

SpringSecurity6从入门到实战之登录后操作 上次已经了解了如何进行自定义登录页面,这次主要是详细讲解登录成功,登录之后的跳转以及包括退出登录等一系列操作.让我们来看看SpringSecurity需要如何进行配置 登录之后的跳转 定义 Spring Security 配置类 Configuration EnableW…

数据治理的七大核心技术 全面了解数据治理必读篇

在当今的数字化时代&#xff0c;数据已成为企业最宝贵的资产之一&#xff0c;其价值不仅体现在数据量的巨大&#xff0c;更在于数据的深度和宽度。随着大数据、云计算、物联网&#xff08;IoT&#xff09;和人工智能&#xff08;AI&#xff09;等技术的不断进步&#xff0c;企业…

25考研线代攻略,老师及习题册推荐!

其实很多经验贴对大家有一定的误导 网上很多人说李永乐讲的好&#xff0c;确实好&#xff0c;但是没有说听李永乐的线代需要一定的基础 于是很多人去听完李永乐&#xff0c;就懵逼了&#xff0c;这讲的很乱啊&#xff0c;听的一头雾水。 其实&#xff0c;李永乐的基础班授课…

天才简史——Diederik P. Kingma与他的Adam优化器

一、了解Diederik P. Kingma 发生日期&#xff1a;2024年6月18日 前几日&#xff0c;与实验室同门一同前往七食堂吃饭。饭间&#xff0c;一位做随机优化的同门说他看过一篇被引18w的文章。随后&#xff0c;我表示不信&#xff0c;说你不会数错了吧&#xff0c;能有1.8w次被引都…

智慧城市低空+AI视频智能监控:构建新时代安全防线

随着科技的飞速发展&#xff0c;智能监控技术已经广泛应用于各个领域&#xff0c;从城市治理到工业生产&#xff0c;从公共安全到环境监测&#xff0c;都发挥着越来越重要的作用。而在低空领域&#xff0c;AI视频智能监控方案的建设更是成为了一个热点话题。 一、低空AI视频智…

Java异常和文件

一、异常 1.定义 异常&#xff1a;异常就是代表程序出现的问题 体系结构&#xff1a; 最上层的是 Throwable 类&#xff0c;下面有两个子类&#xff1a; ① Error&#xff1a;代表系统级别的问题&#xff08;属于严重问题&#xff0c;比如&#xff1a;内存溢出&#xff09;。…

VScode基本使用

VScode下载安装&#xff1a; Visual Studio Code - Code Editing. Redefined MinGW的下载安装&#xff1a; MinGW-w64 - for 32 and 64 bit Windows - Browse Files at SourceForge.net x86是64位处理器架构&#xff0c;i686是32为处理器架构。 POSIX和Win32是两种不同的操…

java文件传输小工具 java17+springboot3+thymeleaf

背景 在和同事工作中经常需要传输文件&#xff0c;但是公网传输太慢&#xff0c;业务方不是计算机专业直接用命令行沟通麻烦。 本小工具通过页面可视化方便用户使用&#xff0c;端口9090&#xff0c;启动默认展示当前登陆本机用户的桌面。 代码开源&#xff1a; https://git…

SM9加密算法:安全、高效的国产密码技术

随着信息技术的飞速发展&#xff0c;网络安全问题日益凸显。加密算法作为保障信息安全的核心技术&#xff0c;受到了广泛关注。在我国&#xff0c;一种名为SM9的加密算法逐渐崭露头角&#xff0c;凭借其卓越的安全性能和高效计算能力&#xff0c;成为了新一代国产密码技术的代表…

NGINX_九 nginx_proxy代理

九 nginx_proxy代理 1.代理 1.1 代理原理 反向代理产生的背景&#xff1a; 在计算机世界里&#xff0c;由于单个服务器的处理客户端&#xff08;用户&#xff09;请求能力有一个极限&#xff0c;当用户的接入请求蜂拥而入时&#xff0c;会造成服务器忙不过来的局面&#xff0…

使用Jetpack Compose和DummyJSON加速你的Android开发

使用Jetpack Compose和DummyJSON加速你的Android开发 在现代Android开发中&#xff0c;Jetpack Compose提供了一种全新的UI构建方式&#xff0c;同时DummyJSON简化了开发过程中数据获取的复杂性。本文将详细介绍一个名为firefly-compose的Jetpack Compose模板应用程序&#xf…