4.9cf自训9..
cf401D 状态压缩dp好题,每次把新加入集合的数字放在最后即可
/*
它可以通过重新排列数字n,
它没有任何前导零,
x除以m后的余数等于0. 每次把新加的数放在最后
dp[i][j]表示状态i下模m=j的数量
dp[i|(1<<k)][j*10+a[k]]+=dp[i][j]; */
#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll len,n,m,a[];
ll dp[<<][];
int main(){
cin>>n>>m;
while(n)a[++len]=n%,n/=;
dp[][]=;
for(int i=;i<(<<len)-;i++)
for(int j=;j<m;j++)
for(int k=;k<len;k++){
if(i&(<<k))continue;
if(i==&&a[k+]==)continue;//前导0
dp[i|(<<k)][(j*+a[k+])%m]+=dp[i][j];
}
ll cnt[]={},f[]={},ans=dp[(<<len)-][];
f[]=f[]=;
for(int i=;i<=;i++)f[i]=f[i-]*i;
for(int i=;i<=len;i++)cnt[a[i]]++;
for(int i=;i<;i++)
if(cnt[i])ans/=f[cnt[i]];
cout<<ans<<endl;
}
cf959E 思维题
#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll n,ans;
ll lowbit(ll x){return x&(-x);} int main(){
cin>>n;
ll tmp=n,cnt=;
while(tmp){
ans+=tmp/*cnt;
tmp/=,cnt*=;
}
if(n==lowbit(n)){
cout<<ans<<endl;
return ;
}
while(n){
n-=lowbit(n); ans+=lowbit(n);
}
cout<<ans<<endl;return ;
}
cf598E dp好题,就是最经典的线性dp,想通了挺简单的
/*
dp[i][j][k]在i*j的方块里吃k大小的代价
*/
#include<bits/stdc++.h>
using namespace std;
int dp[][][];
int main(){
for(int i=;i<=;i++)
for(int j=;j<=;j++)
for(int k=;k<=;k++){
if(k== || k==i*j){
dp[i][j][k]=;
continue;
}
else dp[i][j][k]=;
for (int h = ; h <= k; h++){
for (int m = ; m < j; m++)
dp[i][j][k] = min(dp[i][j][k], dp[i][m][h] + dp[i][j - m][k - h] + i*i);
for (int m = ; m < i; m++)
dp[i][j][k] = min(dp[i][j][k], dp[m][j][h] + dp[i - m][j][k - h] + j*j);
}
}
int t,n,m,k;
cin>>t;
while(t--){
cin>>n>>m>>k;
cout<<dp[n][m][k]<<endl;
}
}
cf886D 字符串乱搞+判环
#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
using namespace std; string s,ans[]; int main()
{
int i,j,n,f,x,len;
int vis[],chu[],ru[],mp[][];
while(cin>>n)
{
f=;
memset(mp,,sizeof(mp)); //字符构成的图
memset(ru,-,sizeof(ru)); //每个字符的入度
memset(chu,-,sizeof(chu)); //每个字符的出度
//在下面这个循环中,chu/ru=0则说明字符出现过,chu/ru=-1则没出现过
for(i=;i<n;i++)
{
cin>>s; //输入字符串
memset(vis,,sizeof(vis)); //用于判断每个字符串中字符出现的次数
len=s.length();
vis[s[]-'a']++; //首个字符出现次数+1
ru[s[]-'a']=; //首个字符出现过
chu[s[]-'a']=; //首个字符出现过
for(j=;j<len;j++)
{ //从第 1 个字符开始建图
int u=s[j-]-'a'; //前一字符
int v=s[j]-'a'; //当前字符
mp[u][v]=;
vis[v]++;
if(vis[v]>) f=; //如果出现次数>1,则输出 NO
ru[v]=;
chu[v]=;
}
}
int next[]; //每个字符的后继字符
memset(next,-,sizeof(next));
for(i=;i<;i++)
for(j=;j<;j++)
if(mp[i][j])
{ //如果存在边
ru[j]++; //入度+1
chu[i]++; //出度+1
next[i]=j; //记录后继
}
for(i=;i<;i++)
if(ru[i]>||chu[i]>)
{ //如果有字符的出度或入度 >1则输出 NO
f=;
break;
}
for(i=;i<;i++)
{ //判断是否有环
x=i;
memset(vis,,sizeof(vis));
while(x!=next[x])
{
if(vis[x]==)
{ //如果当前元素访问过则有环
f=;
break;
}
vis[x]=;
x=next[x];
}
}
if(n> || !f)
{
cout<<"NO"<<endl;
continue;
}
int tol=;
for(i=;i<;i++) //遍历 26个字符
if(ru[i]==)
{ //如果入度为 0,则会形成一串字符
ans[tol]='a'+i;
x=i;
while(next[x]!=-)
{ //加入后继字符
char c=next[x]+'a';
ans[tol]+=c;
x=next[x];
}
tol++;
}
sort(ans,ans+tol); //排序
for(i=;i<tol;i++) cout<<ans[i];
cout<<endl;
}
return ;
}
4.9cf自训9..的更多相关文章
- Java企业实训 - 01 - Java前奏
前言: 虽然个人专攻.NET方向,不过由于个人是干教育行业的,方方面面的东西,不能说都必须精通,但肯定多少都会涉及到. 一个菜鸟学员,从啥都不会,经过一步步学习,最后到企业上手掌管一个模块甚至一个项目 ...
- UML基础与Rose建模实训教程
目 录 第1章 初识UML. 1 1.1 初识UML用例图... 1 1.2 初识UML类图... 3 第2章 Rational Rose工具... 6 2.1 安装与配置Rational Ro ...
- <实训|第六天>偷偷让新手的Linux无限重启附linux主机名称不是随便乱改的!
先说个事情:这几天我正在忙一个项目的设计,8月1号之前要弄出来,所以每天都要弄到很晚,可能更新就有点跟不上了,不过我如果有时间的话,我就更新,没时间的话,我会在8月1号之后统一更新出来,希望大家谅解! ...
- <实训|第五天>通过搭建NFS,FTP实现共享文件附Vim脚本游戏
先说个事情:我周末是不更新这个系列教程的,不过其他内容的会更新,我周末就整理这一周的各种内容到我的微信公众号中,提供给大家! 期待已久的linux运维.oracle"培训班"终于开 ...
- ThoughtWorks西邮暑期特训营 -- JavaScript在线笔试题
ThoughtWorks 公司在西邮正式开办的只教女生前端开发的女子卓越实验室已经几个月过去了,这次计划于暑期在西邮内部开展面向所有性别所有专业的前端培训. 具体官方安排请戳:ThoughtWorks ...
- 软件工程实训项目案例--Android移动应用开发
实训过程 角色分工 1.项目经理:负责项目的组织实施,制定项目计划,并进行跟踪管理 2.开发人员:对项目经理及项目负责 3.需求分析员:负责系统的需求获取和分析,并协助设计人员进行系统设计 4.系统设 ...
- <实训|第四天>Linux下的vim你真的掌握了吗?附上ftp远程命令上传。
期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...
- <实训|第三天>Linux登录界面的修改以及Richard Stallman、自由软件运动
在写博客之前我想说两点: 承认一个错误,昨天写的实训第二天,我把redhat6.7写成了Linux6.7,感谢热心人士的指出! 昨天写的文章名字太长了,今天改善,内容感觉表述不全,希望各位谅解! 官方 ...
- <实训|第二天>掌握linux6.7中安装vmware、vmware安装linux发行版本以及遇到的问题最后libreoffice的安装
期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...
随机推荐
- Python datetime模块的介绍
datetime模块常用的主要有下面这四个类:(要清楚import datetime : 导入的是datetime这个包,包里有各种类) 1. datetime.date 用于表示年月日构成的日期 ...
- ADT SDK Manager启动时一闪而过
原因为使用了Android Studio的绿色JRE,必须要安装安装版JDK或者JRE,绿色版JRE放在ADT目录虽然能启动ADT但是不能启动SDK Manager
- 16.kubernetes的RBAC
role 分为clsterrole和role 我们从普通的role 开始理解起 [root@master ~]# kubectl create role pod-read --verb=get,lis ...
- Ueditor注意的地方
复制粘贴内容到编辑器上时,一些标签的属性会被过滤,在config.js里添加白名单配置项,例如: whitList: { a: ['target', 'href', 'title', 'class', ...
- mpvue——componets中引入vant-weapp组件
前言 这个问题很奇葩,网上也有很多人,给了很多方法,但是我想说的是,那些方法我用了都没效果,我试了一些都没效果,因为我当时引入时报错说没有export default出来,但是一旦暴露出来就又出其他问 ...
- [洛谷P2107] 小Z的AK计划
题目类型:贪心,堆 传送门:>Here< 题意:给出\(N\)个房间,每个房间距离起点的距离为\(x[i]\),每个房间可以选择进去和不进去,如果进去了那么要\(t[i]\)秒后才能出来. ...
- Git让你从入门到精通,看这一篇就够了
简介 Git 是什么? Git 是一个开源的分布式版本控制系统. 什么是版本控制? 版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统. 什么是分布式版本控制系统? 介绍分布 ...
- 计算pi的位数
from random import random from math import sqrt from time import clock DARTS=1000000 hits=0.0 clock( ...
- Python:正则表达式详解
正则表达式是一个很强大的字符串处理工具,几乎任何关于字符串的操作都可以使用正则表达式来完成,作为一个爬虫工作者,每天和字符串打交道,正则表达式更是不可或缺的技能,正则表达式的在不同的语言中使用方式可能 ...
- Mac新手必看教程—让你离熟练操作mac只差十分钟
本文收录于:风云社区(提供各类mac软件资源下载) 本文源自:什么值得买 无论轻薄办公本.还是赶超台式性能的游戏本,关注#笔记本攻略#栏目,解决笔记本电脑从选购到使用的各种问题. 引子 大部分用户接触 ...