C语言 二分查找,计算函数给出一个字节中被置 1 的位的个数,将给定的一个字符串转换成整数,将给定的一个整数转换成字符串

二分查找

#include <stdio.h>

int binarySearch(int arr[],int left,int right,int target)
{
    while(left <= right)
    {
        int mid = left + (right-left)/2;
        if(arr[mid] == target)
            return mid;
        if(arr[mid] < target)
            left = mid + 1;
        else
            right = mid -1 ;
    }
    return -1;

}


int main(int argc, char *argv[])
{ 
    int arr[] = {2,5,8,12,16,23,38,56,72,91};
    int n = sizeof(arr)/sizeof(arr[0]);
    int target = 12;
    int index = binarySearch(arr,0,n-1,target);
    if(index != -1)
    printf("%d\n",index);

    return 0;
} 

计算函数给出一个字节中被置 1 的位的个数

#include <stdio.h>

int countByte(unsigned char c)
{
    int count = 0;
    while(c != 0)
    {
        if(c & 1)
            count++;
        c >>= 1;
    }
    return count;
}


int main(int argc, char *argv[])
{ 
     char c = 0xab;
    int b = countByte(c);
    printf("%d\n",b);

    return 0;
} 

将给定的一个字符串转换成整数

/*===============================================
*   文件名称:iton.c
*   创 建 者: memories
*   创建日期:2023年07月06日
*   描    述:have a nice day
================================================*/
#include <stdio.h>

int iton(char *p)
{
    int num = 0;
    while(*p != '\0')
    {
        int tmp = *p-48;
        num = tmp+num*10;
        p++;
    }
    return num;
}


int main(int argc, char *argv[])
{ 
    char a[] = "asd";
    int num = iton(a);
    printf("%d\n",num);

    return 0;
} 

将给定的一个整数转换成字符串

/*===============================================
*   文件名称:iton.c
*   创 建 者: memories
*   创建日期:2023年07月06日
*   描    述:have a nice day
================================================*/
#include <stdio.h>

void itos(int n,char *str)
{
    int i = 0;
    //判断是否为负数
    if(n < 0)
    {
        str[i++] = '-';
        n = -n;
    }

    //将每一位数字转换并存放在字符串中
    int m;
    do{
     m = n%10;
     n = n/10;
    str[i++] = m +'0';
    }while(n != 0);

    //倒置字符串
    int start = (str[0]=='-')? 1:0;//判断从第几位开始倒转
    int end = i-1;
    while(start < end)
    {
        char tmp = str[end];
        str[end] = str[start];
        str[start] = tmp;
        end--;
        start++;
    }
    str[i] = '\0';

}


int main(int argc, char *argv[])
{ 
    int n = -2121234;
    char str[20];
    itos(n,str);
    printf("%s\n",str);
    return 0;
} 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孤独memories

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值