90. k数和 II

描述

Given n unique integers, number k (1<=k<=n) and target.

Find all possible k integers where their sum is target.

您在真实的面试中是否遇到过这个题?   是

样例

给出[1,2,3,4],k=2, target=5,返回 [[1,4],[2,3]]


思路:DFS,递归

代码:

class Solution {
public:
    /*
     * @param A: an integer array
     * @param k: a postive integer <= length(A)
     * @param target: an integer
     * @return: A list of lists of integer
     */
    vector<vector<int>> kSumII(vector<int> &A, int k, int target) {
        // write your code here
        vector<vector<int> >result;
        vector<int>temp;
        DFS(A,k,target,0,0,result,temp);
        return result;
        
    }
    void  DFS(vector<int> &A, int k, int target,int sum,int index,vector<vector<int> >&result,vector<int>&temp)
    {
        if(temp.size()==k&&sum==target)
        {
          result.push_back(temp);
          return ;
        }
        if(index==A.size()||sum>target)
        return;
        temp.push_back(A[index]);
        DFS(A,k,target,sum+A[index],index+1,result,temp);
        temp.pop_back();
        DFS(A,k,target,sum,index+1,result,temp);
        
    }
};

Wannier90是一个计算固体物理中Wannier函的程序,它可以用于生成具有特定对称性和局域性的Wannier函。Wannier90的输入文件通常被称为.winn文件,这个文件包含了计算所需的所有参和信息。对于单层MoS2(二硫化钼)这样的二维材料,生成.winn文件需要对该材料的电子结构和晶体结构有详细的了解。 一般来说,wannier90.win文件需要包括以下几个部分的关键信息: 1. 单位元和晶胞信息:这些信息用于定义晶体的结构和对称性。 2. 高对称点和高对称线:用于定义能带结构的高对称点(如Γ, K, M等)和路径。 3. 产生Wannier函的初猜:通过指定一个初始的投影函集合来产生Wannier函。 4. 优化和收敛参:设置Wannier函优化的参,如收敛的标准和步。 5. 可选的其他部分:比如k网格划分、自旋轨道耦合参等。 对于MoS2这样的材料,你需要首先有一个第一原理计算的结果,通常是密度泛函理论(DFT)计算得到的能带结构据。然后,你需要决定你想要Wannier化哪些能带,以及是否包括自旋轨道耦合等效应。 一个简化的wannier90.win文件的示例框架可能如下所示: ``` begin unit_cell_cart 3.1890000000 0.0000000000 0.0000000000 ! a1 1.5945000000 2.7735200000 0.0000000000 ! a2 0.0000000000 0.0000000000 12.9278470000 ! a3 end unit_cell_cart num_wann = 6 begin projections Mo: s; px; py; pz S: px; py; pz end projections begin kpoints Γ 0.0000000000 0.0000000000 0.0000000000 K 1.0000000000 0.0000000000 0.0000000000 ... end kpoints mp_grid = 3 3 1 dis_win_min = -3.5 dis_win_max = 3.5 num_iter = 200 postprocess = .true. ``` 请注意,上面的信息仅为示例,实际的.winn文件需要根据具体的研究目标和计算细节进行详细配置。实际编写时,还需要仔细阅读wannier90的用户手册,以确保正确设置了所有必要的参和信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值