GDPU 競賽技能實踐 天碼行空 期末小測

1. 除法(原題)

👨?🏫 實驗二:1.簡單枚舉
輸入正整數n,按從小到大的順序輸出所有形如abcde/fghij= n的表達式,其中a~j恰好為數字0~9的一個排列(可以有前導0),2≤n≤79。

樣例輸入:

62

樣例輸出:

79546 / 01283 = 62

💖 Main1.java

import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;//文件名:Main1.javapublic class Main1
{static int n;static Set<Integer> set = new HashSet<>();// 用于數字去重public static void main(String[] args){Scanner sc = new Scanner(System.in);n = sc.nextInt();for (int i = 1234; i < 100000; i++){if (repeat(i))continue;int y = cal(i);if (y != -1){System.out.print(y + "/");System.out.printf("%05d", i);System.out.println(" = " + n);}set.clear();}}/*** * @param x* @return 返回 x 對應的 x*n,非法值則返回 -1*/private static int cal(int x){int y = x * n;if (value(y))return y;return -1;}//返回 y 是否為有效值private static boolean value(int y){if (y < 10000 || y >= 100000)return false;Set<Integer> tmpSet = new HashSet<>();while (y != 0){int t = y % 10;if (tmpSet.contains(t) || set.contains(t))return false;tmpSet.add(t);y /= 10;}return true;}//返回 x 的每一位是否有重復的數字,有則返回 trueprivate static boolean repeat(int x){if ((x + "").length() == 4)x *= 10;while (x != 0){int t = x % 10;if (set.contains(t)){set.clear();return true;}set.add(t);x /= 10;}return false;}
}

在這里插入圖片描述

2. 求逆序對(原題)

👨?🏫 實驗七:4. 求逆序對

輸入一個序列{a1, a2, a3,…, an},交換任意兩個相鄰元素,不超過k次。交換之后,問最少的逆序對有多少個。

序列中的一個逆序對,是指存在兩個數ai和aj,有ai > aj且1≤i<j≤n。也就是說,大的數排在小的數前面。

輸入:第一行是n和k,1 ≤ n ≤ 105,0 ≤ k ≤ 109;第二行包括n個整數{a1, a2, a3,…, an},0≤ ai ≤109。

輸出:最少的逆序對數量。

Sample Input:

3 1
2 2 1

Sample Output:

1

💖 Main2.java

import java.util.Scanner;public class Main2
{static int N = 100010;static int[] q = new int[N], tmp = new int[N];public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();int k = sc.nextInt();for (int i = 0; i < n; i++)q[i] = sc.nextInt();long cnt = mergeSort(0, n - 1);System.out.println(Math.max(0, cnt - k));}/*** @param l 區間左邊界* @param r 區間右邊界* @return long 類型的區間內的逆序對*/private static long mergeSort(int l, int r){if (l >= r)return 0;int mid = l + r >> 1;long res = mergeSort(l, mid) + mergeSort(mid + 1, r);int k = 0;// 臨時數組指針int i = l;// 左區間指針int j = mid + 1;// 右區間指針while (i <= mid && j <= r){if (q[i] <= q[j])// 無逆序對tmp[k++] = q[i++];else{tmp[k++] = q[j++];res += mid - i + 1;}}if (i <= mid)tmp[k++] = q[i++];if (j <= r)tmp[k++] = q[j++];for (i = l, j = 0; i <= r; i++, j++){q[i] = tmp[j];}return res;}
}

在這里插入圖片描述

3. 求最大子段和(分治法)

👨?🏫 力扣題解:53.最大子數組和

給出一個長度為 n的序列 a,選出其中連續且非空的一段使得這段和最大。

輸入格式
第一行是一個整數,表示序列的長度 n。

第二行有 n 個整數,第 i 個整數表示序列的第 i個數字 ai。

輸出格式
輸出一行一個整數表示答案。

輸入

7
2 -4 3 -1 2 -4 3

輸出

4

💖 源代碼

import java.util.Scanner;public class Main3
{public static void main(String[] args){Scanner sc = new Scanner(System.in);int n = sc.nextInt();int[] nums = new int[n];for (int i = 0; i < n; i++)nums[i] = sc.nextInt();int ans = maxSubArray(nums);System.out.println(ans);}public static int maxSubArray(int[] nums){int len = nums.length;if (len == 0){return 0;}return maxSubArraySum(nums, 0, len - 1);}private static int maxCrossingSum(int[] nums, int left, int mid, int right){// 一定會包含 nums[mid] 這個元素int sum = 0;int leftSum = Integer.MIN_VALUE;// 左半邊包含 nums[mid] 元素,最多可以到什么地方// 走到最邊界,看看最值是什么// 計算以 mid 結尾的最大的子數組的和for (int i = mid; i >= left; i--){sum += nums[i];if (sum > leftSum){leftSum = sum;}}sum = 0;int rightSum = Integer.MIN_VALUE;// 右半邊不包含 nums[mid] 元素,最多可以到什么地方// 計算以 mid+1 開始的最大的子數組的和for (int i = mid + 1; i <= right; i++){sum += nums[i];if (sum > rightSum){rightSum = sum;}}return leftSum + rightSum;}private static int maxSubArraySum(int[] nums, int left, int right){if (left == right){return nums[left];}int mid = left + (right - left) / 2;return max3(maxSubArraySum(nums, left, mid), maxSubArraySum(nums, mid + 1, right),maxCrossingSum(nums, left, mid, right));}private static int max3(int num1, int num2, int num3){return Math.max(num1, Math.max(num2, num3));}
}

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/13049.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/13049.shtml
英文地址,請注明出處:http://en.pswp.cn/web/13049.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

復雜json解析(其中有一個key的value是json格式的字符串)

app上報的參數如下: {"clientId": "8517895440514039afcf6d3e5d7832ae","dua": "SNDOCKCJPH90_GA&VN900042418&BN0&VCXiaomi&MOM2012K11AC&RL1080_2239&CHIDunknown_unknown&LCID&RV&OSAndroid13&…

邦注科技 即熱式節能模溫機的原理及應用介紹

模溫機是一種用于控制模具溫度的設備&#xff0c;它在各種工業領域中發揮著重要作用&#xff0c;特別是在塑料加工行業中。以下是關于模溫機的原理及應用的詳細介紹&#xff1a; 原理 模溫機的工作原理主要是通過加熱和冷卻功能&#xff0c;維持模具溫度在一個恒定的范圍內。…

Hadoop 3.4.0 項目實戰

1環境基于 上一篇搭建 高可用分布式集群 2 官方提供MapReduce程序 #評估圓周率 cd /data/hadoop/share/hadoop/mapreduce/ hadoop jar hadoop-mapreduce-examples-3.4.0.jar pi 2 6 3 實例項目分析1 #預分析的文件如&#xff0c;如單詞統計 # #上傳文件到hdfs hdfs …

SOLIDWORKS 2024云服務新功能

一、簡單的分享一下&#xff0c;在線觀看&#xff0c;輕松標記 在達索系統SOLIDWORKS 2024云服務中&#xff0c;您只需在達索系統SOLIDWORKS中點擊按鈕&#xff0c;就可以將當前的設計分享給其他人&#xff0c;無論是客戶、供應商還是團隊內部成員。共享的用戶只要打開瀏覽器里…

Python中的exec()函數,動態執行代碼的利器

簡介 在Python編程中&#xff0c;exec()函數是一個強大的工具&#xff0c;它允許你執行存儲在字符串或對象中的Python代碼。這種動態執行代碼的能力為腳本編寫、自動化測試、以及快速原型開發提供了極大的便利。 exec()函數的基本用法 exec()函數可以執行作為字符串輸入的Py…

一本專業130+總分400+上海交通大學819考研經驗上交電子信息與通信工程上岸,真題,大綱,參考書。

今年專業課819信號系統與信號處理130&#xff0c;總分400&#xff0c;復試表現中規中矩&#xff08;初試分數查到才開始復習復試&#xff0c;希望大家汲取教訓&#xff0c;初試考完就可以錄取開始準備復試&#xff09;&#xff0c;交大初試比重很高&#xff0c;良心學校&#x…

LeetCode58.最后一個單詞的長度

題目鏈接&#xff1a; 58. 最后一個單詞的長度 - 力扣&#xff08;LeetCode&#xff09; 分析&#xff1a;普通的模擬題&#xff0c;只要有基本的算法思想就可以掌握。 算法思路&#xff1a;要統計最后一個單詞的長度&#xff0c;所以我們只要找到最后一個單詞出現的起始和終…

ASP.NET在線畢業論文提交系統的設計與實現

摘 要 本設計就很好的解決了上面的問題&#xff0c;它不但能實現畢業生論文的在線提交&#xff1b;還能給教師一定的權限&#xff0c;以在線的方式對自己指導的學生的論文進行審核&#xff1b;并且管理員還可以方便的將每個學生的論文信息按統一的論文排版本格式導出成word文…

高并發-線程池面試

文章目錄 高并發-線程池2024心得好的博客必會面試題為什么使用線程池線程池的實現原理線程池的拒絕策略阻塞隊列已滿&#xff0c;在提交任務會發生什么問題threadlocal原理和使用多線程配置 高并發-線程池2024 心得 面試都是圍繞著三高展開&#xff0c;高并發&#xff0c;高可…

洗衣洗鞋店做小程序有什么優勢?

互聯網洗衣洗鞋小程序閃亮登場&#xff0c;想知道這款小程序有何魅力嗎&#xff1f; 如今&#xff0c;眾多商家紛紛推出預約上門洗鞋服務&#xff0c;&#x1f481;?♀?并傾力打造洗鞋小程序&#xff0c;旨在拓展線上銷售渠道。&#x1f31f;那么&#xff0c;這款洗鞋小程序究…

Oracle數據庫的CURRENT SCN

數據庫的CURRENT SCN是Oracle當前最大的SCN&#xff0c;可以通過多種方法獲取該SCN&#xff1a; 1、直接從內存中獲取。由于當前最大SCN存儲在fixed sga中&#xff0c;因此可以通過Oracle debug工具DUMP kcsgscn結構體獲取內存中的最大SCN。在下面的程序中&#xff0c;BA371為1…

網絡配置的加密存儲

隨著數據泄露事件的增加&#xff0c;擾亂了公司的正常工作周期&#xff0c;企業遭受了損失。事實上&#xff0c;數據泄露可以通過存儲加密來控制&#xff0c;存儲加密是防止黑客對網絡數據庫造成嚴重破壞的最有效方法之一。在網絡配置管理器中&#xff0c;存儲加密可用于存儲設…

SpringBoot解析MyBatis預編譯SQL

pom.xml <profile><!-- 開發環境 --><id>dev</id><activation><!-- 默認激活 --><activeByDefault>true</activeByDefault></activation><properties><spring.profiles.active>dev</spring.profiles.ac…

Unity 模擬放大鏡局部放大UI 效果實現

UI 放大實現 RectTransformUtility.ScreenPointToLocalPointInRectangle(rectScale, eventData.position, eventData.pressEventCamera, out localPos); 使用IPointerDownHandler 獲取鼠標點擊時的有效負載&#xff0c;并將鼠標坐標轉成對應的UI 坐標&#xff0c;rectScale 為…

【Win】一鍵恢復IE11工具:讓舊版瀏覽器在新系統中重生

微軟在2020年8月的時候就已經公告IE11的生命周期終點&#xff0c;多次提醒將在2022年6月15日起不再支持IE 11&#xff0c;呼吁用戶盡快轉換到Chromium-based Microsoft Edge。微軟也陸續終止旗下服務支持這個舊式瀏覽器。2021年3月&#xff0c;Chrome瀏覽器已不支持舊IE App。2…

字符串解析-KMP魔改

題目 已知存在一種字符串解析語法&#xff0c;其中的語法元素如下 N:用于匹配單個數字(0-9) A:用于匹配單個字母(a-z,A-Z) n():用于表示一個分組&#xff0c;分組中至少有一個N語法元素或者A語法元素&#xff0c;n為一個數值&#xff0c;表示匹配n次&#xff0c;1<n< 20…

歡迎光臨Java中的客“棧”

就目前而言&#xff0c;相信大家對數組、鏈表還有棧都基本已經有了一些了解&#xff0c;本篇文章將以棧為主體&#xff0c;探究棧和數組&#xff0c;棧和鏈表之間的一些聯系。 當然在開始對棧的學習之前&#xff0c;我們先回顧有關數組、鏈表的基礎知識點。 學習代碼就是一個…

四川景源暢信:如何更好的為抖音小店做引流?

在數字化營銷的浪潮中&#xff0c;抖音小店作為新興的電商形態&#xff0c;正以其獨特的社交屬性和流量優勢吸引著眾多商家的目光。如何為抖音小店引流&#xff0c;成為許多店主心中的疑問。本文將深入探討有效提升店鋪流量的策略&#xff0c;助你在抖音平臺上快速崛起。 一、內…

代碼隨想錄算法訓練營第二十五天:樹的最后學習

代碼隨想錄算法訓練營第二十五天&#xff1a;樹的最后學習 如果不對遞歸有深刻的理解&#xff0c;本題有點難 單純移除一個節點那還不夠&#xff0c;要修剪&#xff01; #669. 修剪二叉搜索樹 力扣題目鏈接(opens new window) 給定一個二叉搜索樹&#xff0c;同時給定最小邊界…

shell腳本之sort,uniq,tr,cut,sphit,paste,ecal與正則表達式

sort命令 uniq命令 tr命令 cut命令 sphit命令 paste命令 ecal命令 正則表達式 sort命令 sort命令---以行為單位對文件內容進行排序&#xff0c;也可以根據不同的數據類型來排序 比較原則是從首字符向后&#xff0c;依次按ASCII碼值進行比較&#xff0c;最后將他們按升序…