日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

利用循环队列的思想进行加密解密(洛谷P1914题题解,Java语言描述)

發布時間:2025/3/15 java 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 利用循环队列的思想进行加密解密(洛谷P1914题题解,Java语言描述) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

在我看來,理解循環隊列對我們思考問題的幫助就是:
合理利用“%”的約束,將問題的“越界”重新彈回問題范圍內。

本文就是一個例子,循環隊列的思想為我快速秒殺本題提供了思路。

題目要求

P1914題目鏈接

分析

我們想要實現’z’后是’a’,就相當于讓右越界的數值返回左邊界內。
這就好比一個常見的特效:一條線從屏幕右側穿出,又從左側穿入。

這種思想在我看來和循環隊列是很像的。
循環隊列在一側“填滿”而“假溢出”之后,會在另一側填裝新的元素。

當然了,隊列會有滿的問題,但這種思想是很好的。

就好比說“彈球游戲”實現問題約束的方式是用模擬動量守恒的方式進行完全彈性碰撞后的反彈,強制不越界;而這里的解決方式是容許一側越界后從另一側回來。

這種思想實現,就是依靠“%”運算符實現的。

但是,這個問題里棘手的一點是:'a’并不是char=0的情況,所以我們應該先讓當前char-‘a’,然后+偏移量,最后%26(因為有26個英文字母,這是界內范圍),再+‘a’,就能得到我們所求的。

這就是本題所謂的加密解密咯。

AC代碼(Java語言描述)

import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int num = Integer.parseInt(scanner.nextLine());char[] password_array = scanner.nextLine().toCharArray();for (int i = 0; i < password_array.length; i++) {password_array[i] = (char)((password_array[i] - 'a' + num) % 26 + 'a');}System.out.println(new String(password_array));scanner.close();} }

總結

以上是生活随笔為你收集整理的利用循环队列的思想进行加密解密(洛谷P1914题题解,Java语言描述)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。