C语言创建数组实现函数init,empty,reverse
创建一个数组:
- 实现函数init()初始化数组
- 实现empty()清空数组
- 实现reverse()函数完成数组元素的逆置
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> void menu() { printf("****************************\n"); printf("******1.初始化数组元素******\n"); printf("******2.清空数组的元素******\n"); printf("******3.逆置数组的元素******\n"); printf("****************************\n"); } void init(int arr[],int len) { int i = 0; printf("请输入数组元素(以空格隔开):"); for (i = 0; i < len; i++) { scanf("%d", &arr[i]); } printf("初始化成功!!\n数组arr[%d]=", i); for (i = 0; i < len; i++) { printf("%d ", arr[i]); } printf("\n"); } void empty(int arr[],int len) { int i = 0; for (i = 0; i < len; i++) { arr[i]=0; } printf("清空成功!!\n数组arr[%d]=", i); for (i = 0; i < len; i++) { printf("%d ", arr[i]); } printf("\n"); printf("\n"); } void reverse(int arr[],int len) { int tmp = 0; int i = 0; for (i = 0; i < len / 2; i++) { tmp = arr[i]; arr[i] = arr[len - i - 1]; arr[len - i - 1] = tmp; printf("逆置成功:\n数组arr[%d]=", i); for (i = 0; i < len; i++) { printf("%d ", arr[i]); } printf("\n"); } } int main() { int len = 0; int i = 0; int arr[20] = { 0 }; printf("请输入数组位数:"); scanf("%d", &len); do { int i = 0; menu(); printf("请选择:"); scanf("%d", &i); switch (i) { case 1: init(arr,len); break; case 2: empty(arr,len); break; case 3: reverse(arr, len); break; default: printf("输入错误,请重新输入:\n"); break; } } while (1); return 0; }
运行结果:
到此这篇关于C语言创建数组实现函数init,empty,reverse的文章就介绍到这了,更多相关C语言创建数组内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
相关推荐
-
VS2017开发C语言出现“no_init_all“的解决办法
当你的编译器出现这种错误时,只需要在winnt.h头文件中 即可消除错误提示 补充一点 这一代码块是微软工程师用于在旧版本的VS中消除该错误提示的预编译头 虽然微软的工程师们宣称他们在最新的VS2019中已经修复了该错误,但是仍有很多人受到了该错误的困扰 以上所述是小编给大家介绍的VS2017开发C语言出现"no_init_all"的解决办法,希望对大家有所帮助.在此也非常感谢大家对我们网站的支持!
-
C语言全方位讲解指针与地址和数组函数堆空间的关系
目录 一.一种特殊的变量-指针 二.深入理解指针与地址 三.指针与数组(上) 四.指针与数组(下) 五.指针与函数 六.指针与堆空间 七.指针专题经典问题剖析 一.一种特殊的变量-指针 指针是C语言中的变量 因为是变量,所以用于保存具体值 特殊之处,指针保存的值是内存中的地址 内存地址是什么? 内存是计算机中的存储部件,每个存储单元有固定唯一的编号 内存中存储单元的编号即内存地址 需要弄清楚的事实 程序中的一切元素都存在于内存中,因此,可通过内存地址访问程序元素. 内存示例 获取地址 C语言中通
-
C语言函数传递数组和传递地址的区别你知道吗
目录 传递数值 传递地址 注: 总结 传递数值 code: #include <stdio.h> void deliveryData(int data) { data = data + 100; printf("deliveryData:data=%d\n", data); } int main(void) { int data=10; deliveryData(data); printf("main:data=%d\n", data); return
-
C语言的数组指针与函数指针详解
目录 前言 函数指针语法 数组指针与指针数组 总结 前言 数组指针和函数指针都是C语言比较难的知识点,尤其是函数指针,并且函数指针在开发中有着巨大的作用. 函数指针语法 定义一个函数指针,并通过函数指针间接调用函数: int get_num(int a, int b) { return a + b; } int (*func)(int a, int b); //定义了一个函数指针func,它指向 返回值为int 参数为 int a, int b的函数 func = &get_num; //函数指
-
C语言中二维数组作为函数参数来传递的三种方法
c语言中经常需要通过函数传递二维数组,有三种方法可以实现,如下: 方法一, 形参给出第二维的长度. 例如: #include <stdio.h> void func(int n, char str[ ][5] ) { int i; for(i = 0; i < n; i++) printf("/nstr[%d] = %s/n", i, str[i]); } void main() { char* p[3]; char str[][5] = {"abc&quo
-
详解C语言用malloc函数申请二维动态数组的实例
详解C语言用malloc函数申请二维动态数组的实例 C语言在程序运行中动态的申请及释放内存十分方便,一维数组的申请及释放比较简单. Sample one #include <stdio.h> int main() { char * p=(char *)malloc(sizeof(char)*5);//申请包含5个字符型的数组 free(p); return 0; } 是否申请二维动态内存也如此简单呢?答案是否定的.申请二维数组有一下几种方法 Sample two /* 申请一个5行3列的字符型
-
深入剖析Android中init进程实现的C语言源码
概述 init是一个进程,确切的说,它是Linux系统中用户空间的第一个进程.由于Android是基于Linux内核的,所以init也是Android系统中用户空间的第一个进程.init的进程号是1.作为天字第一号进程,init有很多重要的工作: init提供property service(属性服务)来管理Android系统的属性. init负责创建系统中的关键进程,包括zygote. 以往的文章一上来就介绍init的源码,但是我这里先从这两个主要工作开始.搞清楚这两个主要工作是如何实现的,我
-
C语言 module_init函数与initcall案例详解
module_init这个函数对做驱动的人来说肯定很熟悉,这篇文章用来跟一下这个函数的实现. 在include/linux/init.h里面有module_init的定义,自然,因为一个module可以在内核启动时自动加载进内核,也可以由我们手动在需要时加载进内核,基于这种场景,内核使用了MODULE这个宏,见代码: #ifndef MODULE #ifndef __ASSEMBLY__ ... #define __define_initcall(level,fn,id) \ static in
-
C语言创建数组实现函数init,empty,reverse
创建一个数组: 实现函数init()初始化数组 实现empty()清空数组 实现reverse()函数完成数组元素的逆置 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> void menu() { printf("****************************\n"); printf("******1.初始化数组元素******\n"); printf("******2.清空数组
-
C语言中数组作为函数的参数以及返回值的使用简单入门
函数通过数组作为参数 如果想通过一个一维数组作为函数的参数,就必须声明函数形式参数,使用以下三种方式与所有三个声明方法之一产生类似的结果,因为每一种方式告诉编译器,一个整数指针将会要被接收.类似的方式,可以使用多维数组形式参数. 方式-1 形式参数为指针如下.在下一章将学习什么是指针. void myFunction(int *param) { . . . } 方式-2 如下形式数组参数的大小: void myFunction(int param[10]) { . . . } 方式-3 如下形式
-
Python使用numpy模块创建数组操作示例
本文实例讲述了Python使用numpy模块创建数组操作.分享给大家供大家参考,具体如下: 创建数组 创建ndarray 创建数组最简单的方法就是使用array函数.它接收一切序列型的对象(包括其他数组),然后产生一个新的含有传入数据的Numpy数组. array函数创建数组 import numpy as np ndarray1 = np.array([1, 2, 3, 4]) ndarray2 = np.array(list('abcdefg')) ndarray3 = np.array([
-
Numpy中创建数组的9种方式小结
目录 1.使用empty方法创建数组 2.使用array创建数组 3.使用zeros/ones创建数组 4.使用arange创建数组 5.使用linspace创建数组 6.使用numpy.random.rand创建数组 7.使用numpy.random.randn创建数组 8.使用numpy.random.randint创建数组 9.使用fromfunction创建数组 1.使用empty方法创建数组 该方式可以创建一个空数组,dtype可以指定随机数的类型,否则随机采用一种类型生成随机数. i
-
5种PHP创建数组的实例代码分享
看这篇文章之前相信大家都已经看过PHP中文手册关于数组这一节的讲解了,怎么样呢,看懂了多少?至少我第一次阅读文档时是一头雾水,也许是因为在翻译的不够通俗易懂吧^_^!!这里UncleToo根据自己的经验,将数组的各种创建方式用PHP实例代码的方式分享给大家,希望对大家有些帮助(当然,PHP文档还是要多看的) 1.使用array()创建数组 array()创建数组是我们在PHP开发过程中最常用到的一种方式,准确来说array()是一种结构而不是一个函数. 示例1: 复制代码 代码如下: <?php
-
php compact 通过变量创建数组
php compact 通过变量创建数组 compact函数通过一个或多个变量建立一个数组,改数组包括变量名和它们的值. 该函数的行为与extract()正好相反. 基本语法 array compact ( mixed $varname [, mixed $... ] ) 创建一个包含变量与其值的数组. 对每个参数, compact() 在当前的符号表中查找该变量名并将它添加到输出的数组中,变量名成为键名而变量的内容成为该键的值.简单说,它做的事和 extract() 正好相反.返回将所有变量添
-
C语言超详细讲解函数栈帧的创建和销毁
目录 1.本节目标 2.相关寄存器 3.相关汇编指令 4.什么是函数栈帧 5.什么是调用堆栈 6.函数栈帧的创建和销毁 (1).main函数栈帧的创建与初始化 (2).main函数的核心代码 (3).Add函数的调用过程 (4).Add函数栈帧的销毁 (5).调用完成 7.对开篇问题的解答 1.本节目标 C语言绝命七连问,你能回答出几个? 局部变量是如何创建的?为什么局部变量不初始化其内容是随机的?有些时候屏幕上输出的"烫烫烫"是怎么来的?函数调用时参数时如何传递的?传参的顺序是怎样的
-
Go语言创建、初始化数组的常见方式汇总
本文实例总结了Go语言创建.初始化数组的常见方式.分享给大家供大家参考.具体分析如下: Go语言的语法很灵活,以下展示了创建并初始化数组的多种方式: 复制代码 代码如下: //数组初始化的各种方式 func arraySliceTest0201() { //创建数组(声明长度) var array1 = [5]int{1, 2, 3} fmt.Printf("array1--- type:%T \n", array1) rangeIntPrin
-
C语言之把数组名作函数参数的四种情况说明
目录 把数组名作函数参数的四种情况 思路 实参与形参的对应关系有以下四种情况 我们来看代码 一般函数作参数和数组名作参数区别 一般函数作参数 数组名作函数参数 把数组名作函数参数的四种情况 如果想要通过函数调用得到n个要改变的值 思路 ①在主函数中设n个变量,用n个指针变量指向它们 ②设计一个函数,有n个指针形参,在这个函数中改变这n个形参所指向的值 ③在主函数中调用这个函数,在调用时将n个指针变量做为实参,将它们的地址传给该函数的形参 ④在执行该函数的过程中,通过形参指针变量,改变它们所指向的
-
C语言之关于二维数组在函数中的调用问题
目录 关于二维数组在函数中的调用问题 函数调用二维数组 二维数组如何放到函数中使用 下面以一个二维矩阵的转置为例 关于二维数组在函数中的调用问题 之前在学习二维数组的时候感觉理解起来很简单,所以理解一下就过去了,但是当自己真正的去用二维数组数组解决一些问题(特别是在函数调用二维数组的过程中)才真正发现原来使用起来还是要去注意一些细节的.废话不多说,直接上干货! 函数调用二维数组 在函数中调用二维数组的具体格式如下: 1.声明:这是声明的两种格式,在这里定义的是一个N*5的二维字符数组,各位看官一
随机推荐
- ASP.NET中Global和URLReWrite用法
- 轻量级网页遮罩层jQuery插件用法实例
- javascript防篡改对象实例详解
- IT世界与金山周末联合预报1218
- Java异常处理实例教程
- 用js闭包的方法实现多点标注冒泡示例
- 微信公众号支付(一)如何获取用户openId
- asp.net JavaScript插件 JavaScript Function Outliner
- Go语言MD5加密用法实例
- javascript九宫格图片随机打乱位置的实现方法
- js获取客户端操作系统类型的方法【测试可用】
- PHP命名空间(Namespace)简明教程
- jQuery实现仿腾讯视频列表分页效果的方法
- Ruby中处理时间的一些基本操作
- JQuery拖动表头边框线调整表格列宽效果代码
- C#中调用SAPI实现语音识别的2种方法
- C++模板之特化与偏特化详解
- php代码出现错误分析详解第1/2页
- PHP实现的杨辉三角求解算法分析
- Golang实现请求限流的几种办法(小结)