diff options
| author | Steve Lee <me@xiangyangli.com> | 2018-01-13 05:13:14 +0800 |
|---|---|---|
| committer | Steve Lee <me@xiangyangli.com> | 2018-01-13 05:13:14 +0800 |
| commit | a46ec300092c1ee8ccac629b7f335643f87662f5 (patch) | |
| tree | b03e20d905e6f583df626386164daf4aa5f81519 /Computer_Science/leetcode/67-add_binary.c | |
| parent | 79a9c52fa923fc78074d88463449a8b7f95ca3ef (diff) | |
| download | 42-a46ec300092c1ee8ccac629b7f335643f87662f5.tar.xz 42-a46ec300092c1ee8ccac629b7f335643f87662f5.zip | |
update
Diffstat (limited to 'Computer_Science/leetcode/67-add_binary.c')
| -rw-r--r-- | Computer_Science/leetcode/67-add_binary.c | 75 |
1 files changed, 75 insertions, 0 deletions
diff --git a/Computer_Science/leetcode/67-add_binary.c b/Computer_Science/leetcode/67-add_binary.c new file mode 100644 index 0000000..48e4744 --- /dev/null +++ b/Computer_Science/leetcode/67-add_binary.c @@ -0,0 +1,75 @@ +#define MAX(a, b) ((a) > (b) ? (a) : (b)) +char* addBinary(char* a, char* b) { + int lenA = strlen(a); + int lenB = strlen(b); + + int len = MAX(lenA, lenB) + 1; + char* result = malloc(sizeof(char) * (len + 1)); + result[len--] = '\0'; + char in = '0'; + int sum = 0; + + lenA--; + lenB--; + + if(len == 0) return "0"; + + while(lenA >= 0 && lenB >=0) { + sum = a[lenA] + b[lenB] + in - 3 * '0'; + switch(sum) { + case 0: + in = '0'; + result[len] = '0'; + break; + case 1: + in = '0'; + result[len] = '1'; + break; + case 2: + in = '1'; + result[len] = '0'; + break; + case 3: + in = '1'; + result[len] = '1'; + break; + } + lenA--; + lenB--; + len--; + } + + while(lenA >= 0) { + if(in == '0') { + result[len] = a[lenA]; + } else if(a[lenA] == '1') { + result[len] = '0'; + in = '1'; + } else { + result[len] = '1'; + in = '0'; + } + lenA--; + len--; + } + + while(lenB >= 0) { + if(in == '0') { + result[len] = b[lenB]; + } else if(b[lenB] == '1') { + result[len] = '0'; + in = '1'; + } else { + result[len] = '1'; + in = '0'; + } + lenB--; + len--; + } + + if(in == '0') + return result + 1; + + *result = '1'; + return result; +} |
