当前位置:首页 > 公众号精选 > 嵌入式大杂烩
[导读]昨晚在微信群看到一个读者发的面试题目,从网上截图出来的,我百思不得其解,题目如图。 幸好,我学过栈 栈,C语言实现 然后我写了个小程序 第一个方法比较笨,当我写完自己的代码后,看到有同学发了自己的代码,我赶紧就发了个红包,一个是为了鼓励大家多讨

昨晚在微信群看到一个读者发的面试题目,从网上截图出来的,我百思不得其解,题目如图。


幸好,我学过

栈,C语言实现


然后我写了个小程序

第一个方法比较笨,当我写完自己的代码后,看到有同学发了自己的代码,我赶紧就发了个红包,一个是为了鼓励大家多讨论问题,一个是为了赞扬这样的行为。


第一个方法就是取出每一个bit,压栈,然后再出栈,你想怎么排序都没有问题。


#include "stdio.h"
#include "stdlib.h"

struct List{
int data;
struct List * next;
};

struct Stack{
struct List *head;
int size;
};


struct Stack * StackInit(void)
{
struct Stack *stack = NULL;
stack = (struct Stack*)malloc(sizeof(struct Stack));
stack->head = (struct List *)malloc(sizeof(struct List));
stack->head->next = NULL;
stack->size = 0;
return stack;
}

int StackPush(struct Stack *stack,int data)
{
struct List *tmp = (struct List *)malloc(sizeof(struct List));
tmp->data = data;
tmp->next = stack->head->next;
stack->head->next = tmp;
stack->size++;
//printf("push:%d \n",data);
return 0;
}

int IsStackEmpty(struct Stack *stack)
{
if(stack->head->next == NULL){
//printf("stack null\n");
return 1;
}else{
//printf("stack is not null\n");
return 0;
}
}

int StackPop(struct Stack *stack,int *data)
{
struct List *tmp = NULL;
if(IsStackEmpty(stack))
return -1;

tmp = stack->head->next;
*data = tmp->data;
stack->head->next = tmp->next;
stack->size--;
if(tmp!=NULL)
free(tmp);

//printf("pop:%d \n",*data);
return 0;
}


int main(void)
{
int i = 0;
unsigned char a = 0x71;
unsigned char b = 0;

struct Stack *stack = NULL;
stack = StackInit();

printf("a:0x%x\n",a);
for(i = 0;i<8;i++)
{

if(a&0x10) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x20) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x40) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x80) StackPush(stack,1);
else StackPush(stack,0);

if(a&0x01) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x02) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x04) StackPush(stack,1);
else StackPush(stack,0);
if(a&0x08) StackPush(stack,1);
else StackPush(stack,0);
}
for(i = 0;i<8;i++)
{
int d = 0;
StackPop(stack,&d);
if(i == 0)
if(d == 1) b |= 0x80;
if(i == 1)
if(d == 1) b |= 0x40;

if(i == 2)
if(d == 1) b |= 0x20;

if(i == 3)
if(d == 1) b |= 0x10;

if(i == 4)
if(d == 1) b |= 0x08;

if(i == 5)
if(d == 1) b |= 0x04;

if(i == 6)
if(d == 1) b |= 0x02;

if(i == 7)
if(d == 1) b |= 0x01;

}

printf("\nb:0x%x\n",b);
return 0;
}


执行如下:


除了用栈来实现,群里有位同学的答案让我眼前一亮

#include <stdio.h>

struct charbits{
unsigned char data1 : 4;
unsigned char data2 : 4;
};


union dataChange{
struct charbits charBits;
unsigned char data;
}datchange,*p;

int main(){

unsigned char temp;

p = &datchange;

datchange.data = 0x34;

temp = p->charBits.data1;

p->charBits.data1 = p->charBits.data2;

p->charBits.data2 = temp;

printf("data is %x", datchange.data);

return 0;
}


完美演示了位域、共用体、结构体、指针的几个知识点~


测试下位域的作用

#include <stdio.h>

struct charbits{
unsigned char data1 : 1;
unsigned char data2 : 3;
};


struct charbits1{
unsigned char data1;
unsigned char data2;
};

int main(){

struct charbits a;
struct charbits1 b;
printf("%d %d\n",sizeof(a),sizeof(b));

/*赋值1看看*/
a.data1 = 1;
printf("%d\n",a.data1);
/*赋值3看看*/
a.data1 = 3;
printf("%d\n",a.data1);

/*赋值3看看*/
a.data2 = 3;
printf("%d\n",a.data2);

/*赋值7看看*/
a.data2 = 7;
printf("%d\n",a.data2);


/*赋值8看看*/
a.data2 = 8;
printf("%d\n",a.data2);
return 0;
}


data1只能存 0和1,如果存其他值的话就会溢出变成0。

data2是 3bits ,只能存 0~7,我们存 8 进去,就溢出变成 0。





  回复「 篮球的大肚子」进入技术群聊
回复「1024」获取1000G学习资料

PS:想加入技术群的同学,加了我好友后,就给我发「篮球的大肚子」这句话,有可能机器人打瞌睡,可以多发几次,不要发与技术无关的消息或者推广。



免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

上海2023年2月13日 /美通社/ -- TUV南德意志集团(以下简称“TUV 南德”)为天合光能有限公司(以下简称“天合光能”)光伏支架系统检测中心颁发光伏跟踪...

关键字: TMP 光伏 BSP 跟踪系统

为中国本土和国际品牌提供程序化服务 上海和蒙特利尔2022年11月25日 /美通社/ -- 全球领先的独立程序化数字户外广告 (DOOH) 技术公司 Hivestack 巢仕达今日宣布,与中国领先的线下广告提...

关键字: STACK BSP 电梯 网络

苏州2022年6月14日 /美通社/ -- 北京时间2022年6月14日,开拓药业(股票代码:9939.HK),一家专注于潜在同类首创和同类最佳创新药物研发及产业化的生物制药公司,宣布公司与印度尼西亚Etana公司的临床...

关键字: AN RS TMP 代码

(全球TMT2022年5月26日讯)Yahoo和全球领先的独立程序化户外 (DOOH) 广告技术公司Hivestack巢仕达宣布建立全球战略合作伙伴关系,致力于连接双方行业领先的技术,并为全球范围内的优质程序...

关键字: STACK BSP DSP MT

(全球TMT2022年5月13日讯)独立程序化数字户外 (DOOH) 广告技术公司 Hivestack巢仕达宣布成立一个新的研究部门,专门探索元宇宙中的店内程序化媒体激活。具有传奇色彩的计算机视觉科学家 P....

关键字: STACK BSP NAND 创始人

前微软研究院董事总经理兼计算机视觉先驱 P. Anandan 加入 Hivestack,担任特别顾问以领导该计划 加拿大多伦多2022年5月13日 /美通社/ -- 世界领先的独立程序化数字户外 (...

关键字: STACK BSP 虚拟化

(全球TMT2022年5月5日讯)日前,在IIF 2022金融创新云论坛上,浪潮云海发布InCloud Stack云原生一体机,面向各行业有软件研发诉求或有分布式业务架构改造和部署诉求的用户,基于浪潮在云原生领域的深度...

关键字: STACK 节点 分布式 AI

Xandr Invest 的广告主通过该联盟,能够在 Hivestack 供应方平台 (SSP) 上于世界各地以程序化的方式购买数字户外 (DOOH) 库存 加拿大蒙特利尔2022年5月4日 /美通社/ -- ...

关键字: STACK AN BSP DSP

(全球TMT2022年5月4日讯)独立程序化数字户外 (DOOH) 广告技术公司 Hivestack(巢仕达)宣布与 Xandr(以数据为基础助力全球优质广告交易市场的技术平台)建立全球战略合作。 Xan...

关键字: STACK AN DSP 集成

(全球TMT2021年12月14日讯)台湾家外媒体广告技术公司搜卖传媒宣布与全球领先的独立程序化数位家外媒体 (DOOH) 广告技术公司Hivestack 建立合作伙伴关系,以期将台湾的程序化家外媒体推向崭新的高度。此...

关键字: STACK DSP 电子 MT
关闭
关闭