海尔2024嵌入式提前批——编程题

题1:

输入一个字符c和一个偏移k,要求输出偏移之后的字符,如果超出了范围就从头开始。

输入、输出样例:

输入:a 1

输出:b

输入:a 26

输出:a

输入:A 2

输出:C

输入:A 51

输出:Z

代码实现

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


int main()
{

    while(1){
        int num;
        char c;
        int ret;
        scanf("%c %d", &c, &num);
        ret = c + num;
        if(c >= 'a' && c <= 'z' && ret >= 'a' && ret <= 'z'){
            printf("%c\r\n", ret);
        }
        if(c >= 'A' && c <= 'Z' && ret >= 'A' && ret <= 'Z'){
            printf("%c\r\n", ret);
        }

        if(c >= 'A' && c <= 'Z' && ret > 'Z'){
            printf("%c\r\n", 'A' + (num - ('Z' - c) - 1) % 26);
        }

        if(c >= 'a' && c <= 'z' && ret > 'z'){
            printf("%c\r\n", 'a' + (num - ('z' - c) - 1) % 26);
        }
    }

}

测试结果

题2:

从终端先输入一个数组的长度,然后再输入数组的元素,并统计数组中元素小于0的个数。

输入、输出样例:

输入: 5

        78 12 -84 56 -34

输出:2

       

输入: 8

        8 12 -84 -156 -34 90 -16 -67

输出:5

代码实现

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


int main()
{

    int size = 0;
    int cnt = 0;
    scanf("%d", &size);
    int *num = (int*)malloc(size*sizeof(int));
    for(int i = 0; i < size; i++){
        scanf("%d", &num[i]);
    }

    for(int i = 0; i < size; i++){
        if(num[i] < 0){
            cnt++;
        }
    }
    printf("%d", cnt);
    free(num);
    num = NULL;
    return 0; 

}

测试结果

总结

以上就是本文的全部内容了,欢迎指正。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
海尔高级Java面试题主要考察Java基础、多线程、集合、IO、反射等知识点。以下是部分题目及答案整理: 1、Java中的四种引用类型分别是什么,有什么区别? 答:Java中的四种引用类型分别是强引用、软引用、弱引用和虚引用。它们的主要区别在于对对象的引用强度不同。强引用是最常见的引用方式,它能够直接引用对象,只有在没有任何引用的情况下才会被垃圾回收器回收。软引用和弱引用都比强引用弱,但是又有所不同。软引用在系统要发生内存溢出之前会被回收,弱引用则更弱,只要发现就会被回收,虚引用最弱,它的存在不会对对象的生命周期造成任何影响,主要用于跟踪对象被垃圾回收的状态。 2、请简述Java内存模型,并解释volatile关键字的作用。 答:Java内存模型可以看成一个虚拟的概念模型,主要包括线程工作内存和主内存两个部分。线程工作内存是线程独立的内存空间,主内存是被所有线程共享的内存空间。volatile关键字可以保证线程之间对变量的可见性,即一个线程修改了volatile变量,其他线程能够立即看到这个变量的改变,而在Java的内存模型中,由于线程之间的数据交互是通过主内存来完成的,所以volatile变量修改后会立即被更新到主内存中,其他线程能够立即看到最新变量。 3、请解释HashMap的实现原理。 答:HashMap是一种散列表,它包含一个数组和一些列链表。散列表的存储结构是一个数组,数组中每一个元素称为桶(Bucket),桶是一个链表结构,表示一组映射到相同桶的键值对。HashMap的实现原理是通过hashCode算法将键值对映射为数组的下标,然后将键值对存储在桶中。如果两个键映射到同一个桶中,那么它们会以链表的方式存储在桶中。当查找一个键值对时,HashMap会根据键的hashCode值计算出它存储的桶的下标,然后在该桶中查找对应的键值对。如果桶中存在多个键值对,则需要遍历链表,查找对应的键值对。 除了以上题目,海尔高级Java面试题还包括Java注解、类加载器、反射等主题,需要面试者充分掌握Java基础知识,具备实战经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

门牙会稍息

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

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

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

打赏作者

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

抵扣说明:

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

余额充值