pat1097链表去重 | pat1133链表元素分类 【完结】

news2024/9/25 1:20:36

pat1097链表去重

与之前不同的是,需要把删掉的元素也拍成一个链表

分类讨论你就好好的分

如果重复了——pre不动,pre的next指向cur的next,然后在已删除中加上一个节点,状态移至下个节点(最后完了记得加上-1)

如果没重复——附1,pre=cur,cur=next

#include<stdio.h>
#include<bits/stdc++.h>
#include <string>
#include <cmath>
#include <algorithm>
const int N=100005;
int n,first,firstid;
using namespace std;
int head,k;

int lnxt[N];
int val[N];

void readout()
{	int temp=head;
while(temp!=-1)
{printf("%d %d %d\n",temp,val[temp],lnxt[temp] );temp=lnxt[temp] ;
}
}



int main()
{
    scanf("%d %d",&head,&n);
    	for(int i=0;i<n;i++)
	{
	int idtemp;
	int valt,lnxtt;
	scanf("%d %d %d",&idtemp,&valt,&lnxtt);
	val[idtemp]=valt;lnxt[idtemp]=lnxtt;
}
int cur=head,pre=-1;
bool h[N]={0};
int dm=N-1;int c=dm;
while(cur!=-1)
{
if(h[abs(val[cur])])
{
	lnxt[pre]=lnxt[cur];//删除
	lnxt[c]=cur;
	c=cur;
//	pre=cur;
cur=lnxt[cur];

}
else{
		h[abs(val[cur])]=1;

	pre=cur;
	cur=lnxt[cur];
}

}
lnxt[c]=-1;
int tp1=head,tp2=lnxt[dm];
//printf("%d %d\n",tp2,dm);
while(tp1!=-1)
printf(lnxt[tp1]>=0?"%05d %d %05d\n":"%05d %d %d\n",tp1,val[tp1],lnxt[tp1]),tp1=lnxt[tp1];

while(tp2!=-1 )
printf(lnxt[tp2]>=0?"%05d %d %05d\n":"%05d %d %d\n",tp2,val[tp2],lnxt[tp2]),tp2=lnxt[tp2];
}

pat1133链表元素分类

 评级:简单????????

这里我想,在原链表上搞有点麻烦?想试试开个新链表

确实可以,下一个节点坐标我们新开个lnxt2数组单独记录

三个条件,遍历三次

#include<stdio.h>
#include<bits/stdc++.h>
#include <string>
#include <cmath>
#include <algorithm>
const int N=100005;
int n,first,firstid;
using namespace std;
int head,k;

int lnxt[N];
int val[N];

void readout()
{	int temp=head;
while(temp!=-1)
{printf("%d %d %d\n",temp,val[temp],lnxt[temp] );temp=lnxt[temp] ;
}
}



int main()
{
    scanf("%d %d %d",&head,&n,&k);
    
    	for(int i=0;i<n;i++)
	{
	int idtemp;
	int valt,lnxtt;
	scanf("%d %d %d",&idtemp,&valt,&lnxtt);
	val[idtemp]=valt;lnxt[idtemp]=lnxtt;
}
int cur=head,pre=-1;
bool h[N]={0};
int dm=N-1;int c=dm;
int lnxt2[N];
while(cur!=-1)
{
if(val[cur]<0)
{lnxt2[c]=cur;c=cur;lnxt2[c]=-1;
}
cur=lnxt[cur];
}
cur=head;
while(cur!=-1)
{
if(val[cur]>=0 && val[cur]<=k)
{lnxt2[c]=cur;c=cur;lnxt2[c]=-1;
}
cur=lnxt[cur];
}
cur=head;
while(cur!=-1)
{
if(val[cur]>k)
{lnxt2[c]=cur;c=cur;lnxt2[c]=-1;
}
cur=lnxt[cur];
}

int tp2=lnxt2[dm];
//printf("%d %d\n",tp2,dm);

while(tp2!=-1 )
printf(lnxt2[tp2]>=0?"%05d %d %05d\n":"%05d %d %d\n",tp2,val[tp2],lnxt2[tp2]),tp2=lnxt2[tp2];

}


链表就先告一段落啦~

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

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

相关文章

C语言05--指针初识

内存地址 字节&#xff1a;字节是内存的容量单位&#xff0c;英文称为 byte&#xff0c;一个字节有8位&#xff0c;即 1byte 8bits地址&#xff1a;系统为了便于区分每一个字节而对它们逐一进行的编号&#xff0c;称为内存地址&#xff0c;简称地址。注:地址是按字节编号的&a…

多模态YOLOv8 融合可见光+红外光(RGB+IR)双输入【附代码】

文章目录 前言视频效果代码获取文章概述必要环境一、模型训练1、 定义数据1.1、数据集结构1.2、定义data.yaml 2、 运行方法运行效果 二、模型验证运行方法运行效果 三、模型推理1. 参数定义2. 运行方法运行效果 四、效果展示白天夜间 总结 前言 最近看不少朋友提到双模态YOLO…

基于SpringBoot的健康饮食管理系统---附源码98382

目 录 1 绪论 1.1 研究背景与意义 1.2国内外研究现状 1.3论文结构与章节安排 2 系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统用例分析 2.4 系统流程…

什么是营销自动化?营销自动化的优势?

在SaaS行业和软件行业中&#xff0c;营销自动化作为一种先进的营销手段&#xff0c;正逐渐受到企业的青睐。营销自动化基于大数据和人工智能技术&#xff0c;能够自动执行、管理和完成营销任务和流程&#xff0c;为企业带来诸多优势。 营销自动化是一种能够一体化执行、管理、…

SecretPixel:一款整合了多种技术的高级图像隐写工具

关于SecretPixel SecretPixel是一款先进的隐写术工具&#xff0c;旨在安全地隐藏图像中的敏感信息。它结合了先进的加密、压缩和种子最低有效位 (LSB) 技术&#xff0c;为隐藏数据提供了一种不可检测的强大解决方案&#xff0c;在数字隐写术领域脱颖而出。 功能介绍 1、高级加…

2024 Python3.10 系统入门+进阶(七):字符串及其常用操作详解上篇

目录 一、初始化二、索引三、常用操作3.1 拼接字符串3.1.1 ""号3.1.2 join()方法 3.2 检索字符串3.2.1 find() 方法——字符串首次出现的索引位置(rfind()、index()、rindex())3.2.2 count() 方法——统计字符串出现次数3.2.3 len() 函数——计算字符串长度或元素个数…

RabbitMQ的高可用

1.Rabbit集群 采用集群模式保护消息的完整。 1.1普通集群 在普通集群模式下&#xff0c;各个节点之间有相同的元数据&#xff0c;即队列结构&#xff0c;而消息不会冗余&#xff08;不同节点的消息不同&#xff09;。 消费时&#xff0c;如果消费的不是存有数据的节点&…

如何用Python进行民宿数据分析:一步步教你实现可视化

&#x1f34a;作者&#xff1a;计算机毕设匠心工作室 &#x1f34a;简介&#xff1a;毕业后就一直专业从事计算机软件程序开发&#xff0c;至今也有8年工作经验。擅长Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等。 擅长&#xff1a;按照需求定制化开发项目…

基于swifter多内核的加速Pandas DataFrame操作运行

swifter是提高pandas性能的第三方包,主要是apply函数。 接口支持范围: 运行环境和安装 操作系统是Win10 64,pandas版本是2.2.2,swifter版本是1.4.0。 pip安装 $ pip install -U pandas # upgrade pandas $ pip install swifter # first time installation $ pip inst…

Android 架构模式之 MVVM

Android 架构 Android 架构模式之 MVCAndroid 架构模式之 MVPAndroid 架构模式之 MVVM 目录 Android 架构架构设计的目的对 MVVM 的理解代码ModelViewViewModel Android 中 MVVM 的问题试吃个小李子BeanModelViewViewModel效果展示 大家好&#xff01; 作为 Android 程序猿&a…

大数据ETL工具(Sqoop, DataX, Kettle)对比

文章目录 1. ETL简介2. Sqoop2.1 Sqoop简介2.2 Sqoop主要特点 3. DataX3.1 DataX简介3.2 DataX框架设计3.3 DataX的主要特点 4. Kettle4.1 Kettle简介4.2 Kettle的主要特点 5. 工具对比5.1 DataX 与 Sqoop对比5.2 DataX 与 Kettle 6. 总结 1. ETL简介 ETL&#xff08;Extract-…

Mamba来搞图像增强了!高创新,发小论文不愁!

用Mamba做图像增强是个创新性比较高的方向&#xff0c;因为Mamba拥有非常独特的架构设计&#xff0c;能够同时捕获全局和局部的信息&#xff0c;轻松助力模型理解图像的整体结构和上下文&#xff0c;帮助我们确保图像细节的准确恢复和增强。 这种优势让它在保持高效计算的同时…

MySQL主从复制重新初始化单表或者单库的方法

作者介绍&#xff1a;老苏&#xff0c;10余年DBA工作运维经验&#xff0c;擅长Oracle、MySQL、PG、Mongodb数据库运维&#xff08;如安装迁移&#xff0c;性能优化、故障应急处理等&#xff09; 公众号&#xff1a;老苏畅谈运维 欢迎关注本人公众号&#xff0c;更多精彩与您分享…

【C++ Primer Plus习题】3.7

问题: 解答: #include <iostream> using namespace std;const float GALLO_TO_LITRE 3.785; const float KM_TO_MILE 62.14;int main() {float litre 0;float gallo 0;float mile 0;cout << "请输入汽车油耗(每100km消耗的汽油量单位为升):";cin &…

C#下在派生类中引发基类事件的方法与示例

文章目录 基类事件在派生类中的定义及触发方式基类事件的传播机制示例总结 在面向对象编程中&#xff0c;继承是代码复用的一种重要方式。C#作为一种面向对象的编程语言&#xff0c;允许派生类继承基类的属性和方法。基类定义了一系列共有的属性和行为&#xff0c;而派生类则可…

【UE】尝试一种老派的平面假反射做法,与进一步改进效果的思路

在实践中&#xff0c;常常需要为类似荧幕&#xff0c;LED广告牌等平面制作反射。 但会遇到各种问题&#xff0c;例如在使用屏幕空间反射时&#xff0c;平面必须在画面内 平面反射捕获与光线追踪又代价高昂 因此&#xff0c;在一些情况下依然会使用一种历史悠久的反射手法 这种…

树(二叉树)

树 1.1 特性 1.1.1 什么是树 树(Tree)是(n>0)个节点的有限集合T&#xff0c;它满足两个条件&#xff1a; (1) 有且仅有一个特定的称为根&#xff08;Root&#xff09;的节点。 其余的节点可以分为m&#xff08;m≥0&#xff09;个互不相交的有限集合T1、T2、……、Tm&#x…

【Docker】Linux系统以及威联通QNAP部署思源笔记的通用教程

本文首发于 ❄️慕雪的寒舍 本文测试的是旧版本v2.11.4的部署方式&#xff0c;实测当前&#xff08;2024.08.15&#xff09;最新的v3.1.3版本也可以用相同的方式部署。本文的部署方式共写了三种&#xff0c;非qnap的linux系统也可以参考本文部署思源笔记。 阅读本文之前&#…

SpringBoot 集成积木报表

SpringBoot 集成积 前言 积木报表是jeecg的一款开源但代码不开源的一款自定义报表&#xff0c;可以基于网页灵活 调整报表的布局、样式等内容&#xff0c;无需编程&#xff0c;专为企业数据分析、报表制作而设计&#xff1b; 降低管理人员汇总制作报表的门槛&#xff0c;解决…

在表格上,按照单元格数值显示单元格背景进度条

想要实现的效果如下&#xff1a; 单元格背景进度条的大小取决于当前单元格里的数值 TreeList和GridControl的设置方法都是相同的&#xff1a;都是通过给列设置FormatRule来实现的。 相关代码及设置如下&#xff1a; 1、给控件绑定数据源&#xff0c;我的数据源是一个DataTab…