定义一个方法实现功能

定义一个方法实现功能:

【键盘上输入原始的学号(一行字符),将字符加上前缀“2211”,再进行输出的功能】

进阶-如果调用一次方法可以实现,则可以改写为循环5次,分别输入和输出。

img

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

#define PREFIX "2211"

int main() {
    char student_id[100];
    printf("请输入原始的学号:");
    scanf("%s", student_id);

    // 将原始学号和前缀合并
    char new_id[100];
    strcpy(new_id, PREFIX);
    strcat(new_id, student_id);

    printf("新的学号为:%s\n", new_id);
    return 0;
}


不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 这有个类似的问题, 你可以参考下: https://ask.csdn.net/questions/269653
  • 你也可以参考下这篇文章:2022Java学习笔记七十四(异常处理:编译时异常的处理机制、异常处理方式、运行时异常处理、自定义异常)
  • 除此之外, 这篇博客: 修改寄存器的位操作方法中的 二、把变量的某几个连续位清零 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

    由于寄存器中有时会有连续几个寄存器位用于控制某个功能,现假设我们需要把寄存器的某几个连续位清零,且其它位不变,方法如下

    若把 a 中的二进制位分成 2 个一组
    即 bit0、bit1 为第 0 组,bit2、bit3 为第 1 组,
    bit4、bit5 为第 2 组,bit6、bit7 为第 3 组

    要对第 1 组的 bit2、bit3 清零

    a &= ~(3<<2*1);
    

    括号中的 3 左移两位,(3<<2*1) 得二进制数:0000 1100 b
    按位取反,~(3<<2*1) 得 1111 0011 b
    假如 a 中原来的值为二进制数: a = 1001 1111 b
    所得的数与 a 作”位与&”运算,a = (1001 1111 b)&(1111 0011 b),
    经过运算后,a 的值 a=1001 0011 b
    a 的第 1 组的 bit2、bit3 被清零,而其它位不变。
    上述 (~(3<<2*1)) 中的 (1) 即为组编号; 如清零第 3 组 bit6、bit7 此处应为 3
    括号中的 (2) 为每组的位数,每组有 2 个二进制位; 若分成 4 个一组,此处即为 4
    括号中的 (3) 是组内所有位都为 1 时的值; 若分成 4 个一组,此处即为二进制数“1111 b”
    例如对第 2 组 bit4、bit5 清零

    a &= ~(3<<2*2)
    
  • 您还可以看一下 2017CCTC大会老师的【微服务专场】实施微服务架构的关键技术课程中的 实施微服务架构的关键技术小节, 巩固相关知识点

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^