1133. Splitting A Linked List (25)

1133. Splitting A Linked List (25)

时间限制
400 ms
内存限制
65536 kB
代码长度限制
16000 B
判题程序
Standard
作者
CHEN, Yue

Given a singly linked list, you are supposed to rearrange its elements so that all the negative values appear before all of the non-negatives, and all the values in [0, K] appear before all those greater than K. The order of the elements inside each class must not be changed. For example, given the list being 18→7→-4→0→5→-6→10→11→-2 and K being 10, you must output -4→-6→-2→7→0→5→10→18→11.

Input Specification:

Each input file contains one test case. For each case, the first line contains the address of the first node, a positive N (<= 105) which is the total number of nodes, and a positive K (<=1000). The address of a node is a 5-digit nonnegative integer, and NULL is represented by -1.

Then N lines follow, each describes a node in the format:

Address Data Next

where Address is the position of the node, Data is an integer in [-105, 105], and Next is the position of the next node. It is guaranteed that the list is not empty.

Output Specification:

For each case, output in order (from beginning to the end of the list) the resulting linked list. Each node occupies a line, and is printed in the same format as in the input.

Sample Input:
00100 9 10
23333 10 27777
00000 0 99999
00100 18 12309
68237 -6 23333
33218 -4 00000
48652 -2 -1
99999 5 68237
27777 11 48652
12309 7 33218
Sample Output:
33218 -4 68237
68237 -6 48652
48652 -2 12309
12309 7 00000
00000 0 99999
99999 5 23333
23333 10 00100
00100 18 27777
27777 11 -1
大意:给一条单向链表,按链表顺序先输出data<0的节点,再输出data小于等于k的节点,最后输出大于k的节点

思路:读入链表后遍历一次,将<0 <=k  >k  分别存放,最后依次输出

注意:1.输入可能有无效节点,所以一定要遍历一次过滤

           2.next是根据重新排列以后的顺序来定的

           3.用数组模拟链表会比较方便

           4.输出要固定5个数字,所以用printf会比较方便

           5.最后一个-1 要和第4条区别开

           6.考虑极端情况,例如没有<0 的时候  或者只有 <0 的时候

代码:

#include <iostream>
#include <stdlib.h>
#include <iomanip> 
#include <string.h>
using namespace std;
int nxt[100000];
int list[100000];
int minlist[100000]; int j = 0;
int midlist[100000]; int p = 0;
int maxlist[100000]; int q = 0;
int main()
{
	int add, k, num;
	cin >> add >> num >> k;
	int a, b, c;
	memset(nxt, -1, sizeof(int) * 100000);
	memset(list, -1, sizeof(int) * 100000);
	for (int i = 0; i < num; i++)
	{
		cin >> a >> b >> c;
		list[a] = b;
		nxt[a] = c;
	}
	a = add; 
	while (a!=-1)
	{
		if (list[a] < 0) minlist[j++] = a;
		else if (list[a] >= 0 && list[a] <= k) midlist[p++] = a;
		else maxlist[q++] = a;
		a = nxt[a];
	}
	int judge = 0;
	for (int i = 0; i < j; i++) {
		if (judge) cout << setw(5) << setfill('0') << minlist[i] << endl;
		cout << setw(5) << setfill('0') << minlist[i] << " " << list[minlist[i]] << " ";
		judge = 1;
	}
	for (int i = 0; i < p; i++) {
		if (judge) cout << setw(5) << setfill('0') << midlist[i] << endl;
		cout << setw(5) << setfill('0') << midlist[i] << " " << list[midlist[i]] << " ";
		judge = 1;
	}
	for (int i = 0; i < q; i++) {
		if (judge) cout << setw(5) << setfill('0') << maxlist[i] << endl;
		cout << setw(5) << setfill('0') << maxlist[i] << " " << list[maxlist[i]] << " ";
		judge = 1;
	}
	cout << -1 << endl;
}

上面的代码有很多可以优化的地方,比如用print可以看起来精简很多,最后三个的输出可以用一个for来写,开头申请三个list太占空间用vector可以完美解决

感言:这题似乎是第二次做,然后还是折腾了半天,各种莫名奇妙的bug,还有各种考虑不周到。不过开心的是,这次的写的代码比上次好看多了 o(* ̄▽ ̄*)ブ

测试点:第一个测试点是样例

              第二个测试点(估计)是复杂情况的样例,三种情况都输出

              第三个测试点第四个测试点没有<0 的数据

              第五个测试点(估计)有无效节点,需要过滤





<think>好的,我现在需要解决用户提到的关于“-enable-amf”选项未被识别的错误。这个错误通常出现在使用命令行工具或编码软件时,比如FFmpeg或者其他多媒体处理工具。首先,我要确定这个选项的具体用途和常见的应用场景。 首先,AMF(Advanced Media Framework)是AMD开发的一个多媒体框架,用于加速视频编解码。在FFmpeg中,启用AMF支持可以让用户利用AMD的GPU进行硬件加速编码。因此,用户可能在尝试使用FFmpeg进行视频编码时添加了“-enable-amf”选项,但系统提示无法识别该选项。 接下来,我需要分析可能导致这个错误的原因。根据之前的类似问题,比如用户提到的交叉编译错误和gcc的“-wall”选项问题,常见的原因包括工具版本不兼容、配置错误或者编译时未启用相关支持。对于FFmpeg来说,如果在编译时没有启用AMF支持,那么运行时使用该选项就会报错。 可能的解决步骤包括: 1. 确认FFmpeg版本是否支持AMF。较旧的版本可能没有集成该功能,需要升级到支持AMF的版本。 2. 检查编译FFmpeg时是否启用了AMF。用户可能需要重新编译FFmpeg,并在配置时添加“--enable-amf”选项,同时确保安装了必要的依赖库,如AMF SDK。 3. 验证运行时命令是否正确。用户可能在命令行中错误地使用了该选项,比如拼写错误或者位置不当。 4. 确认系统环境是否支持AMF,例如是否正确安装了AMD的驱动和运行时库。 另外,用户可能混淆了不同的工具或软件,比如将FFmpeg的编译选项和运行时选项搞混了。需要明确“-enable-amf”是编译时的配置选项,而运行时可能需要使用不同的参数来调用AMF编码器,比如“-c:v h264_amf”。 还需要考虑用户的操作系统和硬件环境。如果用户使用的是非AMD的GPU,或者操作系统不支持AMF,那么即使正确编译了FFmpeg,也无法使用该功能。此外,权限问题或者路径配置错误也可能导致相关库无法加载,从而出现选项未被识别的错误。 总结下来,需要引导用户检查FFmpeg的版本、编译配置、运行时命令以及系统环境,逐步排除可能的问题点。同时,提供具体的步骤和示例命令,帮助用户正确启用AMF支持。</think>### 关于“Unrecognized option '-enable-amf'”错误的解决方案 #### 1. 确认工具版本与AMF兼容性 该错误通常出现在使用FFmpeg等多媒体工具时,尝试启用AMF(Advanced Media Framework)硬件加速编码但未正确配置。需检查以下内容: - **FFmpeg版本要求**:AMF支持需FFmpeg 4.1及以上版本,且需在编译时显式启用AMF[^1] - **硬件与驱动要求**:需AMD显卡(如Radeon系列)并安装最新版驱动及AMF SDK #### 2. 重新编译FFmpeg并启用AMF 若工具版本过旧或编译时未包含AMF支持,需按以下步骤重新编译: ```bash # 下载AMF SDK(需注册AMD开发者账号) git clone https://github.com/GPUOpen-LibrariesAndSDKs/AMF.git export AMF_PATH=/path/to/AMF # 编译FFmpeg ./configure \ --enable-amf \ --enable-encoder=h264_amf \ --enable-encoder=hevc_amf \ --extra-cflags="-I$AMF_PATH/amf/public/include" \ --extra-ldflags="-L$AMF_PATH/amf/public/lib64" make -j$(nproc) sudo make install ``` #### 3. 验证运行时命令 编译成功后,运行时需使用正确的编码器参数(**注意区分编译选项与运行时选项**): ```bash # 错误示例(-enable-amf是编译选项) ffmpeg -i input.mp4 -enable-amf output.mp4 # 正确示例(指定AMF编码器) ffmpeg -i input.mp4 -c:v h264_amf output.mp4 ``` #### 4. 常见问题排查 | 现象 | 解决方案 | |-------|----------| | 报错`AMF not found` | 检查AMF SDK路径是否正确,确保`libamf.so`在库路径中 | | 提示`Driver not supported` | 更新AMD显卡驱动至22.3.1或更高版本 | | 编码效率未提升 | 使用`-quality quality`参数调整编码质量预设值 | #### 5. 替代方案 若无法满足AMF要求,可考虑其他硬件加速方案: ```bash # 使用NVIDIA NVENC ffmpeg -i input.mp4 -c:v h264_nvenc output.mp4 # 使用Intel QuickSync ffmpeg -i input.mp4 -c:v h264_qsv output.mp4 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值