博客
关于我
[编程题]Linked List Sorting
阅读量:368 次
发布时间:2019-03-04

本文共 1705 字,大约阅读时间需要 5 分钟。

链表查找问题处理方案

问题背景

由于题目给定的输入范围较小,我们可以采用静态链表的方式来解决问题。为了确保链表处理的准确性,我们需要在节点结构体中增加一个标记位,用于记录当前节点是否为有效节点。

输入处理

读取输入后,我们需要注意其中可能包含不在链表中的节点。为了标记这些有效节点,我们需要对链表进行一次遍历,检查每个节点的有效性,并将其标记为有效节点。

节点排序规则

在对节点进行排序时,我们需要遵循以下规则:

  • 有效节点优先于无效节点排序。
  • 有效节点之间按照节点的数据值从小到大排序。
  • 节点标记逻辑

    通过对链表进行一次遍历,我们可以标记所有有效节点。具体实现步骤如下:

  • 初始化一个计数器cnt,用于记录有效节点的数量。
  • 从给定起始节点开始,遍历链表的每个节点。
  • 将遍历到的每个节点标记为有效节点,并增加计数器cnt
  • 排序逻辑

    使用自定义的比较函数对节点列表进行排序。比较函数的逻辑如下:

  • 如果两个节点的有效性不同,优先级高的节点排在前面。
  • 如果两个节点均为有效节点,则按数据值从小到大排序。
  • 代码实现

    #include 
    #include
    #include
    #include
    using namespace std;struct NODE { int ad = -1; int next = -1; int num; int flag = -1; // 标记是否为有效节点};bool cmp(const NODE& n1, const NODE& n2) { if (n1.flag != n2.flag) { return n1.flag > n2.flag; } else { return n1.num < n2.num; }}int main() { int ad, n; cin >> ad >> n; vector
    nodes(maxn); for (int i = 0; i < n; ++i) { int a1, a2; int num; cin >> a1 >> a2 >> num; nodes[a1].ad = a1; nodes[a1].num = num; nodes[a1].next = a2; } int p = ad; int cnt = 0; while (p != -1) { nodes[p].flag = 1; cnt++; p = nodes[p].next; } sort(nodes.begin(), nodes.end(), cmp); if (nodes[0].ad != -1) { printf("%d %05d\n", cnt, nodes[0].ad); } else { printf("%d %d\n", cnt, nodes[0].ad); } for (int i = 0; i < maxn; ++i) { if (i > 0) { cout << endl; } if (nodes[i].flag == 1) { cout << nodes[i].ad << " " << setw(5) << nodes[i].num; } }}

    输出格式说明

    • 有效节点数量以%d格式输出。
    • 有效节点的起始地址和数据值以%05d格式输出,以便于对齐。
    • 无效节点的起始地址和数据值直接以%d格式输出。

    通过以上实现,我们可以高效地解决链表查找问题,并确保输出格式符合要求。

    转载地址:http://ziyg.baihongyu.com/

    你可能感兴趣的文章
    Openlayers中使用Image的rotation实现车辆定位导航带转角(判断车辆图片旋转角度)
    查看>>
    Openlayers中加载Geoserver切割的EPSG:900913离线瓦片图层组
    查看>>
    Openlayers中多图层遮挡时调整图层上下顺序
    查看>>
    Openlayers中将某个feature置于最上层
    查看>>
    Openlayers中点击地图获取坐标并输出
    查看>>
    Openlayers中设置定时绘制和清理直线图层
    查看>>
    Openlayers图文版实战,vue项目从0到1做基础配置
    查看>>
    Openlayers实战:modifystart、modifyend互动示例
    查看>>
    Openlayers实战:判断共享单车是否在电子围栏内
    查看>>
    Openlayers实战:加载Bing地图
    查看>>
    Openlayers实战:绘制图形,导出geojson文件
    查看>>
    Openlayers实战:绘制图形,导出KML文件
    查看>>
    Openlayers实战:绘制多边形,导出CSV文件
    查看>>
    Openlayers实战:绘制带箭头的线
    查看>>
    Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>