我有一个1x500单词的单词,长度可变。例如:
words = {'SO','TODAY', 'IS', 'THURSDAY',...}
另外,我有两个500x1整数数组,第一个包含引用起始行的数字,第二个包含引用结束行的数字。例如:
startRow = 283 endRow = 309
309 332
332 367
... ...
我需要做的是,我需要在第283-308行填充一个1x3000的零字符,并在第30-331行填充单词'SO'(以便该字出现在每一行)今天',从332-367开始,单词'IS',依此类推,直到endRow的最后一个元素被处理完毕。
到目前为止,这是我的代码:
new_val = zeros(1,3000);
for t = 1:size(startRow,1)
count(1,t) = endRow(t)-startRow(t);
word{t} = words{t};
end
for i = 1:size(startRow,1)
new_val(1,startRow(i):endRow(i)-1) = repmat(word{1,i},count(i),1);
end
问题出现在第二个循环中,因为赋值维度不匹配。一次迭代后左手元素的大小为[1,26],一次迭代后右手元素的大小为[26,2],因为显然“SO”被计为2个元素。我不知道该怎么办这个问题,所以任何建议,提示和技巧都非常受欢迎。谢谢!
答案 0 :(得分:2)
你不能用字符串填充矩阵!
所以你必须创建一个[3000x1]单元格阵列。
mycell = cell(3000,1);
你填充单元格:
for i = 1:length(startRow)
mycell(startRow(i):endRow(i)) = words(i);
end