| 
在线时间128 小时最后登录2016-1-12注册时间2014-8-14听众数14收听数0能力0 分体力483 点威望0 点阅读权限30积分213相册0日志0记录0帖子140主题9精华0分享0好友42
 
 升级    56.5% TA的每日心情|  | 郁闷 2015-2-4 00:27
 | 
|---|
 签到天数: 64 天 [LV.6]常住居民II 
 自我介绍新人
 
   群组: 国赛讨论 | 
zan| 现在是设计一个把多项式的字符串转换成行向量表示的函数,错误如图所示(非法使用关键字 else)。 贴上源码,原谅我后面的没写注释,就别看后面的了。
 
 
 
 代码:
 
 %str2poly.m
 %把多项式的字符串转换成行向量表示
 function Y=str2poly(X)
 if (ischar(X)==0)%格式检查
 disp('输入错误,输入X必须是一个字符串!');
 end;
 index=regexp(X,'\+|\-');%用正则表达式寻找+或-的下标位置,|表示或
 L=length(index);%多项式的项数
 term=cell(1,L+1);%用于储存多项式每一项信息的单元字符串矩阵,cell(1,L+1)表示创建1行,L+1列的空矩阵。
 term(1)=cellstr(X(1:(index(1)-1)));
 for i=1:L-1
 term(i+1)=cellstr(X(index(i):(index(i+1)-1)));
 if (isempty(char(term(1)))) %如果第一项为空,则删除第一项
 term(1)=[];
 L=L-1;
 end;
 coefficient=[];%多项式系数矩阵
 power=[]; %多项式幂次矩阵,它与多项式系数矩阵一一对应
 for i=1:L+1
 substring=char(term(i));%单项多项式字符串表达式
 index2=regexp(substring,'\^');
 if (isempty(index2)==0)
 if (index2(1)==1) %如果匹配上
 coefficent=[coefficient 1];%单项多项式字符串为 ‘x^*' 形式
 power=[power str2num(substring((index2(1)+2):end))];
 elseif(index2(1)==2)
 if (substring(1)=='+')
 cofficient=[coefficent 1];
 power=[power str2num(substring((index2(1)+2):end))];
 elseif(substring(1)=='-')
 cofficient=[coefficent -1];
 power=[power str2num(substring((index2(1)+2):end))];
 end;
 end;
 coefficient=[coefficent str2sum(substring(1:(index2(1)-1)))];
 power=[power str2num(substring((index2+2):end))];
 end;
 else
 index2=regexp(substring,'x');
 if (isempty(index2)==0)
 if (index2(1)==1)
 cofficient=[coefficent 1];
 power=[power 1];
 elseif(index2(1)==2)
 if ((substring(1)=='+')==1)
 cofficient=[coefficent 1];
 power=[power 1];
 elseif (substring(1)=='-')
 cofficient=[coefficent -1];
 power=[power 1];
 else
 cofficient=[cofficient str2num(substring(1:(index2-1)))];
 power=[power 1];
 end;
 else
 cofficient=[cofficient str2num(substring(1:(index2-1)))];
 power=[power 0];
 end;
 else
 cofficient=[cofficient str2num(substring)];
 power=[power 0];
 end;
 end;
 end;
 N=max(power)+1;
 Y=zeros(1,N);
 for i=1:N
 index3=find(power==(N-i));
 Y(i)=sum(coefficient(index3));
 end;
 | 
 |