我用c语言把何同学的代码跑起来了

简介: 我用c语言把何同学的代码跑起来了

原版代码


首先,先来看下视频中何同学的这两段代码:


0e60ca1206da4e07a4275d97759cedff.png17a551f7b3204eb0852b56286733f3af.png


代码分析


首先呢,根据图片中的这两段代码,我猜测他可能是想获取数组中第0,1,5,6,10,51,56,58,64号下标的值。


了解到这个目的后,就可以根据这个需求进行代码编写了。


 forceCon[whichKey - 1] = force
void littleFingerForce(void) {
  powerCon(1 | 2 | 6 | 7 | 11 | 52 | 57 | 58 | 65, 10);
}


代码实现


  • 这段代码是根据B站up主:内田补水彩 的视频实现的
  • c++实现:可看B站up主:摸鱼摸摸鱼鱼
#include <stdio.h>
#include <stdlib.h>
#define u8 unsigned char
#define forceConLength 128               //数组长度
u8 forceCon[forceConLength] = {0};       //SaiBoDingZhen数组
u8 forceCon_tmp[forceConLength] = {0};  //临时缓存数组
u8 indextable[forceConLength] = {0};    //索引数组
u8 r = 0;
u8 q = 0, p = 0, cnt = 0;
/* 从字符串中提取数组,并包含数字索引信息 
  函数返回值作为powerCon函数输入值
*/
int string2nums(char *nums) {
  while(1) {
    while(nums[r] && (nums[r] < '0' || nums[r] > '9')) {
      r++;
    }
    if(nums[r]) {
      p  = r;
      q = r + 1;
      indextable[cnt] = nums[r] - '0';
      while(nums[q] >= '0' && nums[q] <= '9') {
        indextable[cnt] = 10 * indextable[cnt] + (nums[q] - '0');
        q++;
      }
      r = q;
      cnt++;
    } else {
      break;
    }
  }
  return 0;
}
void powerCon(u8 whichKey, u8 force) {
  if(whichKey) 
    forceCon[whichKey - 1] = force;
  else 
    for(u8 i = 0; i < 68; i++)
      forceCon[i] = force;
}
#define powerCon(nums, force) powerCon(string2nums(#nums), force)
void littleFingerForce(void) {
  powerCon(1 | 2 | 6 | 7 | 11 | 52 | 57 | 58 | 65, 10);
}
int main() {
  printf("I am SaiBoDingZhen!\n");
  littleFingerForce();
  /* 向索引位置赋值,其他位置为0 */
  for(u8 k = 0; k < cnt; k++) {
    forceCon_tmp[indextable[k]] = forceCon[indextable[k]];
  }
  /* 向原数组赋值,并打印输出 */
  for(u8 j = 0; j < forceConLength; j++) {
    forceCon[j] = forceCon_tmp[j];
    printf("%d -> %d\n", j, forceCon[j]);
  }
  system("pause");
}

代码执行结果


可以看出,数组的第0,1,5,6,10,51,56,58,64号位置输出结果为10,其他位置为0。


fe65707a1c09452ca9f26ab9b09597a3.png

相关文章
|
4月前
|
存储 安全 数据管理
C语言之考勤模拟系统平台(千行代码)
C语言之考勤模拟系统平台(千行代码)
84 4
|
7月前
|
NoSQL 编译器 程序员
【C语言】揭秘GCC:从平凡到卓越的编译艺术,一场代码与效率的激情碰撞,探索那些不为人知的秘密武器,让你的程序瞬间提速百倍!
【8月更文挑战第20天】GCC,GNU Compiler Collection,是GNU项目中的开源编译器集合,支持C、C++等多种语言。作为C语言程序员的重要工具,GCC具备跨平台性、高度可配置性及丰富的优化选项等特点。通过简单示例,如编译“Hello, GCC!”程序 (`gcc -o hello hello.c`),展示了GCC的基础用法及不同优化级别(`-O0`, `-O1`, `-O3`)对性能的影响。GCC还支持生成调试信息(`-g`),便于使用GDB等工具进行调试。尽管有如Microsoft Visual C++、Clang等竞品,GCC仍因其灵活性和强大的功能被广泛采用。
190 1
|
3月前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
4月前
|
存储 安全 物联网
C语言物联网开发之设备安全与代码可靠性隐患
物联网设备的C语言代码安全与可靠性至关重要。一是防范代码安全漏洞,包括缓冲区溢出和代码注入风险,通过使用安全函数和严格输入验证来预防。二是提高代码跨平台兼容性,利用`stdint.h`定义统一的数据类型,并通过硬件接口抽象与适配减少平台间的差异,确保程序稳定运行。
77 10
|
4月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
102 1
|
5月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
5月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
5月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
6月前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
92 4
|
6月前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
837 6