C语言—十进制转成二进制

学习笔记:十进制转成二进制
在RGB灯项目的时候,希望从端口输入RGB的值。
因为RGB的每一位为8位,范围为0-255。

#include <stdio.h> 
#include <stdlib.h>
#include <string.h>

int yello_color[24] = {1,1,0,0,0,1,0,0,1,1,1,1,1,1,1,1,0,0,1,0,1,1,0,1};
int rgb_arr[24] = {0};
/* 连接数组 */
int connection_arr(int *r,int *g, int *b)
{
    int i = 1;//用来计数
    int *rgb = rgb_arr;
	while (i <= 8)
	{
		*rgb = *g;
		rgb++;
		g++;
		i++;
	}

    while (i <= 16)
	{
		*rgb = *r;
		rgb++;
		r++;
		i++;
	}

    while (i <= 24)
	{
		*rgb = *b;
		rgb++;
		b++;
		i++;
	}
    return 0;
}

/* 反转数组 */
int reserve(int *x) {
    int* p, temp, * i, * j, m = (8 - 1) / 2;
    i = x;    //数组首元素地址
    j = x + 8 - 1;//数组末尾元素地址
    p = x + m;//中间元素地址
    for (i=x; i <= p; i++, j--)
    {
        temp = *i;
        *i = *j;
        *j = temp;
    }
    return 0;
}

int main(){
        int g_num = 0;
        int r_num = 0;
        int b_num = 0;

        printf("请输入一个数:");
        scanf("%d %d %d", &r_num, &g_num, &b_num);
        int g_arr[8] = {0};//用一个长度为32的数组接收最后的二进制数,里面的0是为数组设置初始值
        int r_arr[8] = {0};//用一个长度为32的数组接收最后的二进制数,里面的0是为数组设置初始值
        int b_arr[8] = {0};//用一个长度为32的数组接收最后的二进制数,里面的0是为数组设置初始值
        int index = 0;//用来定义数组的下标
        g_arr[index] = g_num % 2;//先获取输入数字的第一个二进制位
        r_arr[index] = r_num % 2;//先获取输入数字的第一个二进制位
        b_arr[index] = b_num % 2;//先获取输入数字的第一个二进制位
        index++;//下标下移一位
        while (1){//使用while循环来获取剩下的二进制位
            /*十进制转换为二进制思想:1.对十进制数进行除以2的操作
            2.对所获得的商进行取余的操作,所获得的数就是二进制每一位
            3.当num<2时,即num除以二不会再有大于1的数字,num%2必为0时
            此时说明num已经完全转换位二进制数,则跳出循环*/
            g_num = g_num / 2;
            r_num = r_num / 2;
            b_num = b_num / 2;
            g_arr[index] = g_num % 2;
            r_arr[index] = r_num % 2;
            b_arr[index] = b_num % 2;
            index++;
            if (g_num < 2 && r_num <2 && b_num < 2){
                break;
            }
        }
        /* 因为储存的时候是倒序储存,所以得对数组进行反转 */
        reserve(g_arr);
        reserve(r_arr);
        reserve(b_arr);
		/* 反转后对数组进行连接 */
        connection_arr(r_arr,g_arr,b_arr);

        int sz = sizeof(g_arr) / sizeof(g_arr[0]);//此为获取数组的长度,总的字节长的大小/单个元素的字节大小
        //以下对数组的倒序遍历,因为arr[0]存储的是二进制位的第一位,以此内推,所以采用数组的倒序遍历
        for (int i = 0; i <= sz - 1; ++i){
            printf("%d", g_arr[i]);
        }
        for (int i = 0; i <= sz - 1; ++i){
            printf("%d", r_arr[i]);
        }
        for (int i = 0; i <= sz - 1; ++i){
            printf("%d", b_arr[i]);
        }
        printf("\n");
        for (int i = 0; i <= 23; ++i){
            printf("%d", yello_color[i]);
        }
        printf("\n");//进行换行操作
        for (int i = 0; i <= 23; ++i){
            printf("%d", rgb_arr[i]);
        }
        printf("\n");//进行换行操作

        system("pause");
        return 0;
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一叶舞澎湃

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

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

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

打赏作者

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

抵扣说明:

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

余额充值