我是靠谱客的博主 潇洒橘子,最近开发中收集的这篇文章主要介绍LeetCode—67. 二进制求和,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

这题总体思路有点像两个线性表的合并,有个知识点花了很长时间,函数传回字符串,详见上一篇

char *S(char *b)
{
    char *s;
    return s;
}

这个s是传不回去的,因为在函数体里面定义,是局部变量。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char *addBinary(char * a, char * b) {
    int lena,lenb,len=0,num_a,num_b,i,j,jin=0;
    int s[100];
    char ss[100];
    lena=strlen(a);
    lenb=strlen(b);
    i=lena-1;
    j=lenb-1;
//printf("a%d b%dn",lena,lenb);
    while(i!=-1&&j!=-1)
    {
        num_a=a[i]-'0';
        num_b=b[j]-'0';
        s[len]=(num_a+num_b+jin)%2;
        jin=(num_a+num_b+jin)/2;
        len++;
        i--;
        j--;
    }

    while(i!=-1)
    {
        num_a=a[i]-'0';
        s[len]=(num_a+jin)%2;
        jin=(num_a+jin)/2;
        len++;
        i--;
    }
    while(j!=-1)
    {
        num_b=b[j]-'0';
        s[len]=(num_b+jin)%2;
        jin=(num_b+jin)/2;
        len++;
        j--;
    }
    if(jin==0)
    {
        for(i=len-1;i>=0;i--)
        ss[len-i-1]=s[i]+'0';
        ss[len]='';
    }
    else
    {
        for(i=len-1;i>=0;i--)
        ss[len-i]=s[i]+'0';
        ss[0]='1';
        ss[++len]='';
    }
    a=ss;
    puts(a);
    return a;
}
int main()
{
    char a[]= "11", b[] = "1";
   // printf("a%d  b%dn",a,b);
    //char *ss;
    printf("%sn",a);
    return 0;
}

最后

以上就是潇洒橘子为你收集整理的LeetCode—67. 二进制求和的全部内容,希望文章能够帮你解决LeetCode—67. 二进制求和所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(80)

评论列表共有 0 条评论

立即
投稿
返回
顶部