当前位置: 首页 > news >正文

笔面试编程题总结

8/6诺瓦星云

修改程序

void point(int *p){*p = p[2];};
int main() {int c[] ={1,2,3,4,5},*p = c;point(p+1);for(;p <c+5;){printf("%d",*p++);}return 0;
}

1、分隔字符串 strtok

在这里插入图片描述

//c语言
#include <stdio.h>
#include <string.h>// 函数声明
char* findLongestWord(char* str);int main() {char* str = "This is a test string";char* longestWord = findLongestWord(str);if (longestWord != NULL) {printf("The longest word is: %s\n", longestWord);} else {printf("No words found in the string.\n");}return 0;
}// 函数定义
char* findLongestWord(char* str) {if (str == NULL) return NULL; // 检查输入字符串是否为空//分隔char *token;char *tokens[100]; // 假设最多分割出100个子字符串int i = 0;char delimiters[] = " "; // 定义分隔符// 复制输入字符串,因为strtok会修改原字符串char *strCopy = strdup(str);// 用strtok分割字符串,要分割的字符串,第一次调用时传入需要分割的字符串,之后传入 NULLtoken = strtok(strCopy, delimiters);while (token != NULL) {tokens[i++] = token; // 保存分割后的子字符串token = strtok(NULL, delimiters); // 继续获取下一个子字符串}// 打印分割后的结果int max = -1;char* longestWord = NULL; // 指向最长单词的指针for (int j = 0; j < i; j++) {//printf("%s\n", tokens[j]);int len_tmp = strlen(tokens[j]);if(len_tmp>max){max = len_tmp;longestWord = tokens[j];}}// 释放复制的字符串free(strCopy);return longestWord;
}

2、后缀法解 最长无重复子串

//C 最长无重复子串
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//得到字符串最长的无重复的前缀长度
int longestlen(char * p)
{int hash[256];int len = 0;memset(hash,0,sizeof(hash));while (*p && !hash[*p]){hash[*p] = 1;++ len;++ p;}return len;
}//使用后缀数组解法
int max_unique_substring4(char * str)
{int maxlen = -1;int begin = 0;char *a[99999];int n = 0;while(*str != '\0'){a[n++] = str++;}for (int i=0; i<n; i++){int temlen = longestlen(a[i]);if (temlen > maxlen){maxlen = temlen;begin = i;}}printf("%.*s\n", maxlen, a[begin]);return maxlen;
}
int main() {char *test_str = "abcabcbb";printf("Length of the longest substring without repeating characters: %s\n", max_unique_substring4(test_str));return 0;
}

3、双向链表

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>// 定义链表节点结构体
typedef struct list_node_t {struct list_node_t *p_before;  // 上一级节点struct list_node_t *p_next;    // 下一级节点void *p_data;                  // 存储数据节点uint32_t data_size;            // 存储数据大小
} list_node_t;// 插入数据到链表尾部
int insert_data_to_list(void *p_list_head, const void *data, uint32_t data_size) {if (!p_list_head || !data) {return -2; // 传入指针为空错误}// 创建新节点list_node_t *new_node = (list_node_t *)malloc(sizeof(list_node_t));if (!new_node) {return -1; // 内存申请错误}new_node->p_data = malloc(data_size);if (!new_node->p_data) {free(new_node);return -1; // 内存申请错误}memcpy(new_node->p_data, data, data_size);new_node->data_size = data_size;new_node->p_before = NULL;new_node->p_next = NULL;// 找到链表尾部list_node_t *current = (list_node_t *)p_list_head;while (current->p_next) {current = current->p_next;}// 插入新节点到尾部current->p_next = new_node;new_node->p_before = current;return 0; // 正确
}// 从链表中删除节点并释放空间
int delete_list_node(void *p_node) {if (!p_node) {return -2; // 传入指针为空错误}list_node_t *node = (list_node_t *)p_node;// 重新连接链表if (node->p_before) {node->p_before->p_next = node->p_next;}if (node->p_next) {node->p_next->p_before = node->p_before;}// 释放节点数据和节点本身free(node->p_data);free(node);return 0; // 正确
}// 示例用法
int main() {list_node_t head = {NULL, NULL, NULL, 0}; // 初始化链表头部int data1 = 100;int data2 = 20;insert_data_to_list(&head, &data1, sizeof(data1));insert_data_to_list(&head, &data2, sizeof(data2));// 遍历链表并打印数据list_node_t *current = head.p_next;while (current) {printf("%d\n", *(int *)current->p_data);current = current->p_next;}// 删除所有节点current = head.p_next;while (current) {list_node_t *next = current->p_next;delete_list_node(current);current = next;}return 0;
}

4、背包问题

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <string.h>// 定义链表节点结构体
typedef struct list_node_t {struct list_node_t *p_before;  // 上一级节点struct list_node_t *p_next;    // 下一级节点void *p_data;                  // 存储数据节点uint32_t data_size;            // 存储数据大小
} list_node_t;// 插入数据到链表尾部
int insert_data_to_list(void *p_list_head, const void *data, uint32_t data_size) {if (!p_list_head || !data) {return -2; // 传入指针为空错误}// 创建新节点list_node_t *new_node = (list_node_t *)malloc(sizeof(list_node_t));if (!new_node) {return -1; // 内存申请错误}new_node->p_data = malloc(data_size);if (!new_node->p_data) {free(new_node);return -1; // 内存申请错误}memcpy(new_node->p_data, data, data_size);new_node->data_size = data_size;new_node->p_before = NULL;new_node->p_next = NULL;// 找到链表尾部list_node_t *current = (list_node_t *)p_list_head;while (current->p_next) {current = current->p_next;}// 插入新节点到尾部current->p_next = new_node;new_node->p_before = current;return 0; // 正确
}// 从链表中删除节点并释放空间
int delete_list_node(void *p_node) {if (!p_node) {return -2; // 传入指针为空错误}list_node_t *node = (list_node_t *)p_node;// 重新连接链表if (node->p_before) {node->p_before->p_next = node->p_next;}if (node->p_next) {node->p_next->p_before = node->p_before;}// 释放节点数据和节点本身free(node->p_data);free(node);return 0; // 正确
}// 示例用法
int main() {list_node_t head = {NULL, NULL, NULL, 0}; // 初始化链表头部int data1 = 100;int data2 = 20;insert_data_to_list(&head, &data1, sizeof(data1));insert_data_to_list(&head, &data2, sizeof(data2));// 遍历链表并打印数据list_node_t *current = head.p_next;while (current) {printf("%d\n", *(int *)current->p_data);current = current->p_next;}// 删除所有节点current = head.p_next;while (current) {list_node_t *next = current->p_next;delete_list_node(current);current = next;}return 0;
}

相关文章:

笔面试编程题总结

8/6诺瓦星云 修改程序 void point(int *p){*p p[2];}; int main() {int c[] {1,2,3,4,5},*p c;point(p1);for(;p <c5;){printf("%d",*p);}return 0; }1、分隔字符串 strtok //c语言 #include <stdio.h> #include <string.h>// 函数声明 char* fin…...

[other][知识]八大行星的英文各是什么?

1、水星英文名 Mercury&#xff0c;水星最接近太阳&#xff0c;是太阳系中体积和质量最小的行星&#xff1b; 2、金星英文名 Venus&#xff0c;太阳系中第六大行星&#xff0c;太阳系中温度最高的行星&#xff0c;中国古代称之为太白或太白金星&#xff1b; 3、地球英文 E…...

如何使用 AWS CLI 创建和运行 EMR 集群

为初学者提供清晰易懂的教程 为初学者提供清晰易懂的教程 Apache Spark 和 AWS EMR 上的 Spark 集群 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 欢迎来到雲闪世界。Spark 被认为是“大数据丛林之王”&#xff0c;在数据分析、机器学习、流媒体和图形…...

HDFS写入数据的流程图

1.客户端向namenode发送请求&#xff0c;请示写入数据 2.namenode接受请求后&#xff0c;判断这个用户是否有写入权限&#xff0c;如果不具备直接报错&#xff1b;如果有写入权限&#xff0c;接着判断在要写入的目录下是否已经存在这个文件&#xff0c;如果存在&#xff0c;直…...

【Material-UI】使用指南:快速入门与核心功能解析

文章目录 一、快速入门1.1 安装和导入1.2 组件的独立性 二、全局设置2.1 响应式元标签2.2 CssBaseline2.3 默认字体 三、响应式设计3.1 Grid系统 四、最佳实践4.1 组件的一致性4.2 性能优化4.3 可访问性 五、总结 Material-UI是一个功能强大且灵活的React UI框架&#xff0c;为…...

【Java 第十三篇章】MyBatis 持久化框架的介绍

一、MyBatis 的历史 MyBatis 的前身是 iBATIS&#xff0c;它最早在 2001年由 Clinton Begin 发起。iBATIS 在早期就因其简单易用和灵活的特性受到了开发者的关注。 随着时间的推移&#xff0c;iBATIS 不断发展和改进。然而&#xff0c;在 2010年&#xff0c;iBATIS 项目团队决…...

AI新应用:概要设计与详细设计自动生成解决方案

近日&#xff0c;CoCode旗下的Co-Project智能项目管理平台V4.0.0升级发布&#xff0c;新增AI生成概要设计和AI生成详细设计功能&#xff0c;大大提高了设计的效率和质量。 CoCode旗下的Co-Project智能项目管理平台 一键智绘蓝图自现 平台设计板块新增概要设计功能&#xff0c;…...

【物联网设备端开发】使用QEMU模拟ESP硬件运行ESP-IDF

目录 一&#xff0c;开发环境搭建 1.1 安装ESP-IDF 1.2 安装vscode插件 1.3 在ESP-IDF插件配置ESP-IDF开发配置 1.4 下载IOTDeviceSDK 设备端开发代码 1.5 通过ESP-IDF插件编译好镜像 1.6 构建QEMU docker镜像 1.7 使用QEMU容器运行镜像 二&#xff0c;搭建QEMU环境步…...

#子传父父传子props和emits #封装的table #vue3

#子传父&父传子props和emits #封装的table #vue3 父组件&#xff1a;emits defineEmits props 子组件&#xff1a; 子组件 <template><el-table v-bind"$attrs" ref"innerTableRef" v-loading"loading" border :data"tabl…...

尚硅谷谷粒商城项目笔记——四、使用docker安装redis【电脑CPU:AMD】

四、使用docker安装redis 注意&#xff1a; 因为电脑是AMD芯片&#xff0c;自己知识储备不够&#xff0c;无法保证和课程中用到的环境一样&#xff0c;所以环境都是自己根据适应硬件软件环境重新配置的&#xff0c;这里的虚拟机使用的是VMware。 在解决了 Docker 安装的问题之…...

Java在无人驾驶方向的就业方向

在无人驾驶领域&#xff0c;Java作为一种主流编程语言&#xff0c;尽管不是最常见的选择&#xff08;例如&#xff0c;C和Python通常更受欢迎&#xff09;&#xff0c;但它仍然有很多应用场景和就业机会。以下是一些Java在无人驾驶方向的就业方向&#xff1a; 1. 后台服务开发 …...

机器学习中的关键距离度量及其应用

引言 在当今的数据驱动世界中&#xff0c;机器学习算法扮演着至关重要的角色&#xff0c;它们在图像分类、面部识别、在线内容审核、零售目录优化和推荐系统等多个领域发挥着重要作用。这些算法的核心在于它们能够识别和利用数据之间的相似性。而实现这一点的关键&#xff0c;…...

Redis中缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题

目录 1.什么是缓存雪崩1.1 导致雪崩的原因1.2 如何解决 2.什么是缓存穿透2.1 导致穿透的原因2.2 如何解决 3.什么是缓存预热3.1 如何解决 4.什么是缓存降级4.1 缓存降级的目的4.2 解决方案4.3 服务降级的目的 5.缓存更新 1.什么是缓存雪崩 就是存储在缓存里面的大量数据&#…...

【C++】vector 的模拟实现

&#x1f4e2;博客主页&#xff1a;https://blog.csdn.net/2301_779549673 &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01; &#x1f4e2;本文由 JohnKi 原创&#xff0c;首发于 CSDN&#x1f649; &#x1f4e2;未来很长&#…...

【C++】模版详解

1、概念 C模版分两类&#xff1a;函数模版和类模版 1&#xff09;函数模板的格式 template <class 形参名&#xff0c;class 形参名&#xff0c;......> 返回类型 函数名(参数列表) {函数体 }例如&#xff1a; template <class T> void swap(T& a, T& b…...

应用商店故障(UOS系统)

应用商店故障&#xff08;UOS系统&#xff09; 1. 安装应用商店内的应用无法下载&#xff0c;更新系统时提示依赖关系被破坏&#xff0c;怎么办&#xff1f; 问题描述 安装应用商店内的应用无法下载&#xff0c;更新系统时均提示依赖关系被破坏 解决方案 1、可先建议用户尝试修…...

8月8号前端日报:web在线进行eps32固件升级

最近几天在开发固件更新的功能&#xff0c;学习了不少相关的知识。 在arduino中对esp32进行固件更新&#xff0c;本质是使用esp官方的esptool&#xff0c;使用一个python exe程序&#xff0c;执行一段脚本&#xff0c;该脚本会将固件文件按照对应的位置来写入到esp芯片中。一共…...

win7安装python3.10

到这下载 PythonWin7/3.10.1 at master adang1345/PythonWin7 GitHub...

【Liunx】线程与进程的经典面试题总结

在这个浮躁的时代 只有自律的人才能脱颖而出 -- 《觉醒年代》 线程与进程的面试题总结 1 简述什么是LWP2 简述LWP与pthread_create创建的线程之间的关系3 简述轻量级进程ID与进程ID之间的区别4 请简述什么是线程互斥&#xff0c;为什么需要互斥5 简述你了解的进程间通信方式…...

Python中的 `break` 语句:掌握循环控制的艺术

Python中的 break 语句&#xff1a;掌握循环控制的艺术 下滑即可查看博客内容 &#x1f308; 欢迎莅临我的个人主页 &#x1f448;这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地&#xff01;&#x1f387; &#x1f393; 博主简介&#xff1a;985高校的普通本硕…...

业务系统对接大模型的基础方案:架构设计与关键步骤

业务系统对接大模型&#xff1a;架构设计与关键步骤 在当今数字化转型的浪潮中&#xff0c;大语言模型&#xff08;LLM&#xff09;已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中&#xff0c;不仅可以优化用户体验&#xff0c;还能为业务决策提供…...

大数据学习栈记——Neo4j的安装与使用

本文介绍图数据库Neofj的安装与使用&#xff0c;操作系统&#xff1a;Ubuntu24.04&#xff0c;Neofj版本&#xff1a;2025.04.0。 Apt安装 Neofj可以进行官网安装&#xff1a;Neo4j Deployment Center - Graph Database & Analytics 我这里安装是添加软件源的方法 最新版…...

python/java环境配置

环境变量放一起 python&#xff1a; 1.首先下载Python Python下载地址&#xff1a;Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个&#xff0c;然后自定义&#xff0c;全选 可以把前4个选上 3.环境配置 1&#xff09;搜高级系统设置 2…...

服务器硬防的应用场景都有哪些?

服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式&#xff0c;避免服务器受到各种恶意攻击和网络威胁&#xff0c;那么&#xff0c;服务器硬防通常都会应用在哪些场景当中呢&#xff1f; 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(一)

宇树机器人多姿态起立控制强化学习框架论文解析 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架&#xff08;一&#xff09; 论文解读&#xff1a;交大&港大&上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化…...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)

UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中&#xff0c;UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化&#xf…...

DeepSeek 技术赋能无人农场协同作业:用 AI 重构农田管理 “神经网”

目录 一、引言二、DeepSeek 技术大揭秘2.1 核心架构解析2.2 关键技术剖析 三、智能农业无人农场协同作业现状3.1 发展现状概述3.2 协同作业模式介绍 四、DeepSeek 的 “农场奇妙游”4.1 数据处理与分析4.2 作物生长监测与预测4.3 病虫害防治4.4 农机协同作业调度 五、实际案例大…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解

在 C/C 编程的编译和链接过程中&#xff0c;附加包含目录、附加库目录和附加依赖项是三个至关重要的设置&#xff0c;它们相互配合&#xff0c;确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中&#xff0c;这些概念容易让人混淆&#xff0c;但深入理解它们的作用和联…...

Redis:现代应用开发的高效内存数据存储利器

一、Redis的起源与发展 Redis最初由意大利程序员Salvatore Sanfilippo在2009年开发&#xff0c;其初衷是为了满足他自己的一个项目需求&#xff0c;即需要一个高性能的键值存储系统来解决传统数据库在高并发场景下的性能瓶颈。随着项目的开源&#xff0c;Redis凭借其简单易用、…...

作为测试我们应该关注redis哪些方面

1、功能测试 数据结构操作&#xff1a;验证字符串、列表、哈希、集合和有序的基本操作是否正确 持久化&#xff1a;测试aof和aof持久化机制&#xff0c;确保数据在开启后正确恢复。 事务&#xff1a;检查事务的原子性和回滚机制。 发布订阅&#xff1a;确保消息正确传递。 2、性…...