Java程序练习-单链表三类字符归类

本文介绍如何从单链表中提取不同类型的字符数据(字母、数字、其他字符),并使用循环链表表示这些数据。通过程序实现,最终输出各分类字符的线性排列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述
单链表中含有三类字符数据元素(字母、数字、和其他字符,在main()里从键盘输入表长,然后建立该表),试编写算法构造三个以循环链表表示滴线性表,使每个表只含一类字符,且利用原表节点空间作为这三个表的空间,头节点可另辟空间。(最后输出各个表的元素,顺序为数字、字母、其他字符)
样例输入
8
5 d = & 0 D 9 +
样例输出
5 0 9
d D
= & +
参考代码
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class Main { public static void main(String[] args) throws IOException { BufferedReader cin = new BufferedReader(new InputStreamReader(System.in)); cin.readLine(); String sn[] = cin.readLine().split(" "); List<Character> list1 = new ArrayList<Character>(); List<Character> list2 = new ArrayList<Character>(); List<Character> list3 = new ArrayList<Character>(); for(int i = 0;i < sn.length;++ i){ char ch = sn[i].charAt(0); if(Character.isDigit(ch)){ list1.add(ch); }else if(Character.isLetter(ch)){ list2.add(ch); }else{ list3.add(ch); } } Iterator<Character> it = list1.iterator(); while(it.hasNext()){ System.out.print(it.next()+" "); } System.out.println(); it = list2.iterator(); while(it.hasNext()){ System.out.print(it.next()+" "); } System.out.println(); it = list3.iterator(); while(it.hasNext()){ System.out.print(it.next()+" "); } System.out.println(); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值