C语言第三十四练——01背包

简介: C语言第三十四练——01背包

第三十四练 01 背包

有 N 件物品和一个容量为 V 的背包。(每种物品均只有一件)第 i 件物品的费用是 c[i],价值是 w[i]。

求解将哪些物品装入背包可使价值总和最大。

要求: 1、你需要学一下01背包基础知识2、输入整数n,接下来n行,分别数据物品的费用和价值

第三十三练答案

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include <queue>
#include <algorithm>
#include <map>
#include <iomanip>

#define INF 999999999

using namespace std;

const int MAX = 100000 + 10;
char s[MAX * 2];
int next[MAX];

void get_next(char *a, int len) {
    int i = -1, j = 0;
    next[0] = -1;
    while (j < len) {
        if (i == -1 || a[i] == a[j]) next[++j] = ++i;
        else i = next[i];
    }
}

void get_extend(char *a, int len) {
    int k = 0, i = 1;
    next[0] = len;
    while (k + 1 < len && a[k] == a[k + 1]) ++k;
    next[1] = k;
    k = 1;
    while (++i < len / 2) { // 只需要求到原串的长度即可
        int maxr = k + next[k] - 1;
        next[i] = min(next[i - k], max(maxr - i + 1, 0));
        while (i + next[i] < len && a[next[i]] == a[i + next[i]]) ++next[i];
        if (i + next[i] > k + next[k]) k = i;
    }
}

int main() {
    int t, num = 0;
    cin >> t;
    while (t--) {
        scanf("%s", s);
        int len = strlen(s);
        get_next(s, len);
        int temp = len % (len - next[len]) == 0 ? len / (len - next[len]) : 1; // 求循环节循环了几次
        for (int i = 0; i <= len; ++i) s[i + len] = s[i];
        get_extend(s, len + len);
        int a = 0, b = 0, c = 0;
        for (int i = 0; i < len; ++i) {
            if (next[i] >= len) ++b; // 表示等于原串的
            else if (s[next[i]] < s[i + next[i]]) ++c; // 表示大于原串的
            else ++a; // 表示小于原串的
        }
        cout << "Case " << ++num << ": " << a / temp << ' ' << b / temp << ' ' << c / temp << endl;
    }
    return 0;
}

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了

更多

欢迎来到C语言每日一练服务!

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

我们的服务特点包括:

  1. 日常练习题目: 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 详细解析: 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 互动学习社区: 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 个性化学习建议: 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

参与每日一练的好处:

  • 持续学习提升技能: 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 增强自信心: 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 拓宽思路: 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 为未来发展奠定基础: 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!

目录
相关文章
|
7月前
|
算法 搜索推荐 程序员
C语言第三十六练——多重背包
C语言第三十六练——多重背包
90 0
|
7月前
|
算法 搜索推荐 程序员
C语言十九练——养兔子
C语言十九练——养兔子
81 0
|
25天前
|
存储 编译器 C语言
【C语言】指针大小知多少 ?一场探寻C语言深处的冒险 !
在C语言中,指针的大小(即指针变量占用的内存大小)是由计算机的体系结构(例如32位还是64位)和编译器决定的。
49 9
|
存储 编译器 C语言
带你们偷瞄编程绕不开的C语言(三)
带你们偷瞄编程绕不开的C语言(三)
82 0
|
7月前
|
人工智能 网络协议 BI
【c语言基础题】— —第七版,可当作日常练习和期末复习,有奇效哟!
【c语言基础题】— —第七版,可当作日常练习和期末复习,有奇效哟!
|
7月前
|
算法 搜索推荐 程序员
C语言第三十五练——完全背包
C语言第三十五练——完全背包
62 0
|
7月前
|
算法 搜索推荐 程序员
C语言第二十练——鸡兔同笼问题
C语言第二十练——鸡兔同笼问题
123 0
|
7月前
|
算法 搜索推荐 程序员
C语言第二十一练——青蛙爬井
C语言第二十一练——青蛙爬井
310 0
|
7月前
|
算法 搜索推荐 程序员
C语言第三十七练——状态压缩DP
C语言第三十七练——状态压缩DP
50 0
|
7月前
|
算法 安全 搜索推荐
C语言第二十五练 中国剩余定理
C语言第二十五练 中国剩余定理
70 0