c语言:解决数组有关的删除,排序,合并等问题。

题目1:判断数组是否有序(升序或者降序)


 

思路和代码:

#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{int a = 0;scanf("%d", &a);int arr[50];int flag1 = 0;//是降序int flag2 = 0;//是升序for (int i = 0; i < a; i++){scanf("%d", &arr[i]);if (i > 0){if (arr[i] >= arr[i - 1])//如果存在降序{flag1 = 1;//降序赋值为1}if (arr[i] < arr[i - 1])//如果存在升序{flag2 = 1;//升序赋值为1}}}if (flag1 + flag2 == 1)//满足升序或者降序其中一个就是有序数组{printf("sorted\n");}else//反之不是{printf("unsorted\n");}
}

题目2:去除数组中重复的数字 

思路和代码: 

#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{int a = 0;scanf("%d", &a);int arr[1000];//读取for (int i = 0; i < a; i++){scanf("%d", &arr[i]);}//去重for (int i = 0; i < a; i++){int j = 0;for (j = i + 1; j < a; j++)//从下一个元素开始找{if (arr[i] == arr[j])//重复{//去重,后面元素往前覆盖int k = 0;for (k = j; k < a - 1; k++){arr[k] = arr[k + 1];//因为最大到a,所以k+1<a,k<a-1}a--;//数组个数减少一个j--;下标回退,重新判断后面有没有重复的}}}for (int i = 0; i < a; i++){printf("%d ", arr[i]);}return 0;}

题目3:合并,排序两个有序数组,并打印 

思路和代码: 

#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{int n = 0;int m = 0;//创建两个数组int arr1[100] = { 0 };int arr2[100] = { 0 };//传入两个数组的元素个数scanf("%d %d", &n, &m);int i = 0;//输入数组1for (i = 0; i < n; i++){scanf("%d", &arr1[i]);}//输入数组2for (i = 0; i < m; i++){scanf("%d", &arr2[i]);}//int j = 0;i = 0;//合并while (i < n && j < m){if (arr1[i] < arr2[j])//哪个数组元素小先打印谁{printf("%d ", arr1[i]);i++;}else{printf("%d ", arr2[j]);j++;}}if (i == n)//相等都打印一次{for (; j < m; j++){printf("%d ", arr2[j]);}}else{for (; i < n; i++){printf("%d ", arr1[i]);}}return 0;
}

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

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

相关文章

Zabbix实现故障自愈

一、简介 Zabbix agent 可以运行被动检查和主动检查。 在被动检查模式中 agent 应答数据请求。Zabbix server&#xff08;或 proxy&#xff09;询求数据&#xff0c;例如 CPU load&#xff0c;然后 Zabbix agent 返还结果。 主动检查处理过程将相对复杂。Agent 必须首先从 Z…

Web之JavaScript(jQuery)笔记

Web之HTML、CSS、JavaScript 三、JavaScriptJS调试变量自定义函数数据类型及转换运算符优先级内置函数数组事件DOM(Document Object Model 文档对象模型)jQuery Web之HTML笔记 Web之CSS笔记 三、JavaScript JavaScript&#xff08;简称“JS”&#xff09;是一种轻量级的面向对…

关于缓存和数据库一致性问题的深入研究

如何保证缓存和数据库一致性&#xff0c;这是一个老生常谈的话题了。 但很多人对这个问题&#xff0c;依旧有很多疑惑&#xff1a; 到底是更新缓存还是删缓存&#xff1f;到底选择先更新数据库&#xff0c;再删除缓存&#xff0c;还是先删除缓存&#xff0c;再更新数据库&…

2023最新最全【内网渗透工具】零基础安装教程

1.1 简介 nps是一款轻量级、高性能、功能强大的内网穿透代理服务器。目前支持tcp、udp流量转发&#xff0c;可支持任何tcp、udp上层协议&#xff08;访问内网网站、本地支付接口调试、ssh访问、远程桌面&#xff0c;内网dns解析等等……&#xff09;&#xff0c;此外还支持内网…

LeetCode(29)三数之和【双指针】【中等】

目录 1.题目2.答案3.提交结果截图 链接&#xff1a; 三数之和 1.题目 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复…

【Java SE】循环一些基本练习

判定一个数字是否是素数 public class Test {public static int is_sushu(int n) {if(n 1) {return 0;}int i ;for (i 2; i < Math.sqrt(n); i) {if(n % i 0 ) {break;}}if (i > n) {return 1;}return 0;}public static void main(String[] args) {Scanner scanner …

高效背单词——单词APP安利

大英赛&#xff0c;CET四六级&#xff0c;以及考研英语&#xff0c;都在不远的未来再度来临&#xff0c;年复一年的考试不曾停息&#xff0c;想要取得好成绩&#xff0c;需要我们的重视并赋予相应的努力。对于应试英语&#xff0c;词汇量是不可忽略的硬性要求。相比于传统默写&…

2243. 计算字符串的数字和

2243. 计算字符串的数字和 Java&#xff1a;以 k 为步长进行跳&#xff01;然后再延伸k class Solution {public String digitSum(String s, int k) {while (s.length() > k) {int n s.length();StringBuilder sb new StringBuilder(); // sb存&#xff01;for (int i …

麦克风阵列入门

文章引注&#xff1a; http://t.csdnimg.cn/QP7uC 一、麦克风阵列的定义 所谓麦克风阵列其实就是一个声音采集的系统&#xff0c;该系统使用多个麦克风采集来自于不同空间方向的声音。麦克风按照指定要求排列后&#xff0c;加上相应的算法&#xff08;排列算法&#xff09;就可…

【Qt开发流程之】窗口部件

qt类关系图 创建Qt项目时&#xff0c;发现提供的窗体默认 基类有&#xff1a;QMainWindow、QDialog、QWidget这三种。 之后&#xff0c;你会发现&#xff0c;这3中窗体在UI交互中&#xff0c;用的也是最多的。 以下是Qt类关系图&#xff1a; 基础窗口控件QWidget 由上图可以…

gradle8.0或者其他版本下载太慢或者time out超时(完美解决方法)

官网镜像地址 如果其他软件除了android studio可以在下面完整直接下载 地址&#xff1a;https://mirrors.cloud.tencent.com/gradle/ Android Stuiod如何配置更换 项目名称\gradle\wrapper\gradle-wrapper.properties 下面是我已经更改后的了&#xff0c;大家如果跟这个不一样换…

Blowfish在线加密解密调试校验工具

具体请前往&#xff1a;在线Blowfish加密解密工具