蓝桥杯:整数删除

2024-09-06 06:20
文章标签 删除 蓝桥 整数

本文主要是介绍蓝桥杯:整数删除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

// 蓝桥杯整数删除.cpp : Defines the entry point for the console application.
//#include "stdafx.h"
#include<stdio.h>
#define MAX 100
void findmin(int a[],int n,int& pos)
{int min=a[0];pos=0;//pos=0我开始忘了,特别注意边界for(int i=1;i<n;i++){if(min>a[i])//找到3,2,1,7,1,找到第一个1{min=a[i];pos=i;}}}int main(int argc, char* argv[])
{int a[5]={1,4,2,8,7};//	int a[5]={5,2,8,7,9};//	int a[5]={8,2,5,7,9};int m=3;int pos=0;//初始化int afterpos;for(int k=1;k<4;k++){findmin(a,5,pos);//从数组0号单元,找最小值//	printf("%d\n",pos);if(pos==0){for(int k=1;k<5;k++){if(a[k]==MAX);else{break;//第k个数不是MAX}}a[k]=a[pos]+a[k];a[pos]=MAX;//	thefirst(a,5,pos);}else{int tail,head;//找出a[pos]之前第一个不是MAX的值for(tail=pos-1;tail>=0;tail--){if(a[tail]==MAX);elsebreak;}int pretemp;if(tail>=0){pretemp=a[tail];}elsepretemp=MAX;//找出a[pos]之后第一个不是MAX的值for(head=pos+1;head<5;head++){if(a[head]==MAX);elsebreak;}int temp;if(head==5){temp=MAX;}elsetemp=a[head];//比较最小值,前面与后面的相邻值,找到相邻值中较小的那个if(pretemp!=MAX){a[tail]=a[tail]+a[pos];}if(temp!=MAX){a[head]=a[head]+a[pos];}a[pos]=MAX;}for(int g=0;g<5;g++)//test{printf("%d    ",a[g]);}printf("\n");}//for(k)return 0;
}

不好好审题!!!!!导致一直在错

给定一个长度为 N 的整数数列:A1, A2, ... , AN。你要重复以下操作 K 次:
每次选择数列中最小的整数(如果最小值不止一个,选择最靠前的),将其删除。
并把与它相邻的整数加上被删除的数值。(这个条件我一开始审题不清)
输出 K 次操作后的序列。

 

 

删除我采用特殊值覆盖

关于输入,我直接给定了

知识点总结:

(1)记录最小值及位置,这里是数组;;;在我的csdn博客上链式存储的简单选择排序,也可记录最小值节点的指针

(2)学会分析不同的情况:pos=0时

pos!=0时,找它前面不被覆盖的最近的相邻值--------找它后面不被覆盖的最近的相邻值

	//比较最小值,前面与后面的相邻值,找到相邻值中较小的那个if(pretemp!=MAX){a[tail]=a[tail]+a[pos];}if(temp!=MAX){a[head]=a[head]+a[pos];}a[pos]=MAX;

 (3)删除我采用特殊值覆盖a[pos]=MAX

(4)没看清题意,就去做题

(5)写循环程序,先写最内层的循环因为它是最基本的功能

 

这篇关于蓝桥杯:整数删除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1141242

相关文章

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

MySQL中删除重复数据SQL的三种写法

《MySQL中删除重复数据SQL的三种写法》:本文主要介绍MySQL中删除重复数据SQL的三种写法,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录方法一:使用 left join + 子查询删除重复数据(推荐)方法二:创建临时表(需分多步执行,逻辑清晰,但会

Python按条件批量删除TXT文件行工具

《Python按条件批量删除TXT文件行工具》这篇文章主要为大家详细介绍了Python如何实现按条件批量删除TXT文件中行的工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.简介2.运行效果3.相关源码1.简介一个由python编写android的可根据TXT文件按条件批

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

如何恢复回收站中已删除/清空的文件

回收站清空后如何恢复已删除的文件?是否可以恢复永久删除的文件?或者最糟糕的是,如果文件直接被删除怎么办?本文将向您展示清空回收站后恢复已删除数据的最佳方法。 回收站清空后如何恢复已删除的文件? “回收站清空后我还能恢复已删除的文件吗?” 答案是肯定的,但是在这种情况下您将需要一个  回收站恢复工具 来从回收站中检索文件: 错误/永久删除回收站或任何数字存储设备中的文件 直接删除的文件/