测试三种控制台读取方法的速度快慢

本文通过实验对比了Java中不同输入输出流的效率,包括Scanner、BufferedReader和带BufferedInputStream的Scanner。结果显示,在处理较小数据量时,BufferedReader和带缓冲的InputStream提供了更快的读取速度。

由以下的测试可以看出,使用BufferedReader和BufferedInputStream速度接近,可能是因为数据量比较小,但是它们的速度均比Scanner要快很多。

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Scanner;

public class FindFastest {
	public static void main(String[] args) {
		FindFastest ff = new FindFastest();
		// 测试数据
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		ff.testScanner();
		// 测试结果如下:
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用Scanner读取耗时:252微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用Scanner读取耗时:230微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用Scanner读取耗时:271微秒

		// ff.testScannerWithBufferedInputStream();
		// 测试结果如下:
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用带BufferedInputStream的Scanner读取耗时:75微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用带BufferedInputStream的Scanner读取耗时:7微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用带BufferedInputStream的Scanner读取耗时:5微秒

		// ff.testBufferedReader();
		// 测试结果如下:
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用BufferedReader读取耗时:95微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用BufferedReader读取耗时:3微秒
		// 苹果公司计划于9月9日召开新闻发布会,届时苹果将发布新一代iPhone。而苹果iPhone发布会一般于9月初至9月中旬召开,这次传闻的召开时间与近几年基本吻合。
		// 使用BufferedReader读取耗时:3微秒
	}

	public void testScanner() {
		Scanner in = new Scanner(System.in);
		while (in.hasNext()) {
			long start = System.nanoTime();
			in.next();
			// 返回用第二个参数指定基数表示的第一个参数的字符串表示形式。
			// System.out.println(Integer.toString(in.nextInt(), 10));
			long end = System.nanoTime();
			System.out.println("使用Scanner读取耗时:" + (end - start) / 1000 + "微秒");
		}
	}

	public void testScannerWithBufferedInputStream() {
		Scanner in = new Scanner(new BufferedInputStream(System.in));
		while (in.hasNext()) {
			in.next();
			long start = System.nanoTime();
			System.out.println("使用带BufferedInputStream的Scanner读取耗时:" + (System.nanoTime() - start) / 1000 + "微秒");
		}
	}

	public void testBufferedReader() {
		BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
		try {
			String str = null;
			while ((str = buf.readLine()) != null) {
				if (!"".equals(str)) {
					long start = System.nanoTime();
					System.out.println("使用BufferedReader读取耗时:" + (System.nanoTime() - start) / 1000 + "微秒");

				}
			}
		} catch (IOException e1) {
			// TODO Auto-generated catch block
			e1.printStackTrace();
		}
	}

	/**
	 * 
	 * @param num
	 * @param base
	 * @return 该函数是将十进制数字转化成指定的任意进制的数
	 */
	public static String baseString(int num, int base) {
		String str = "", digit = "0123456789abcdef";
		if (num == 0) {
			return "";
		} else {
			str = baseString(num / base, base);
			return str + digit.charAt(num % base);
		}
	}
}



根据你给我的代码修改我要的是控制台输入1 2 3 4 5 2 #include <iostream> using namespace std; struct ListNode { int val; ListNode *next; ListNode(int x) : val(x), next(nullptr) {} }; class Solution { public: ListNode* rotateRight(ListNode* head, int k) { // 处理空链表或单节点链表 if (head == nullptr || head->next == nullptr) return head; // 计算链表长度 int length = 0; ListNode* p = head; while (p != nullptr) { length++; p = p->next; } // 计算有效旋转次数 k = k % length; if (k == 0) return head; // 快指针先走k步 ListNode* fast = head; for (int i = 0; i < k; ++i) { fast = fast->next; } // 同步移动快慢指针找到断开点 ListNode* slow = head; while (fast->next != nullptr) { slow = slow->next; fast = fast->next; } // 重组链表 ListNode* newHead = slow->next; slow->next = nullptr; fast->next = head; return newHead; } }; // 辅助函数:打印链表 void printList(ListNode* head) { while (head != nullptr) { cout << head->val << " "; head = head->next; } cout << endl; } // 测试用例 int main() { // 示例1 ListNode* head1 = new ListNode(1); head1->next = new ListNode(2); head1->next->next = new ListNode(3); head1->next->next->next = new ListNode(4); head1->next->next->next->next = new ListNode(5); Solution().rotateRight(head1, 2); printList(head1); // 实际测试需先执行旋转后打印新头节点,此处仅为示意 // 示例2 ListNode* head2 = new ListNode(0); head2->next = new ListNode(1); head2->next->next = new ListNode(2); ListNode* result2 = Solution().rotateRight(head2, 4); printList(result2); // 输出应为 2 0 1 return 0; }
最新发布
04-01
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值