当前位置: 首页 > news >正文

【牛客网C语言刷题合集】(四)

🌟菜鸟主页:@晨非辰的主页

  👀学习专栏:《C语言刷题集》

💪学习阶段:C语言方向初学者

名言欣赏:"学习不是填满一桶水,而是点燃一把火。"


1.  有序序列合并

--题目链接:有序序列合并_牛客网


  解题思路——

--对于变量,数组……准备工作,小子就不多bb了; 直接看结构

  • 大体结构

        -- 首先想到进行有序合并就要比较大小,这里需要选择语句:用下标访问元素,遍历俩数组元素并大小;

                --说到遍历就需要循环结构,因为可以判断循环条件比较简单:只要避免数组越界即可;所以使用while结构;

        -- 再者,往前看,输入数组元素时,俩数组长度同样长的概率较小,一般是合并完一个数组,就要着手打印另个数组的剩余元素;      

                --这时要判断是哪个数组有身剩余:选择语句,条件也简单:下标未达到数组长度-1


#include <stdio.h>
int main()
{int n = 0;int m = 0;scanf("%d%d", &n, &m);//检查输入是否正确if (n < 1 || n > 1000 || m < 1 || m > 1000) {printf("n和m的范围应为1到1000。\n");return 1;}int arr1[1000] = { 0 };int arr2[1000] = { 0 };//数组arr1输入升序数组for (int i = 0; i < n; i++){scanf("%d", &arr1[i]);//检查数组元素输入if (arr1[i] < 0 || arr1[i] > 30000) {printf("arr1[%d]超出范围!\n", i);return 1;}}//数组arr2输入升序数组for (int j = 0; j < m; j++){scanf("%d", &arr2[j]);//检查数组元素输入if (arr1[j] < 0 || arr1[j] > 30000) {printf("arr1[%d]的值超出范围!\n", j);return 1;}}//开始遍历数组,进行合并int i = 0;int j = 0;while (i < n && j < m){if (arr1[i] < arr2[j]){printf("%d ", arr1[i]);i++;}else{printf("%d ", arr2[j]);j++;}}//数组arr1若有剩余元素while (i < n){printf("%d ", arr1[i]);i++;}//数组arr2若有剩余元素while (j < m){printf("%d ", arr2[j]);j++;}return 0;
}

--上面代码是判断小的先打印,当然也有先打印大的,只不过在后程进行逆序打印整体效率低(自己体会吧):

int main()
{int n = 0;int m = 0;scanf("%d%d", &n, &m);int arr1[100] = { 0 };int arr2[100] = { 0 };int arr3[200] = { 0 };//数组arr1输入升序数组for (int i = 0; i < n; i++){scanf("%d", &arr1[i]);}//数组arr2输入升序数组for (int j = 0; j < m; j++){scanf("%d", &arr2[j]);}int i = n - 1;int j = m - 1;int k = n + m -1;while (i >= 0 && j >=0){if (arr2[j] >= arr1[i]){arr3[k] = arr2[j];j--;k--;}else{arr3[k] = arr1[i];i--;k--;}}// 处理剩余元素while (i >= 0) {arr3[k--] = arr1[i--];}while (j >= 0) {arr3[k--] = arr2[j--];}//打印arr3for (k = 0; k < n+m; k++){printf("%d ", arr3[k]);}return 0;
}

--补充:return 1; 的作用

(对于上面的return语句,小子在这里有点补充要加)

--先说明:当代码执行到 return 1; 时,程序会立即终止,并返回状态码 1 给操作系统(表示异常退出)。

--这是可能会想,1不是表示为真嘛!怎么会异常退出!

        --哎,你的问题非常好!这里确实存在一个容易混淆的概念:

--在逻辑判断中(如 if 条件)

  • 1 表示 逻辑真(true);

  • 0 表示 逻辑假(false);

--在 return 语句中(程序退出状态):

  • return 0; 表示 程序成功执行约定俗成);

  • return 1;(或其他非零值)表示 程序异常终止(错误码);

--所以输入合法性检查可以使用 return 1; :

        --当用户输入不符合要求时(如超出范围、格式错误),终止程序并提示


结语:本篇内容收录在《C语言刷题集》中,本篇分享的是分支循环语句与数组综合运用的练习,难度稍有,一定程度上能够有效提升编程能力,喜欢的朋友们,三连后一起来学习吧!!!

http://www.xdnf.cn/news/1195831.html

相关文章:

  • PostgreSQL并发控制
  • 机器学习鸢尾花案例
  • KingbaseES聚焦产品上线
  • docker与k8s的容器数据卷
  • 自由学习记录(74)
  • 多租户Kubernetes集群架构设计实践——隔离、安全与弹性扩缩容
  • MYSQL--再谈间隙锁和临键锁
  • RabbitMq 常用命令和REST API
  • 商品中心—1.B端建品和C端缓存
  • Python-初学openCV——图像预处理(四)——滤波器
  • 命令行和neovim的git操作软件-lazygit
  • sealos 方式安装k8s5节点集群
  • 自动标注软件X-AnyLabeling的使用教程
  • 基于动态增强的 LLM 置信度方法研究
  • C语言中:形参与实参的那些事
  • [SAP ABAP] ALV报表练习4
  • Matlab自学笔记六十五:解方程的数值解法(代码速成)
  • 文件IO——bmp图像处理
  • 磁悬浮轴承转子不平衡质量控制策略设计:原理、分析与智能实现
  • 基于java的在线教育平台管理系统、在线学习系统的设计与实现
  • 零基础学习性能测试第三章:jmeter性能组件应用(事件,并发,定时器)
  • 哈尔滨←→南昌的铁路要道
  • AWD的攻击和防御手段
  • idea中无法删除模块,只能remove?
  • 2025年7月26日训练日志
  • 最优估计准则与方法(4)最小二乘估计(LS)_学习笔记
  • 幸福网咖订座点餐小程序的设计与实现
  • element-plus安装以及使用
  • 《基于雅可比矢量近似的EIT触觉传感灵敏度非均匀校正》论文解读
  • 微分方程入门之入门之入门,纯笔记