已知文件 a.txt 文件中的内容为“bcdeadferwplkou”, * 请编写程序读取该文件内容,并按照自然顺序排序后输出到 b.txt 文件中。 * 即 b.txt 中的文件内容应为“ab...

import java.io.*;
class SortChar
{
private String str;
private char arrayList[];
private BufferedReader br; //字符流
private File f; //读取的文件

SortChar( String s )
{
f=new File( s );
}

public void start()
{

if( inputData()==-1 )
{
return;
}
//对字符数组进行冒泡排序
sortChar( );
//把排序后的数组变成字符串,并通过流将字符串写入b.txt文件中。
outputString();
}
//通过BufferedReader读取文本中的字符串
//读取文件失败返回-1,成功返回1
private int inputData()
{
try
{
br=new BufferedReader( new FileReader(f));
//读取文本的内容
while( (str=br.readLine())!=null )
{
//把所有字母转换为小写
str.toLowerCase();
arrayList=str.toCharArray();
}
}
catch( IOException e )
{
System.out.println( "读取文件出错!" );
e.printStackTrace();
return -1;
}
finally
{
//关闭输入流
if( br!=null )
{
try
{
br.close();
}
catch( IOException e )
{
e.printStackTrace();
}
}
}
return 1;
}
//对字符数组进行冒泡排序
private void sortChar( )
{
char temp=0;
for( int i=0; i<arrayList.length-1; i++ )
{
for( int j=0; j<arrayList.length-i-1; j++ )
{
if( arrayList[j]>arrayList[j+1] )
{
temp=arrayList[j];
arrayList[j]=arrayList[j+1];
arrayList[j+1]=temp;
}
}
}
}
/*
把排序后的数组变成字符串,并通过流将字符串写入b.txt文件中。
a.通过String类的构造函数将字符数组变成字符串。
b.通过FileWriter把字符串写入到b.txt文件中。
*/
private void outputString()
{
BufferedWriter bw=null;
try
{
FileWriter fw = new FileWriter("D:\\zy\\b.txt");
bw = new BufferedWriter(fw);

//把排序完成后的字符串重新写入到文件中
bw.write( new String( arrayList,0,arrayList.length ));
bw.flush();
}
catch( IOException e )
{
e.printStackTrace();
}
finally
{
//关闭输入流
if( bw!=null )
{
try
{
bw.close();
}
catch( IOException e )
{
e.printStackTrace();
}
}
}
}
}
class Demo
{
public static void main(String arsg[])
{
new SortChar( "D:\\zy\\a.txt" ).start();

}
}

转载于:https://www.cnblogs.com/gt33/p/9260677.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
西南交通大学;实验(大作业)题目:C语言文件操作;实验目的: (1) 掌握C语言字符文件读写方法; (2) 掌握C语言二进制文件读写方法。 实验要求: (1) 完成2个文件操作程序。 (2) 撰写实验报告:每个程序包括源程序代码;按要求描述关键算法或算法程图;提供程序测试结果(至少两种不同输入,可屏幕截图)与结论。 实验内容: 1. 在字符文件b.txt录入n个整数,录入整数的分隔符为空格、换行或TAB。若n=5,则b.txt的一种正确格式为 5 9 12 -15 30 -7 即b.txt的第一个数为n,后面是n个整数。 编写程序,从文件b.txt读出n值,建立长度为n的动态1维整型数组,然后继续从文件b.txt读入n个整数存于该数组,进行由小到大排序,最后将排序结果输出字符文件c.txt。 要求的输出格式是每个整数%6d,每输出5个整数换一行。 实验报告要求给出该程序的程图。 2. 1616点阵汉字的显示。从键盘输入一个汉字,从1616点阵汉字库文件HZK16.dat读取汉字点阵信息,打印汉字到控制台屏幕上(构成汉字的每个点用输出字母O表示)。 输入输出示例: 输入一个汉字: O O O O OOOOOOOOOOOOOO O O O O O O O O O O O O OOOOOOOOOOOOO O O O O O O O O O 提示1:16*16点阵字库文件HZK16.dat的存储格式。 以汉字“我”为例,16*16点阵构成的字形信息用二进制编码(1表示有点,0表示无点)形成32字节,每行2个字节,共16行,如下所示。这32个字节在文件的存储顺序为:每行从左向右,行从上到下。 16*16点阵字库文件HZK16.dat,每个汉字(32字节字形信息)按区位码由小到大的顺序存储。以汉字“啊”为例,它的区号为16,位号为1,故它的32字节字形信息在文件的起始字节偏移量offset=((区号-1)*94+位号-1)*32。 0000010010000000 0x04,0x80 0000111010100000 0x0E,0xA0 0111100010010000 0x78,0x90 0000100010010000 0x08,0x90 0000100010000100 0x08,0x84 1111111111111110 0xFF,0xFE 0000100010000000 0x08,0x80 0000100010010000 0x08,0x90 0000101010010000 0x0A,0x90 0000110001100000 0x0C,0x60 0001100001000000 0x18,0x40 0110100010100000 0x68,0xA0 0000100100100000 0x09,0x20 0000101000010100 0x0A,0x14 0010100000010100 0x28,0x14 0001000000001100 0x10,0x0C 提示2:GB2312-80汉字内码 GB2312-80共收录约6700多个汉字以及其它符号,用一个94行*94列的表格表示(最多可表示94*94个汉字和符号)。某个汉字所在的行号(从1开始)称为“区号”,列号(从1开始)称为“位号”,形成区位码。 如:汉字“啊”在16行,第1列,故它的区位码为(16,1)。 在存储器,为了与ASCII码区别,用内码表示一个汉字的编码,汉字的内码为一个2字节编码,第一字节=区号+160,第2字节=位号+160,故汉字“啊”的内码为(176,161)。 已知汉字内码,则在HZK16.dat该汉字32字节字形信息首字节的存储位置为 offset=((内码第一字节-161)*94+(内码第二节字-161))*32
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值