題目:
給定兩個表示復(fù)數(shù)的字符串钢拧。
返回表示它們乘積的字符串。注意排惨,根據(jù)定義 i2 = -1 涩堤。
示例:
輸入: "1+-1i", "1+-1i"
輸出: "0+-2i"
解釋: (1 - i) * (1 - i) = 1 + i2 - 2 * i = -2i 胚膊,你需要將它轉(zhuǎn)換為 0+-2i 的形式。
解題方法:
按照正常的計算法則把字符串中需要的數(shù)字分離出來就可以了想鹰,難度不大紊婉,不多BB,看看代碼就行了辑舷。
代碼和結(jié)果:
class Solution {
public:
void get(string s,int &a,int &b)
{
string::size_type pos=s.find('+');
string as=s.substr(0,pos);
int len=s.size()-1-pos;
string bs=s.substr(pos+1,len);
a=atoi(as.c_str());
b=atoi(bs.c_str());
}
string complexNumberMultiply(string a, string b) {
int a1,b1;
get(a,a1,b1);
int a2,b2;
get(b,a2,b2);
int c=a1*a2-b1*b2;
int d=a1*b2+a2*b1;
return to_string(c)+"+"+to_string(d)+"i";
}
};
運行結(jié)果:原題鏈接:https://leetcode-cn.com/problems/complex-number-multiplication/