CareerCup chapter 1 Arrays and Strings
1.Implement an algorithm to determine if a string has all unique characters What if you can not use additional data structures?
The length of ACSII code of a character is 8, so we can build a array, the length is 260, to represent the hash table of all characters.
bool allCharUnique(string s){
int a[260];
memset(a,0,sizeof a);
for(int i=0;i<s.length();i++){
if(a[s[i]]==0)a[s[i]]++;
else return false;
}
return true;
}
2.Write code to reverse a C-Style String (C-String means that “abcd” is represented as five characters, including the null character )
consider the null character. we traverse the string to find the last index of valid char.
void reverseCStyleString(char* s){
int i=0,j=0;
char *cur = s;
while(cur){cur++;j++;}--j;
while(i<j){
swap(s[i],s[j]);
++i;--j;
}
}
3.Design an algorithm and write code to remove the duplicate characters in a string without using any additional buffer NOTE: One or two additional variables are fine An extra copy of the array
is not
FOLLOW UP
Write the test cases for this method
Here is two idea. One is O(n^2), by loop all characters of the string, and each char, loop all characters whose index is bigger than current char. if
these two char is equal, then erase the char whose index is bigger.
Other idea is build a map array, map[8], represents the hash table of all characters. Following is this code:
void removeDuplicateChar(string s){
if(s==NULL)return;
int map[]={0,0,0,0,0,0,0,0};
int ascii,index,pos;
int cur=0;
for(int i=0;i<s.length();i++){
ascii = (int)s[i];
index = ascii/32;
pos = ascii%32;
int res = map[index]&(1<<pos);
if(!res){
map[index]|=1<<pos;
s[cur++]=s[i];
}
}
s[cur]='\0';
return;
}
Test case: NULL , empty string, all duplicates and others.
4.Write a method to decide if two strings are anagrams or not.
One idea: sort these two strings, then look whether of these two strings are equal. O(nlogn)
Other idea: map the first string by unordered_map<char,int>. then decide the map 0f the second string is equal to the first. O(n). Following is this code:
bool isAnagrams(string a,string b){
if(a==NULL||b==NULL)return false;
if(a.length()==0&&b.length()==0)return true;
if(a.length()!=b.length())return false;
unordered_map<char,int> map;
for(int i=0;i<a.length();i++){
if(map.count(a[i])==0)map.insert(make_pair(a[i],1));
else map[a[i]]++;
}
for(int i=0;i<b.length();i++){
if(map.count(b[i])==0)return false;
else{
map[b[i]]--;
if(map[b[i]]<0)return false;
}
}
return true;
}
5.Write a method to replace all spaces in a string with "%20".
"%20" is a string with length of 3. each space is 1 length. So the string's length is extend to s.length()+spaceCount*2. First enlarge the string,whose length
is s.length()+spaceCount*2, then we copy the original string to this new string. When we come across a space, the new string is insert '0' '2' '%'.
void replaceAllSpaces(string s){
if(s==NULL)return;
int spaceCount=0,preLenth=s.length();
for(int i=0;i<s.length();i++){
if(s[i]==' ')spaceCount++;
}
for(int i=0;i<2*spaceCount;i++)s+=' ';
int cur=s.length()-1,j=preLenth-1;
while(j>=0){
if(s[j]==' '){
s[cur--]='0';
s[cur--]='2';
s[cur]='%'
}else{
s[cur]=s[j];
}
cur--;j--;
}
return;
}
6.Given an image represented by an NxN matrix, where each pixel in the image is 4 bytes, write a method to rotate the image by 90 degrees Can you do this in place?
ClockWise rotate: first we turn over all pixels diagonal. then reverse each line.
other idea: rotate each layer such as loop diagram. left layer ->top layer,bottom layer -> left layer, right layer->bottom layer, top layer->right layer.
void clockwiseRotate(vector<vector<int> > matrix){
if(matrix.size()==0||matrix[0].size()==0)return;
int n=matrix.size();
for(int i=0;i<n;i++){
for(int j=i;j<n;j++){
swap(matrix[i][j],matrix[j][i]);
}
}
for(int i=0;i<n;i++){
reverse(matrix[i].begin(),matrix[i].end());
}
return;
}
7.Write an algorithm such that if an element in an MxN matrix is 0, its entire row and column is set to 0.
we build two record array(row,column) to track in which row/column should be set to 0.
void setMatrix(vector<vector<int> > matrix){
if(matrix.size()==0||matrix[0].size()==0)return;
int *row = new int[matrix.size()];
int *column = new int[matrix[0].size()];
memset(row,0,sizeof row);memset(column,0,sizeof column);
for(int i=0;i<matrix.size();i++){
for(int j=0;j<matrix[i].size();j++){
if(matrix[i][j]==0){
row[i]=1;column[j]=1;
}
}
}
for(int i=0;i<matrix.size();i++){
for(int j=0;j<matrix[i].size();j++){
if(row[i]||column[j])matrix[i][j]=0;
}
}
return;
}
8.Assume you have a method isSubstring which checks if one word is a substring of another Given two strings,s1and s2,write code to check if s2 is a rotation of s1using only one call to isSubstring
(i e , “waterbottle” is a rotation of “erbottlewat”).
first, make sure s1.length() equals to s2.length(). if(s1.length()!=s2.length())return false;
Then, concatenate s1 with itself and look s2 is or not the substring of s1s1.
bool isRotation(string s1,string s2){
if(s1==NULL||s2==NULL)return false;
int len = s1.length();
if(len==s2.length()&&len>0){
string s1s1 = s1+s1;
return isSubstring(s1s1,s2);
}
return false;
}
版权声明:本文博主原创文章,博客,未经同意不得转载。
CareerCup chapter 1 Arrays and Strings的更多相关文章
- CareerCup Chapter 9 Sorting and Searching
9.1 You are given two sorted arrays, A and B, and A has a large enough buffer at the end to hold B. ...
- Careercup | Chapter 1
1.1 Implement an algorithm to determine if a string has all unique characters. What if you cannot us ...
- Careercup | Chapter 3
3.1 Describe how you could use a single array to implement three stacks. Flexible Divisions的方案,当某个栈满 ...
- Careercup | Chapter 2
链表的题里面,快慢指针.双指针用得很多. 2.1 Write code to remove duplicates from an unsorted linked list.FOLLOW UPHow w ...
- Careercup | Chapter 8
8.2 Imagine you have a call center with three levels of employees: respondent, manager, and director ...
- Careercup | Chapter 7
7.4 Write methods to implement the multiply, subtract, and divide operations for integers. Use only ...
- CareerCup Chapter 4 Trees and Graphs
struct TreeNode{ int val; TreeNode* left; TreeNode* right; TreeNode(int val):val(val),left(NULL),rig ...
- Careercup | Chapter 6
6.2 There is an 8x8 chess board in which two diagonally opposite corners have been cut off. You are ...
- Careercup | Chapter 5
5.1 You are given two 32-bit numbers, N andM, and two bit positions, i and j. Write a method to inse ...
随机推荐
- 【C语言天天练(二四)】内存分配
引言: 对于C语言程序,了解它执行时在内存中是怎样分配的对于我们理解它的执行机制是很实用的.以下就总结一下C语言程序的一些内存分配知识. 一 一段C程序.编译连接后形成的可运行文件一般有代码段.数据段 ...
- 表达式树动态拼接lambda
动态拼接lambda表达式树 前言 最近在优化同事写的代码(我们的框架用的是dapperLambda),其中有一个这样很普通的场景——界面上提供了一些查询条件框供用户来进行过滤数据.由于dappe ...
- poj1836--Alignment(dp,最长上升子序列变形)
Alignment Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 13319 Accepted: 4282 Descri ...
- Android基于发展Service音乐播放器
这是一个基于Service组件的音乐播放器,程序的音乐将会由后台的Service组件负责播放,当后台的播放状态改变时,程序将会通过发送广播通知前台Activity更新界面:当用户单击前台Activit ...
- Wix打包系列(五) 部署数据库
原文:Wix打包系列(五) 部署数据库 很多人在使用vs进行打包的时候,经常会为数据库部署的问题犯愁,即便是重写Installer类的方法,也不是很可靠方便,下面我们来看看在wix中如何部署数据库. ...
- Git——git 上传时 遗漏文件解决办法
今天在Server上建立一个git 库,把本地的code 上传到Server,再次clone下来时,发现少了些文件.原来git 工具不上上传一些二进制,pdf,.patch等一些文件.在上传时,git ...
- 美版SOLOWHEEL与盗版SOLOWHEEL-IPS独轮车终极PK【图】_厂商资讯_太平洋电脑网
http://g.pconline.com.cn/x/330/3304676.html
- 一些周期性GC的理由为何
1.供tomcat:防止内存泄漏监听器 JreMemoryLeakPreventionListener在上班,每隔一小时默认触发一次System.gc Class clazz = Class.forN ...
- 关于AIX VG中 LV 的状态问题,LV STATE
在数据库管理过程中常常遇见LV状态异常,而造成LV不能再次被使用的情况,那么AIX中LV的两种状态分别代表什么呢 如果是访问fs需要open,即创建文件系统并mount 文件系统LV STATE 才是 ...
- linux进程解析--进程的退出及销毁
一进程的退出: 当一个进程运行完毕或者因为触发系统异常而退出时,最终会调用到内核中的函数do_exit(),在do_exit()函数中会清理一些进程使用的文件描述符,会释放掉进程用户态使用的相关的物理 ...