Make writing a habit together! This is my first day to participate in the “Gold Digging Day New Plan · April More text challenge”, click to see the details of the activity.
📢 preface
🚀 Algorithm 🚀 |
- 🌲 punch in an algorithm every day, which is not only a learning process, but also a sharing process 😜
- 🌲 tip: the programming languages used in this column are C# and Java
- 🌲 to maintain a state of learning every day, let us work together to become a god of algorithms 🧐!
- 🌲 today is the force button algorithm continued to punch the card 104 days 🎈!
🚀 Algorithm 🚀 |
🌲 Uncommon words in two sentences
A sentence is a string of words separated by Spaces. Each word consists only of lowercase letters.
A word is uncommon if it appears exactly once in one sentence but not in the other.
Given two sentences s1 and s2, return a list of all uncommon words. Returns a list of words that can be organized in any order.
Example 1:
Enter s1 ="apple apple", s2 = "banana"Output:"banana"]
Copy the code
Example 2:
Enter s1 ="this apple is sweet", s2 = "this apple is sour"Output:"sweet"."sour"]
Copy the code
Tip:
- 1 <= s1.length, s2.length <= 200
- S1 and S2 consist of lowercase letters and Spaces
- Neither S1 nor S2 contain leading or trailing Spaces
- All words in S1 and S2 are separated by a single space
🌻C# method: dictionary traversal
Each unusual word appears only once in total.
We can count the number of occurrences of each word and return words that occur exactly once.
Code:
public class Solution {
public string[] UncommonFromSentences(string s1, string s2) {
string[] sa = s1.Split(' ');
string[] sb = s2.Split(' ');
Dictionary<string.int> dic = new Dictionary<string.int> ();foreach(var s in sa)
{
if(! dic.ContainsKey(s)) { dic.Add(s,1);
}
else{ dic[s]++; }}foreach(var s in sb)
{
if(! dic.ContainsKey(s)) { dic.Add(s,1);
}
else
{
dic[s]++;
}
}
List<string> ret = new List<string> ();foreach(var item in dic)
{
if(item.Value == 1) { ret.Add(item.Key); }}returnret.ToArray(); }}Copy the code
The execution result
By execution time:140Ms, in all CBeat 42.14% of users in # submissionMemory consumption:41.9MB, in all C# beat 14.70% of users in submission
Copy the code
🌻Java methods: count
We can iterate through the sequence and record the length of the current group.
If the next character is different from the current character or is already enumerated to the end of the string, the current character is the end of the current group.
Each time we find the end of the current group, if the group is 33 in length, we add it to the answer.
Code:
class Solution {
public String[] uncommonFromSentences(String A, String B) {
Map<String, Integer> count = new HashMap();
for (String word: A.split(""))
count.put(word, count.getOrDefault(word, 0) + 1);
for (String word: B.split(""))
count.put(word, count.getOrDefault(word, 0) + 1);
List<String> ans = new LinkedList();
for (String word: count.keySet())
if (count.get(word) == 1)
ans.add(word);
return ans.toArray(newString[ans.size()]); }}Copy the code
The execution result
By execution time:2Ms, beat out all Java commits99.41% user memory consumption:38.4MB, beat out all Java commits5.53% of the userCopy the code
Complexity analysis
Time complexity: O(M+N) where M and N are the lengths of A and B respectively. Space complexity: O(M+N)Copy the code
💬 summary
- Today is the 104th day of clocking!
- The article USES the
C#
andJava
Two programming languages to solve the problem - Some methods are also written by the god of reference force buckle, and they are also shared while learning, thanks again to the algorithm masters
- That’s the end of today’s algorithm sharing, see you tomorrow!