DBS
DBS

Reputation: 301

Concatenate two cell arrays of strings with a space in between?

How can I concatenate:

A = {'hello'; 'hi'; 'hey'}

with

B = {'Ben'; 'Karen'; 'Lisa'}

with a space in between to get:

C = {'hello Ben'; 'hi Karen'; 'hey Lisa'}

Is there a fast non-looping way?

Upvotes: 3

Views: 6941

Answers (3)

Eitan T
Eitan T

Reputation: 32930

A faster (albeit less elegant) alternative to strcat that concatenates strings is a combination of the sprintf and textscan commands:

C = [A; B];
C = textscan(sprintf('%s %s\n', C{:}), '%s', 'delimiter', '\n');

Benchmark

Here's the benchmark code:

A = {'hello' ; 'hi' ; 'hey'};
B = {'Ben' ; 'Karen' ; 'Lisa'};

%// Solution with strcat
tic
for k = 1:1000
    C1 = strcat(A, ' ', B);
end
toc

%// Solution with sprintf and textscan
tic
for k = 1:1000
    C2 = [A; B];
    C2 = textscan(sprintf('%s %s\n', C2{:}), '%s', 'delimiter', '\n');
end
toc

The results are:

Elapsed time is 0.022659 seconds.
Elapsed time is 0.006011 seconds.

Upvotes: 2

Oleg
Oleg

Reputation: 10676

You can use strcat(), although it performs a loop:

strcat(A,{' '}, B)

where the blank is preserved by enclosing it within a cell.

Alternatively, FEX:CStrCatStr is a mex routine which achieves a 10x speedup (depending on testing environment):

CStrCatStr(A,' ', B)

Upvotes: 3

Molly
Molly

Reputation: 13610

You can do that using cellfun:

cellfun(@(x,y) [x, ' ', y], A, B, 'UniformOutput', false)

ans = 
{
  [1,1] = hello Ben
  [2,1] = hi Karen
  [3,1] = hey Lisa
}

Upvotes: 1

Related Questions