C语言实验-数组、字符串以及指针

一:

求一个N×N矩阵主、次对角线上所有元素之和。矩阵输入、矩阵输出、矩阵对角线求和分别用三个子函数实现。(N的值由用户从键盘输入)

 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>void print(int(*arr)[3], int N)
{for (int i = 0; i < N; i++){for (int j = 0; j < N; j++){printf("%d ", *(arr[i] + j));}printf("\n");}printf("\n");
}void input(int(*arr)[3], int N)
{for (int i = 0; i < N; i++){for (int j = 0; j < N; j++){scanf("%d", (arr[i] + j));}}
}int fun(int (*arr)[3], int N)//指针数组的形式传参
{int ret = 0;for (int i = 0; i < N; i++){ret += *(arr[i] + i);}return ret;
}int main()
{printf("输入数组行列数:\n");int N = 0;scanf("%d", &N);int(*arr)[3] = (int(*)[3])malloc(sizeof(int) * N * N);//数组指针,[3]中的3没有任何意义,但是不能去掉printf("输入数组:\n");input(arr, N);print(arr, N);printf("对角线之和为%d", fun(arr, N));return 0;
}

二: 

编写程序,将一个数列实现循环右移一位。

例如:  输入数列的长度:6

输入原始数列:1  2  3  4  5  6

循环右移一位后变为:6  1  2  3  4  5

数列输入、数列输出、数列右移分别用三个子函数实现。(数列的个数由用户从键盘输入)

 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>void print(int* arr, int N)
{for (int i = 0; i < N; i++){printf("%d ", arr[i]);}printf("\n");
}void input(int* arr, int N)
{for (int i = 0; i < N; i++){scanf("%d", &arr[i]);}
}void fun(int* arr, int N)
{int* arr2 = (int*)malloc(sizeof(int) * N);for (int i = 1; i < N; i++){arr2[i] = arr[i - 1];}arr2[0] = arr[N - 1];print(arr2, N);
}int main()
{printf("请输入数组长度:");int N = 0;scanf("%d", &N);int* arr = (int*)malloc(sizeof(int) * N);//动态开辟空间input(arr, N);fun(arr, N);return 0;
}

三:

在2题的基础上,改写程序,实现数列右移n位。数列输入、数列输出、数列右移分别用三个子函数实现。(数列的个数、右移的位数由用户从键盘输入)

例如:  输入数列的长度:6

输入原始数列:1  2  3  4  5  6

        输入右移的位数:3

循环右移3位后变为:4  5  6  1  2  3 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>void print(int* arr, int N)
{for (int i = 0; i < N; i++){printf("%d ", arr[i]);}printf("\n");
}void input(int* arr, int N)
{for (int i = 0; i < N; i++){scanf("%d", &arr[i]);}
}void fun(int* arr, int N, int a)
{int* arr2 = (int*)malloc(sizeof(int) * N);for (int i = a; i < N; i++){arr2[i] = arr[i - a];}for (int i = 0; i < a; i++){arr2[i] = arr[N - a + i];}print(arr2, N);
}int main()
{printf("请输入数组长度:");int N = 0;scanf("%d", &N);int* arr = (int*)malloc(sizeof(int) * N);input(arr, N);printf("右移的位数:");int a = 0;scanf("%d", &a);fun(arr, N, a);return 0;
}

四: 

编写程序,删除数列中的某个数。数列输入、数列输出、数列删除分别用三个子函数实现。(数列、要删除的数值都由用户从键盘输入,有则删除——所谓删除就是后序的元素往前覆盖,无则提示“该数不存在。”)

例如:  输入数列的长度:11

输入原始数列:1  2  3  4  5  6  2  8  -5  2  7

        输入要删除的数: 2

删除以后的数列长度:8

删除以后的数列:1  3  4  5  6  8  -5  7

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>void print(int* arr, int N)
{for (int i = 0; i < N; i++){printf("%d ", arr[i]);}printf("\n");
}void input(int* arr, int N)
{for (int i = 0; i < N; i++){scanf("%d", &arr[i]);}
}void fun(int* arr, int N, int a)//N位数组长度 a为要删除元素
{int num = N;int* arr2 = (int*)malloc(sizeof(int) * N);int j = 0;int i = 0;while (j < N){if (arr[j] == a){j++;num--;}arr2[i++] = arr[j++];}printf("删除以后的数列长度:%d\n", num);print(arr2, num);
}int main()
{printf("输入数组长度:");int N = 0;scanf("%d", &N);int* arr = (int*)malloc(sizeof(int) * N);input(arr, N);printf("输入要删除的数:");int a = 0;scanf("%d", &a);fun(arr, N, a);return 0;
}

五:

编写程序,将数列中大于平均值的元素往前放,小于平均值的数往后放。数列输入、数列输出、数列求平均值、数列重排分别用四个子函数实现。(数列长度由用户从键盘输入)

例如:  输入数列的长度:10

输入原始数列:1  5  15  23  7  9  19  10  -5  22

其平均值为:10.6

重排以后的数列:15  23  19  22  1  5  7  9  10  -5

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>void print(int* arr, int N)
{for (int i = 0; i < N; i++){printf("%d ", arr[i]);}printf("\n");
}void input(int* arr, int N)
{for (int i = 0; i < N; i++){scanf("%d", &arr[i]);}
}double average(int* arr, int N)
{int ret = 0;double sum = 0;for (int i = 0; i < N; i++){sum += arr[i];}return sum / N;
}void fun(int* arr, int N)
{int ave = average(arr, N);int i = 0;int j = N;while (j > i)//当i位置的数小于平均值,j位置的值大于平均值,交换i 和j指向的值{while (arr[j] < ave){j--;}while (arr[i] > ave){i++;}if (j > i){int tmp = arr[i];arr[i] = arr[j];arr[j] = tmp;}}
}int main()
{printf("输入数组元素个数:");int N = 0;scanf("%d", &N);int* arr = (int*)malloc(sizeof(int) * N * N);printf("输入数组:");input(arr, N);printf("其平均值为:%.1lf\n", average(arr, N));fun(arr, N);printf("重拍之后的数组:");print(arr, N);return 0;
}

六: 

编写子函数fun,其功能是将形参数列中小于平均值且最接近平均值的数返回,main函数负责输入、输出。

例如:   输入数列的长度:10

输入数列:46、30、32、40、6、17、45、15、48、26

         数列的平均值:30.50

         小于平均值且最接近平均值的数为:30

 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<math.h>void print(int* arr, int N)
{for (int i = 0; i < N; i++){printf("%d ", arr[i]);}printf("\n");
}void input(int* arr, int N)
{for (int i = 0; i < N; i++){scanf("%d", &arr[i]);}
}double average(int* arr, int N)
{double sum = 0;for (int i = 0; i < N; i++){sum += arr[i];}return sum / N;
}int fun(int* arr, int N)
{double ave = average(arr, N);double gap = 0;int ret = arr[0];for (int i = 1; i < N; i++){gap = fabs(arr[i] - ave);if (gap < fabs(ret - ave)){ret = arr[i];}}return ret;}int main()
{printf("输入数列的长度:");int N = 0;scanf("%d", &N);int* arr = (int*)malloc(sizeof(int) * N * N);printf("输入数组:");input(arr, N);printf("平均值为:%.2lf\n", average(arr, N));printf("小于平均值且最接近平均值的数为:%d", fun(arr, N));return 0;
}

七: 

编写程序,将用户输入的字符串中从第i个到第j个之间的字符逆序颠倒。(字符串、i、j的值都由用户从键盘输入)

例如: 输入字符串:abcdefgh

       输入i:3

       输入j:7

颠倒以后的字符串为:abgfedch

 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
void swap(char* ch1, char* ch2)
{char tmp = *ch1;*ch1 = *ch2;*ch2 = tmp;
}void reverse(char* str, int i, int j)
{while (i < j){swap(&str[i], &str[j]);i++;j--;}
}int main()
{char str[50] = {0};//长度设为50printf("输入字符串:");scanf("%s", str);//输入int i = 0; int j = 0;printf("\n输入i:");scanf("%d", &i);printf("\n输入j:");scanf("%d", &j);reverse(str,i-1,j-1);printf("\n颠倒以后的字符串为:%s", str);return 0;
}

 

 八:

编写程序,删除字符串中的某个字符。(字符串、要删除的字符都由用户从键盘输入,有则删除——所谓删除就是后序的元素往前覆盖,无则提示“该字符不存在。”)

例如:  输入原始字符串:abcebacebaghbf

        输入要删除的字符: b

删除以后的字符串:aceaceaghf

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>void fun(char *str,char a)
{char str1[50] = "\0";int i = 0;int j = 0;while (str[i] != '\0'){while(str[i] == a){i++;}str1[j] = str[i];i++;j++;}str[++j] = '\n';for (int i = 0; i < j; i++){str[i] = str1[i];}
}int main()
{printf("输入字符串:\n");char str[50] = "\0";scanf("%s", str);getchar();char a = '\0';printf("输入要删除的字符: ");scanf("%c", &a);fun(str,a);printf("删除以后的字符串:%s",str);	return 0;
}

九:

编写程序,将一个数字字符串转换成面值相同的整数输出。(假设全是整数,不需要考虑小数情况)

例如:  输入数字字符串:21459     (这里输入的是一个字符串,放在一个char型数组里。)

        输出整数: 21459     (这里输出的是一个int型变量)

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>int fun(char *str)
{int ret = 0;int i = 0;while (str[i] != '\0'){ret = (str[i]-'0') + ret * 10;i++;}return ret;
}int main()
{printf(" 输入数字字符串:\n");char str[50] = "\0";scanf("%s", str);getchar();printf("输出整数:%d", fun(str));return 0;
}

 

十: 

编写程序,将一个字符串中的数字字符串转换成对应的整数输出 (假设全是整数,不需要考虑小数情况)

例如:  输入字符串:abs123efe45sefe89sef

            输出整数:123  45  89       (输出的是3个整数)

 

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>void fun(char* str)
{int i = 0;printf("输出整数:\n");while (str[i] != '\0'){int ret = 0;int flag = 0;while (str[i] <= '9' && str[i] >= '0'){flag = 1;ret = str[i] - '0' + ret * 10;i++;}if (flag != 0){printf("%d ", ret);}i++;}
}int main()
{printf("输入字符串:\n");char str[50] = "\0";scanf("%s", str);getchar();fun(str);return 0;
}

取码点赞👍!

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

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

相关文章

有哪些好用的局域网电脑监控系统软件?

企业员工不好管理&#xff1f;&#xff1f;&#xff1f; 局域网已成为企业日常运营不可或缺的一部分。 然而&#xff0c;随着网络技术的普及&#xff0c;员工在局域网中的不当行为也日益增多&#xff0c;如滥用网络资源、泄露敏感信息、消极怠工等。 为了解决这些问题&#x…

植物大战僵尸杂交版

1.感谢作者潜艇伟伟迷 2.大小大概110M&#xff0c;下载链接在下方 链接&#xff1a;https://pan.baidu.com/s/1Ew6iTg0_d_Ut8N9_18KGLw 提取码&#xff1a;yspa 3.祝大家玩的开心

嵌入式学习——C语言基础——day13

1. 结构体类型的定义 struct 类型名 { 数据类型1 成员变量1; 数据类型2 成员变量2; 数据类型3 成员变量3; ... }; 定义结构体中可以使用的数据类型有 1.基本数据类型&#xff1a;int long short char doub…

C++-10

1.C一个程序&#xff0c;实现两个类&#xff0c;分别存放输入的字符串中的数字和字母&#xff0c;并按各自的顺序排列&#xff0c; 类中实现-一个dump函数&#xff0c;调C用后输出类中当前存放的字符串结果。 例如&#xff0c;输入1u4y2a3d,输出:存放字母的类&#xff0c;输出a…

Mybatis-plus对单表操作的封装

MyBatis-Plus单表操作详解及拓展 MyBatis-Plus是一个基于MyBatis的增强工具&#xff0c;它提供了丰富的CRUD操作和分页查询等功能&#xff0c;极大地简化了开发人员的数据库操作。本文将详细介绍MyBatis-Plus官方已经写好的单表操作&#xff0c;并提供一些拓展内容。 1. 引言…

爬虫 - 基于requests进行二次开发

项目地址 https://github.com/markadc/wauo.git持续更新中…

树,二叉树的基本概念介绍,二叉树的性质

目录 树 树的定义 树的相关概念 树的存储结构 树在实际中的运用&#xff08;表示文件系统的目录树结构 &#xff09; 二叉树 二叉树的定义 现实中的二叉树 二叉树的特点 特殊的二叉树 1.斜树 2.满二叉树 3.完全二叉树 二叉树的性质 性质1&#xff1a;二叉树的第…

嵌入式C语言教程:实现DMA控制的高速SPI通信

在高速数据传输应用中&#xff0c;SPI&#xff08;串行外设接口&#xff09;是一种常用的通信协议。 利用DMA&#xff08;直接内存访问&#xff09;进行SPI数据传输可以显著提高数据处理效率&#xff0c;减少CPU的负载。 本文将详细介绍如何在STM32微控制器上配置和使用DMA来…

2012NOIP普及组真题 2. 寻宝

线上OJ&#xff1a; 一本通&#xff1a;http://ybt.ssoier.cn:8088/problem_show.php?pid1958 核心思想&#xff1a;&#xff08;模拟&#xff09; 1、模拟 每一层从起始房间开始&#xff0c;轮询 x 个有楼梯的房间后到达终点房间 2、由于 0 < N ≤ 10000 &#xff0c; 0…

网络基础(1)网络编程套接字UDP

要完成网络编程首先要理解原IP和目的IP&#xff0c;这在上一节已经说明了。 也就是一台主机要进行通信必须要具有原IP和目的IP地址。 端口号 首先要知道进行网络通信的目的是要将信息从A主机送到B主机吗&#xff1f; 很显然不仅仅是。 例如唐僧要去到西天取真经&#xff0…

源码篇--Nacos服务--中章(8):Nacos服务端感知客户端实例变更-3

文章目录 前言一、客户端实例变更&#xff1a;二、实例变更感知&#xff1a;2.1 实例注册信息通知&#xff1a;2.1.1 接收DistroDataRequest 请求&#xff1a;2.1.2 onReceive 处理请求&#xff1a;2.1.3 processData 处理请求&#xff1a;2.1.4 handlerClientSyncData 处理数据…

Optimistic乐观挑战游戏Sharelock审计大赛

1. 引言 Optimistic的Sherlock审计大赛已进入升级期&#xff0c;fault proofs距离OP主网上线又更近一步了。本文将分享一些初步竞赛结果以及通往Stage 1的后续安排。 2. 审计状态更新 2024年3月27日&#xff0c;Optimistic团队开始针对拟议的 OP Stack fault proof系统进行 …

MySQL修改密码过期时间

1、my.ini中设置 [mysqld] #过期时间90天 default_password_lifetime90 2、或者 SET GLOBAL default_password_lifetime 90; 3、或者 ALTER USER usernamehostname PASSWORD EXPIRE INTERVAL 90 DAY; 4、查看过期时间 SHOW VARIABLES LIKE default_password_lifetime; …

k8s集群Grafana精选dashboard页面

文章目录 参考文档 Grafana自选模板推荐模板&#xff1a;13332、13824、14518Grafana默认配置我们选择 Node Exporter/Nodes 的 Dashboard 进去&#xff1a;点击 Kubernetes/Networking/Cluster 进去使用模板查看结果 Grafana接入Prometheus数据Grafana添加监控模板导入 1860_r…

光伏电站运维的重要性!

随着可再生能源的不断发展和应用&#xff0c;光伏电站成为了当下热门的能源产业之一。然而&#xff0c;光伏电站的运维管理却常常被忽视。光伏电站系统运维管理的重要性不容忽视&#xff0c;它直接关系着光伏电站的稳定运行、发电效率以及长期收益。 1.保证光伏电站的正常运行…

体验用AI写代码

近两年&#xff0c;AI确实迎来了大爆发&#xff0c;2023年也成了AI时代的元年&#xff0c;去年下半年的时候&#xff0c;国内月之暗面出品的Kimi成了新的AI热门&#xff0c;也体验用Kimi修改论文&#xff0c;以及用图片生成代码&#xff0c;代码准确度还是蛮高的。做为SRE&…

使用Python的Tkinter库创建你的第一个桌面应用程序

文章目录 准备工作创建窗口和按钮代码解释运行你的应用程序结论 在本教程中&#xff0c;我们将介绍如何使用Python的Tkinter库创建一个简单的桌面应用程序。我们将会创建一个包含一个按钮的窗口&#xff0c;点击按钮时会在窗口上显示一条消息。 准备工作 首先&#xff0c;确保…

【LeetCode题库】1068. 产品销售分析 I —— MySQL 性能提升,using()关键字

文章目录 原题题解解题笔记 我是一名立志把细节都说清楚的博主&#xff0c;欢迎【关注】&#x1f389; ~ 原创不易&#xff0c; 如果有帮助 &#xff0c;记得【点赞】【收藏】 哦~ ❥(^_-)~ 如有错误、疑惑&#xff0c;欢迎【评论】指正探讨&#xff0c;我会尽可能第一时间回…

扩展大型视觉-语言模型的视觉词汇:Vary 方法

在人工智能领域&#xff0c;大型视觉-语言模型&#xff08;LVLMs&#xff09;正变得越来越重要&#xff0c;它们能够处理多种视觉和语言任务&#xff0c;如视觉问答&#xff08;VQA&#xff09;、图像字幕生成和光学字符识别&#xff08;OCR&#xff09;。然而&#xff0c;现有…

互联网的路由选择协议

一、内部网关协议RIP &#xff08;1&#xff09;概述 RIP是一种分布式的、基于距离向量的路由选择协议。 RIP认为一个好的路由就是它通过的路由器的数目少&#xff0c;即“距离短”RIP允许一条路径最多只能包含15个路由器 &#xff08;2&#xff09;RIP的特点 和谁交换信息…