news 2026/6/4 22:40:32

12.16 - 全排列 C语言中声明和定义的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
12.16 - 全排列 C语言中声明和定义的区别

目录

1.全排列

a.核心思想

b.思路

c.步骤

2.C语言中声明和定义的区别

a.核心区别

b.场景对比

c.关键规则

d.特殊情况


1.全排列

46. 全排列 - 力扣(LeetCode)https://leetcode.cn/problems/permutations/

class Solution { public: // 回溯算法核心实现 // start - 当前处理的起始位置 void backtrack(vector<int>& nums, int start, vector<vector<int>>& rev) { if (start == nums.size()) { rev.push_back(nums); return; } // 遍历从start到数组末尾的所有元素 for(int i = start; i < nums.size(); i++) { swap(nums[start], nums[i]); backtrack(nums, start+1, rev); swap(nums[start], nums[i]); } } vector<vector<int>> permute(vector<int>& nums) { vector<vector<int>> revv; backtrack(nums, 0, revv); return revv; } };

a.核心思想

利用回溯算法,通过递归的方式生成所有可能的排列,在递归过程中通过交换元素的位置来生成不同的排列,当处理到数组末尾时,将当前排列加入结果集。

b.思路

回溯法是一种通过探索所有可能的候选解来找出所有解的算法。如果候选解被确认不是一个解(或者至少不是最后一个解),回溯算法会通过在上一步进行一些变化来丢弃该解,即“回溯”并尝试其他可能性。

c.步骤

① 定义一个递归函数,用于生成排列。

② 在递归函数中,从当前位置开始,依次将每个元素交换到当前位置。

③ 递归处理下一个位置。

④ 当处理到数组末尾时,将当前排列加入结果集。

⑤ 回溯,恢复数组原来的状态,以便进行下一次交换。

2.C语言中声明和定义的区别

a.核心区别

声明:告知编译器标识符(变量/函数/类型)的存在及类型,不分配内存。可多次出现(如头文件中的extern声明)。

  • 示例:extern int a;(变量声明)、int func(int, int);(函数声明)。

定义:分配内存并创建实体,可包含初始化(变量)或具体实现(函数)。同一作用域只能定义一次。

  • 示例:int a = 10;(变量定义)、int func() { return 0; }(函数定义)。

b.场景对比

类型

声明

定义

变量

extern int global;(不分配内存)

int global = 0;(分配内存+初始化)

函数

double add(double, double);

double add(double a, double b) { return a+b; }

结构体

struct Point;(不完整类型声明)

struct Point { int x, y; };(完整类型定义)

数组

extern int arr[10];

int arr[10] = {0};

c.关键规则

唯一性:定义只能出现一次(如全局变量、函数体),声明可多次(如头文件中的extern)。

内存分配:定义必然分配内存,声明不分配(除非定义时隐含声明)。

初始化:带初始化的变量声明(如int a=5;)本质是定义;extern声明不可初始化。

头文件作用:头文件通常存放声明(函数原型、extern变量),源文件存放定义(函数实现、变量初始化)。

d.特殊情况

结构体/联合体:声明(如struct S;)需后续定义才能使用成员;定义(如struct S { int x; };)直接创建完整类型。

匿名结构体:struct { int x; } var;同时完成声明与定义,无法复用类型。

函数参数:形参列表中的变量名仅是声明(如void func(int a);),不分配内存。

希望这些内容对大家有所帮助!

感谢大家的三连支持!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 1:05:31

人人都在谈大模型,但90%的企业AI转型,都死在了数据这一关

从CEO到一线员工&#xff0c;几乎所有人都在热烈地讨论着大模型的最新进展和各种眼花缭乱的AI应用。我们仿佛进入了一个模型为王的时代&#xff0c;似乎只要接入最强的模型&#xff0c;就能解决所有问题。但现实是残酷的。 为什么很多企业AI项目总是做不出来&#xff1f; 我们也…

作者头像 李华
网站建设 2026/6/5 21:58:12

机器学习--线性回归

1、线性回归定义线性回归是利用数理统计中回归分析&#xff0c;来确定两种或两种以上变量间相互依赖的定量关系的一种统计分析方法。相关关系:包含因果关系和平行关系因果关系:回归分析【原因引起结果&#xff0c;需要明确自变量和因变量平行关系:相关分析【无因果关系&#xf…

作者头像 李华
网站建设 2026/6/5 6:28:52

LobeChat系统稳定性承诺书

LobeChat系统稳定性与架构深度解析 在生成式AI迅猛发展的今天&#xff0c;大语言模型&#xff08;LLMs&#xff09;早已不再是研究实验室里的“黑箱”&#xff0c;而是逐步走进千家万户的生产力工具。然而&#xff0c;一个常被忽视的问题是&#xff1a;再强大的模型&#xff0…

作者头像 李华
网站建设 2026/6/4 16:57:36

代码之恋(第十二篇:公开的合并与意外的提交)

周一的 办公室&#xff0c;晨光刚漫过工位隔板&#xff0c;咖啡机还在 “咕嘟咕嘟” 预热&#xff0c;空气里飘着速溶咖啡和隔夜外卖的混合气味 —— 典型的 “节后重启失败” 现场。李磊站在电梯口等艾丽&#xff0c;指尖无意识地摩挲着手机壳边缘&#xff0c;心里像跑着十个异…

作者头像 李华
网站建设 2026/6/5 14:30:24

基于89C51单片机的交通灯控制系统设计

基于89C51单片机的交通灯控制系统设计 第一章 系统概述 传统十字路口交通灯多采用固定时序电路&#xff0c;存在时序不可调、无法响应实时交通变化的问题&#xff0c;易在早晚高峰引发拥堵。基于89C51单片机的交通灯控制系统&#xff0c;以低成本、高可靠性的89C51为核心&#…

作者头像 李华