当前位置: 首页 > 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;
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 详解pd.pivot_table
  • 计算机网络——网络层(多协议标签交换MPLS、软件定义网络SDN)
  • SQL Server端口设置完整详细步骤
  • 900565Z error Failed opening bolt
  • C# 设计模式之装饰器模式
  • 在Linux中宏观的看待线程
  • leetcode17. 电话号码的字母组合,dfs深度优先搜索
  • JC/T 2436-2018 木塑家具板材检测
  • Java 中的 ArrayList 和 LinkedList 在性能上有什么不同?
  • Linux安装Java(JKD)
  • 边缘计算×AI:绘制未来实时智能的宏伟蓝图
  • 智能化的Facebook未来:AI如何重塑社交网络的面貌?
  • Docker-数据卷指令
  • 使用ThreadStatic属性提供线程安全的数据访问
  • 算法学习day30
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 【附node操作实例】redis简明入门系列—字符串类型
  • 30天自制操作系统-2
  • Asm.js的简单介绍
  • CSS盒模型深入
  • iOS高仿微信项目、阴影圆角渐变色效果、卡片动画、波浪动画、路由框架等源码...
  • laravel 用artisan创建自己的模板
  • nfs客户端进程变D,延伸linux的lock
  • Objective-C 中关联引用的概念
  • React的组件模式
  • 阿里云购买磁盘后挂载
  • 欢迎参加第二届中国游戏开发者大会
  • 可能是历史上最全的CC0版权可以免费商用的图片网站
  • 力扣(LeetCode)965
  • 两列自适应布局方案整理
  • 排序算法学习笔记
  • 批量截取pdf文件
  • 适配iPhoneX、iPhoneXs、iPhoneXs Max、iPhoneXr 屏幕尺寸及安全区域
  • 提醒我喝水chrome插件开发指南
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • # windows 运行框输入mrt提示错误:Windows 找不到文件‘mrt‘。请确定文件名是否正确后,再试一次
  • (ISPRS,2023)深度语义-视觉对齐用于zero-shot遥感图像场景分类
  • (ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY)讲解
  • (第二周)效能测试
  • (分布式缓存)Redis持久化
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (机器学习-深度学习快速入门)第三章机器学习-第二节:机器学习模型之线性回归
  • (考研湖科大教书匠计算机网络)第一章概述-第五节1:计算机网络体系结构之分层思想和举例
  • (每日一问)操作系统:常见的 Linux 指令详解
  • (十一)JAVA springboot ssm b2b2c多用户商城系统源码:服务网关Zuul高级篇
  • (转)winform之ListView
  • (转载)虚函数剖析
  • (自适应手机端)响应式服装服饰外贸企业网站模板
  • .dwp和.webpart的区别
  • .libPaths()设置包加载目录
  • .NET MAUI Sqlite数据库操作(二)异步初始化方法