IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 嵌入式软件工程师-第二阶段ARM裸机全集 -> 正文阅读

[嵌入式]嵌入式软件工程师-第二阶段ARM裸机全集

分析

选择物品放入背包时每个物品只有两种选择情况即放入与不放入,所以在n个物品的情况下采用最暴力手段解决时最坏时间复杂度应为2的n次方。

解决

假如物品数量为3,编号分别为1、2、3则情况无非如下8种(0表示不放入背包,1表示放入背包):

1    0 0 0 * 
2    1 0 0 * 
3    0 1 0
4    0 0 1
5    1 1 0 * 
6    1 0 1
7    0 1 1
8    1 1 1 * 

第1行为三个0的全排列,所以只有1种情况;
第2~4行为仅含有一个1的全排列;
第5~7行为含有两个1的全排列;
第8行为三个1的全排列。

由此,很自然的想到对深度递归全排列的方法进行升级改进以求解。

不过我总感觉应该有更简洁更直观的暴力手段来求解背包问题,而且总感觉上面写的分析和下面的解决好像其实不是同一个方法,但是自己又说不出个所以然来。
唉,没办法,自己实在是太菜了,就希望先作为随笔记录下来期待未来有一天待自己强大了再回头来看看吧。加油!!!

代码如下:

#include<bits/stdc++.h>
using namespace std;

const int N = 510;
int n, V;
int e[N], v[N], w[N], path[N];
int st[N], res = 0;

void dfs(int u){
    if(u == n + 1){
        int sum_v = 0, sum_w = 0;
        for(int i=1; i<=n; i++){
            sum_v += path[i] * v[i];
            sum_w += path[i] * w[i];
            // printf("%d ", path[i]);
        }
        puts("");
        if(sum_v <= V) res = max(sum_w, res);
        return;
    }

    for(int i=1; i<=n; i++){
        if(!st[i]){
            path[u] = e[i];
            st[i] = true;
            dfs(u + 1);
            st[i] = false;
        }
    }
}

int main(){
    freopen("0-1背包问题.txt", "r", stdin);
    scanf("%d%d", &n, &V);
    for(int i=1; i<=n; i++){
        scanf("%d%d", v+i, w+i);
    }

    for(int i=1; i<=n; i++){
        e[i] = 1;
        dfs(1);
    }
    cout << res << endl;
    return 0;
}
/*
测试样例
输入:
4 5
1 2
2 4
3 4
4 5
输出:
8
*/

——/嵌入式第2阶段/
├──1.1.ARM那些你得知道的事儿-ARM裸机开篇部分(ID-3584).7z 1.22G
├──1.10.SD卡启动详解-ARM裸机第十部分(ID-4291).7z 945.56M
├──1.11.NandFlash和iNand-ARM裸机第十一部分(ID-4355).7z 1.16G
├──1.12.I2C通信详解-ARM裸机第十二部分(ID-4379).7z 923.58M
├──1.13.ADC-ARM裸机第十三部分(ID-4427).7z 596.84M
├──1.14.LCD显示器实战-ARM裸机第十四部分(ID-4472).7z 1.74G
├──1.15.触摸屏TouchScreen-ARM裸机第十五部分(ID-4485).7z 556.16M
├──1.16.shell原理和问答机制引入-ARM裸机第十六部分(ID-4498).7z 1.60G
├──1.2.ARM体系结构与汇编指令-ARM裸机第二部分(ID-3635).7z 2.53G
├──1.3.开发板、原理图和数据手册-.ARM裸机第三部分(ID-3727).7z 1.44G
├──1.4.GPIO和LED-ARM裸机第四部分视频课程(ID-3767).7z 1.90G
├──1.5.SDRAM和重定位relocate-ARM裸机第五部分(ID-3860).7z 1.92G
├──1.6.S5PV210的时钟系统-ARM裸机第六部分(ID-4092).7z 973.14M
├──1.7.串口通信详解-ARM裸机第七部分(ID-4135).7z 1.74G
├──1.8.按键和CPU的中断系统-ARM裸机第八部分(ID-4167).7z 1.66G
└──1.9.定时器、看门狗和RTC-ARM裸机第九部分(ID-4235).7z 1.31G

下载地址:https://www.feimaoke.com/9851.html

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2021-07-29 11:48:50  更:2021-07-29 11:50:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/1 7:08:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码