当前位置:网站首页>Li Kou brush question diary /day1/2022.6.23
Li Kou brush question diary /day1/2022.6.23
2022-07-04 18:35:00 【Bobo toilet cleaning spirit】
Novice Village
Failure is a fog , Through it, you can see success
Data structure algorithm , Array is an important concept , Today, I mainly study the concepts of arrays .
Array (Array) Is made up of elements of the same type (element) Is a collection of data structures composed of , Allocate a contiguous block of memory for storage . Use the index of the element (index) The storage address for this element can be calculated .
Simply speaking , An array consists of a piece continuity Data structure composed of memory . There is a keyword in this concept “ continuity ”, It reflects a major feature of arrays , It must be composed of a continuous memory
The advantages of arrays :
Array of “ continuity ” Its characteristics determine its fast access speed , Because it is continuously stored , So this determines that its storage location is fixed , So its access speed is very fast . For example, there is now 10 Rooms are booked in order of age , When we know that the first house is 20 After years old , Then we know that the second house is 21 A man of years old , The fifth house is 24 A man of years old ...... wait .
Disadvantages of arrays :
1. The memory requirements are relatively high , You must find a contiguous piece of memory .
2. Insertion and deletion are slow , Suppose we insert or delete a data in the non tail of the array , Then you have to move all the data after , This brings some performance overhead
3. Fixed size , Can't expand dynamically .
Array creation
arrayList = new ArrayList<Integer>();
// The first way to create an array
int[] arr=new int[10]; // Declare an array object by creating the method of the object
// The second way to create an array
int[] x={1,2,3,4,5,6,7,8,9,10}; // adopt {} To create
// The third way to create an array .
int[] y= new int[]{1,2,3,4,5};// Declare an object and fill the array with values , Get array object [1,2,3,4,5]
// The fourth way to create an array
int[] arr = new int[26]// Create a 26 An empty array of elements
How to judge whether the array subscript is out of bounds
public static boolean isLength(int m,int arr[]){
boolean flag=false;
int length = arr.length;
if(m<length)
flag=true;
return flag;
}
Example 1data:image/s3,"s3://crabby-images/b1ad3/b1ad35ddaeb3506acfe7c5a33df524925d6927ca" alt=""
solution Class contains a runningSum Method
class Solution {
public int[] runningSum(int[] nums) {
int n = nums.length;
for (int i = 1; i < n; i++) {
nums[i] = nums[i] + nums[i - 1];
}
return nums;
}
}
java Format .length Get the length of the array
c Format .size() Get the length of the array
Example 2
Their thinking :
Compare first ransomNote and magazine The length of , If ransomNote Is longer than magazine The length of , return false
Traverse ransomNote The characters in , use count[i] Express 26 Lower case English characters , And record the number of occurrences of characters count[i]++, Re traversal magazine character string , Record the number of character occurrences and subtract one count[i]--,count[i]++ It means that ransomNote The number of occurrences of a character in , stay magazine Traversal string in ,count[i]-- It means that magazine Subtract one from the corresponding characters in , If count[i] Last greater than 0, Description in ransomNote The number of occurrences of a string in is greater than that in magazine Number of occurrences ,magazine Characters in cannot form ransomNote
According to the prompt, the elements in the string are only composed of lowercase English letters , according to ASCLL surface , character -“a” It is the numerical value corresponding to the character
class Solution {
public boolean canConstruct(String ransomNote, String magazine) {
int[] count = new int[26];
if(ransomNote.length()>magazine.length()){
return false; // First, judge the length of the two strings
}
for(int i=0;i<ransomNote.length();i++){
count[ransomNote.charAt(i)-'a']++;
}
for(int i=0;i<magazine.length();i++){
count[magazine.charAt(i)-'a']--;
}
for(int i=0;i<26;i++){
if(count[i]>0) return false;
}
return true;
}
}
charAt() Method to return the characters at the specified index . Index range is from 0 To length() - 1.
边栏推荐
- Implementation of shell script replacement function
- How is the entered query SQL statement executed?
- How to improve development quality
- 力扣刷题日记/day8/7.1
- Is it safe to open an account online? is that true?
- 【Hot100】31. 下一个排列
- Pytoch deep learning environment construction
- Digital "new" operation and maintenance of energy industry
- 五千字讲清楚团队自组织建设 | Liga 妙谈
- How to download files using WGet and curl
猜你喜欢
TCP waves twice, have you seen it? What about four handshakes?
Five thousand words to clarify team self-organization construction | Liga wonderful talk
Li Kou brush question diary /day6/6.28
[cloud native] what is the "grid" of service grid?
【Hot100】32. Longest valid bracket
估值900亿,超级芯片IPO来了
力扣刷题日记/day3/2022.6.25
Mysql5.7 installation tutorial graphic explanation
Imitation of numpy 2
Halcon模板匹配
随机推荐
激进技术派 vs 项目保守派的微服务架构之争
【Hot100】31. Next spread
An example of multi module collaboration based on NCF
I always thought that excel and PPT could only be used for making statements until I saw this set of templates (attached)
Five thousand words to clarify team self-organization construction | Liga wonderful talk
比李嘉诚还有钱的币圈大佬,刚在沙特买了楼
"In Vietnam, money is like lying on the street"
能源行业的数字化“新”运维
力扣刷题日记/day8/7.1
android使用SQLiteOpenHelper闪退
NBA赛事直播超清画质背后:阿里云视频云「窄带高清2.0」技术深度解读
Interpretation of SIGMOD '22 hiengine paper
Li Kou brush question diary /day5/2022.6.27
Set the transparent hidden taskbar and full screen display of the form
【209】go语言的学习思想
Improve the accuracy of 3D reconstruction of complex scenes | segmentation of UAV Remote Sensing Images Based on paddleseg
With an estimated value of 90billion, the IPO of super chip is coming
华为云ModelArts的使用教程(附详细图解)
I wrote a learning and practice tutorial for beginners!
Nature Microbiology | 可感染阿斯加德古菌的六种深海沉积物中的病毒基因组