算法-全排列

1、全排列函數的使用

舉例:{1,2,3}的全排列

#include<iostream>
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(){ll a[3] = {1, 2, 3};do{for (ll i = 0; i < 3;i++){cout << a[i] << " ";}cout << endl;} while (next_permutation(a, a + 3));
}

2、算法題應用

B-小苯購物_牛客周賽 Round 94

題目描述:?給我們3個優惠券,每個優惠券存在兩個參數a,b。表示只有商品價格大于a元的時候我們才可以優惠b元。每種商品我們可以選或者不選。給出一開始商品的價格n,問最終n的最小值為多少?

本題思路:

  1. b都是大于0的,如果可以選擇優惠我們選就比不選好。
  2. 但是這樣就會存在一些問題,選擇優惠之后可能商品的價格會變低,影響后面商品優惠的選擇,說明這個又和優惠券的選擇順序有關。
  3. 本題只存在3個優惠券,我們枚舉出所有選擇的全排列進行依次比較即可,這樣以來我們就可以考慮到所有的選擇情況了。
#include<iostream>
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n; // 商品初始價格
ll a[3], b[3]; // 三個優惠券的參數,a[i]表示優惠閾值,b[i]表示優惠金額
// 函數f,用于計算在特定優惠券選擇順序下的最終價格
ll f(ll i, ll j, ll k) {ll m = n; // 初始化當前價格為初始價格n// 檢查第一個優惠券是否可用,如果可用則應用優惠if (a[i] <= m) m -= b[i];// 檢查第二個優惠券是否可用,如果可用則應用優惠if (a[j] <= m) m -= b[j];// 檢查第三個優惠券是否可用,如果可用則應用優惠if (a[k] <= m) m -= b[k];// 如果最終價格小于0,則設置為0if (m < 0) m = 0;return m; // 返回最終價格
}
void solve() {cin >> n; // 讀取商品初始價格n// 讀取三個優惠券的參數for (ll i = 0; i < 3; i++) {cin >> a[i] >> b[i];}ll mx = n; // 初始化最小價格為初始價格nll c[3] = {0, 1, 2}; // 優惠券選擇順序的初始排列// 遍歷所有可能的優惠券選擇順序do {ll v = f(c[0], c[1], c[2]); // 計算當前順序下的最終價格// 如果當前最終價格小于當前最小價格,則更新最小價格if (v < mx) {mx = v;}} while (next_permutation(c, c + 3)); // 生成下一個排列cout << mx << endl; // 輸出最小價格
}
int main() {ll t;cin >> t;while (t--) { solve(); }
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/82720.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/82720.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/82720.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

面試加分秘籍:校招數據傾斜場景下的SQL優化方案

校招面試經常會問大家有沒有過調優的經驗&#xff0c;相信大家的回答基本都是往數據傾斜和小文件問題這兩方面回答&#xff0c;對于數據傾斜相信大部分同學對熱key打散或null值引發的傾斜已經非常熟悉&#xff0c;但這些內容面試官也是聽膩了&#xff0c;希望大家在面試時候講一…

Elasticsearch索引機制與Lucene段合并策略深度解析

引言 在現代分布式搜索引擎Elasticsearch中&#xff0c;文檔的索引、更新和刪除操作不僅是用戶交互的核心入口&#xff0c;更是底層存儲架構設計的關鍵挑戰。本文圍繞以下核心鏈路展開&#xff1a; 文檔生命周期管理&#xff1a;從客戶端請求路由到分片定位&#xff0c;從內存…

git提交更改

第一步&#xff1a;添加改動 git add . 第二步&#xff1a;提交改動 git commit -m “替換了 SerialPort 庫文件” 第三步&#xff1a;推送到遠程 git push 為什么git 的UI界面做的遠不如SVN

WPF的基礎控件:布局控件(StackPanel DockPanel)

布局控件&#xff08;StackPanel & DockPanel&#xff09; 1 StackPanel的Orientation屬性2 DockPanel的LastChildFill3 嵌套布局示例4 性能優化建議5 常見問題排查 在WPF開發中&#xff0c;布局控件是構建用戶界面的基石。StackPanel和DockPanel作為兩種最基礎的布局容器&…

互聯網大廠Java求職面試:AI大模型推理服務性能優化與向量數據庫分布式檢索

互聯網大廠Java求職面試&#xff1a;AI大模型推理服務性能優化與向量數據庫分布式檢索 面試現場&#xff1a;技術總監的連環追問 技術總監&#xff1a;&#xff08;翻看著簡歷&#xff09;鄭薪苦&#xff0c;你在上一家公司參與過LLM推理服務的性能優化項目&#xff1f;說說你…

如何解決網站服務器的異常問題?

當網站服務器出現異常情況&#xff0c;導致用戶無法正常訪問網頁信息的時候&#xff0c;該如何解決這一問題呢&#xff1f;小編下面就帶領大家共同探討一下這一問題。 企業在面對網站服務器異常時&#xff0c;首先要對服務器硬件設備進行詳細的檢查&#xff0c;可以使用硬盤檢測…

Day 35

模型可視化與推理 知識點回顧&#xff1a; 三種不同的模型可視化方法&#xff1a;推薦torchinfo打印summary權重分布可視化 進度條功能&#xff1a;手動和自動寫法&#xff0c;讓打印結果更加美觀 推理的寫法&#xff1a;評估模式 模型結構可視化 理解一個深度學習網絡最重要的…

[yolov11改進系列]基于yolov11引入自注意力與卷積混合模塊ACmix提高FPS+檢測效率python源碼+訓練源碼

[ACmix的框架原理] 1.1 ACMix的基本原理 ACmix是一種混合模型&#xff0c;結合了自注意力機制和卷積運算的優勢。它的核心思想是&#xff0c;傳統卷積操作和自注意力模塊的大部分計算都可以通過1x1的卷積來實現。ACmix首先使用1x1卷積對輸入特征圖進行投影&#xff0c;生成一組…

[DS]使用 Python 庫中自帶的數據集來實現上述 50 個數據分析和數據可視化程序的示例代碼

使用 Python 庫中自帶的數據集來實現上述 50 個數據分析和數據可視化程序的示例代碼 摘要&#xff1a;由于 sample_data.csv 是一個占位符文件&#xff0c;用于代表任意數據集&#xff0c;我將使用 Python 庫中自帶的數據集來實現上述 50 個數據分析和數據可視化程序的示例代碼…

【Python 中 lambda、map、filter 和 reduce】詳細功能介紹及用法總結

以下是 Python 中 lambda、map、filter 和 reduce 的詳細功能介紹及用法總結&#xff0c;涵蓋基礎語法、高頻場景和示例代碼。 一、lambda 匿名函數 功能 用于快速定義一次性使用的匿名函數。不需要顯式命名&#xff0c;適合簡化小規模邏輯。 語法 lambda 參數1, 參數2, ..…

貪心算法——分數背包問題

一、背景介紹 給定&#x1d45b;個物品&#xff0c;第&#x1d456;個物品的重量為&#x1d464;&#x1d454;&#x1d461;[&#x1d456;?1]、價值為&#x1d463;&#x1d44e;&#x1d459;[&#x1d456;?1]&#xff0c;和一個容量為&#x1d450;&#x1d44e;&#…

《軟件工程》第 5 章 - 需求分析模型的表示

目錄 5.1需求分析與驗證 5.1.1 順序圖 5.1.2 通信圖 5.1.3 狀態圖 5.1.4 擴充機制 5.2 需求分析的過程模型 5.3 需求優先級分析 5.3.1 確定需求項優先級 5.3.2 排定用例分析的優先順序 5.4 用例分析 5.4.1 精化領域概念模型 5.4.2 設置分析類 5.4.3 構思分析類之間…

基于MATLAB的大規模MIMO信道仿真

1. 系統模型與參數設置 以下是一個單小區大規模MIMO系統的參數配置示例&#xff0c;適用于多發多收和單發單收場景。 % 參數配置 params.N_cell 1; % 小區數量&#xff08;單小區仿真&#xff09; params.cell_radius 500; % 小區半徑&#xff08;米&#xff09…

想查看或修改 MinIO 桶的匿名訪問權限(public/private/custom)

在 Ubuntu 下&#xff0c;如果你想查看或修改 MinIO 桶的匿名訪問權限&#xff08;public/private/custom&#xff09;&#xff0c;需要使用 mc anonymous 命令而不是 mc policy。以下是詳細操作指南&#xff1a; 1. 查看當前匿名訪問權限 mc anonymous get minio/test輸出示例…

HarmonyOS:相機選擇器

一、概述 相機選擇器提供相機拍照與錄制的能力。應用可選擇媒體類型實現拍照和錄制的功能。調用此類接口時&#xff0c;應用必須在界面UIAbility中調用&#xff0c;否則無法啟動cameraPicker應用。 說明 本模塊首批接口從API version 11開始支持。后續版本的新增接口&#xff0…

牛客AI簡歷篩選:提升招聘效率的智能解決方案

在競爭激烈的人才市場中&#xff0c;企業HR每天需處理海量簡歷&#xff0c;面臨篩選耗時長、標準不統一、誤判率高等痛點。牛客網推出的AI簡歷篩選工具&#xff0c;以“20分鐘處理1000份簡歷、準確率媲美真人HR”的高效表現&#xff0c;成為企業招聘的智能化利器。本文將深度解…

白楊SEO:做AI搜索優化的DeepSeek、豆包、Kimi、百度文心一言、騰訊元寶、通義、智譜、天工等AI生成內容信息采集主要來自哪?占比是多少?

大家好&#xff0c;我是白楊SEO&#xff0c;專注SEO十年以上&#xff0c;全網SEO流量實戰派&#xff0c;AI搜索優化研究者。 在開始寫之前&#xff0c;先說個抱歉。 上周在上海客戶以及線下聚會AI搜索優化分享說各大AI模型的聯網搜索是關閉的&#xff0c;最開始上來確實是的。…

QML與C++交互2

在QML與C的交互中&#xff0c;主要有兩種方式&#xff1a;在C中調用QML的方法和在QML中調用C的方法。以下是具體的實現方法。 在C中調用QML的方法 首先&#xff0c;我們需要在QML文件中定義一個函數&#xff0c;然后在C代碼中調用它。 示例 //QML main.qml文件 import QtQu…

OpenGL Chan視頻學習-8 How I Deal with Shaders in OpenGL

bilibili視頻鏈接&#xff1a; 【最好的OpenGL教程之一】https://www.bilibili.com/video/BV1MJ411u7Bc?p5&vd_source44b77bde056381262ee55e448b9b1973 函數網站&#xff1a; docs.gl 說明&#xff1a; 1.之后就不再整理具體函數了&#xff0c;網站直接翻譯會更直觀也…

動態防御新紀元:AI如何重構DDoS攻防成本格局

1. 傳統高防IP的靜態瓶頸與成本困境 傳統高防IP依賴預定義規則庫&#xff0c;面對SYN Flood、CC攻擊等威脅時&#xff0c;常因規則更新滯后導致誤封合法流量。例如&#xff0c;某電商平臺曾因靜態閾值過濾誤封20%的訂單接口流量&#xff0c;直接影響營收。以下代碼模擬傳統方案…