2.24完成129、134、135

题目:

现在,有许多给小孩子玩的数字游戏,这些游戏玩起来简单,但要创造一个就不是那么容易的了。 在这,我们将介绍一种有趣的游戏。

你将会得到N个正整数,你可以将一个整数接在另一个整数之后以制造一个更大的整数。 例如,这有4个数字123, 124, 56, 90,他们可以制造下列整数─ 1231245690, 1241235690, 5612312490, 9012312456, 9056124123....等,总共可以组合出24(4!)种数字。 但是,9056124123是最大的那一个。

你可能会想这是个简单的事情,但对刚有数字概念小孩来说,这会是个简单的任务吗?

要点总结:

数字的字符串只要没有前缀0并且长度相同,可以直接用>或者<进行比较,本质是字典序比较,和数字大小一致。

这里先读入所有数字string,然后定义一个新的比较方式,两个字符串拼接后放在前面结果大的排前面,按这个顺序排完之后拼接输出即为最大值。

另外,特殊处理一下全是000000的情况,只输出一个

代码:

#include<bits/stdc++.h>

using namespace std;

bool compa(string x,string y){

return x+y>y+x;

}

int main(){

int n;

while(cin>>n){

if(n==0) continue;

vector<string> arr;

for(int i=0;i<n;i++){

string a;

cin>>a;

arr.push_back(a);

}

sort(arr.begin(),arr.end(),compa);

string res;

for(string m : arr){

res+=m;

}

if(res[0]=='0'){

cout<<"0"<<endl;

}else{

cout<<res<<endl;

}

}

return 0;

}

题目:

3000米长跑时,围观党们兴高采烈地预测着最后的排名。因为他们来自不同的班,对所有运动员不一定都了解,于是他们分别对自己了解的一些运动员的实力作出了评估,即对部分运动员做了相对排名的预测,并且告诉了可怜留守的班长。因为无聊,于是他们就组团去打Dota去了。比赛结束后他们向班长询问最后的排名,但班长不记得了,只记得他们中哪些人的预测是正确的,哪些人的预测是错误的。他们想知道比赛的排名可能是什么。

要点总结:

我的思路是使用next_permutation枚举所有的可能排名情况,然后对每一个预测的排名判断是不是可能排名的合法情况(如果预测为正确必须为其子序列,如果预测为错误必须不为其子序列),遍历完所有预测即可判断该枚举情况是不是合理,合理就塞入vector里面。但是这里暴力枚举拿不全分数,有的用例会超时,之后可以思考看看是否有简单方法。

代码:

#include<bits/stdc++.h>

using namespace std;

struct pred{

vector<int> seq;

bool iscorr;

};

bool isseq(vector<int> xulie,vector<int> yuce){

int j=0;

for(int i=0;i<xulie.size()&&j<yuce.size();i++){

if(xulie[i]==yuce[j]){

j++;

}

}

return j==yuce.size();

}

int main(){

int n,m;

cin>>n>>m;

vector<int> xulie(n);

for(int i=0;i<n;i++){

xulie[i]=i;

}

vector<pred> pre(m);

for(int i=0;i<m;i++){

int a,flag;

cin>>a;

vector<int> seq(a);

for(int j=0;j<a;j++){

cin>>seq[j];

}

cin>>flag;

pred x;

x.seq=seq;

x.iscorr=(flag==1);

pre[i]=x;

}

vector<vector<int>> valid;

do{

bool ok=true;

for(pred s : pre){

bool sub=isseq(xulie,s.seq);

if(s.iscorr){

if(!sub){

ok=false;

break;

}

}else{

if(sub){

ok=false;

break;

}

}

}

if(ok){

valid.push_back(xulie);

}

}while(next_permutation(xulie.begin(),xulie.end()));

cout<<valid.size()<<endl;

for(vector<int> y : valid){

for(int k=0;k<y.size();k++){

cout<<y[k]<<" ";

}

cout<<endl;

}

return 0;

}

题目:

有n(2≤n≤20)块芯片,有好有坏,已知好芯片比坏芯片多。

每个芯片都能用来测试其他芯片。用好芯片测试其他芯片时,能正确给出被测试芯片是好还是坏。而用坏芯片测试其他芯片时,会随机给出好或是坏的测试结果(即此结果与被测试芯片实际的好坏无关)。

给出所有芯片的测试结果,问哪些芯片是好芯片。

要点总结:

这里代码没难度,关键在于思想。看到好芯片比坏芯片多要学会分析。如果是好芯片,则一定得到预测为1的超过总芯片数一半(因为坏的来检测它会五五分,而好的来检测它全是1),所以对每一列,去累加所有行然后判断即可。

代码:

#include<bits/stdc++.h>

using namespace std;

int main(){

int n;

cin>>n;

int arr[n][n];

for(int i=0;i<n;i++){

for(int j=0;j<n;j++){

cin>>arr[i][j];

}

}

vector<int> good;

for(int j=0;j<n;j++){

int count=0;

for(int i=0;i<n;i++){

if(arr[i][j]==1){

count++;

}

}

if(count>n/2){

good.push_back(j+1);

}

}

for(int m=0;m<good.size();m++){

cout<<good[m]<<" ";

}

return 0;

}

英语翻译:

智能手机配备了内置的语音识别系统,这使用户能使用语音指令提问并控制设备。智能手机也包含GPS功能,所以智能手机的app能够提供基于定位的服务,例如导航地图或者提供附近餐厅的清单。

智能手机是由基础的手机和PDA发展而来的,PDA(即个人数字助力)是被用作电子日程本、计算器、笔记本的手持设备。现代智能手机有类似的一套应用程序,但它们也有大量的移动端app可以帮助用户计算小费、播放其喜欢的音乐、提供游戏以供娱乐。

智能手机的操作系统和平板电脑的类似。iphone和ipad就都是使用IOS系统。智能手机上的win10移动系统可以提供类似windows笔记本的用户体验。三星平板使用的安卓系统也用于三星的galaxy系列以及摩托罗拉的droid系列智能手机

PDA个人数字助理

electronic appointment book 电子日程本

相关推荐
I_LPL2 小时前
day36 代码随想录算法训练营 动态规划专题4
java·算法·leetcode·动态规划·hot100
2301_816997882 小时前
虚拟DOM与Diff算法
前端·vue.js·算法
闻缺陷则喜何志丹2 小时前
P8153 「PMOI-5」送分题/Yet Another Easy Strings Merging|普及+
c++·数学·算法·洛谷
tankeven2 小时前
HJ102 字符统计
c++·算法
升讯威在线客服系统2 小时前
从 GC 抖动到稳定低延迟:在升讯威客服系统中实践 Span 与 Memory 的高性能优化
java·javascript·python·算法·性能优化·php·swift
We་ct2 小时前
LeetCode 199. 二叉树的右视图:层序遍历解题详解
前端·算法·leetcode·typescript·广度优先
孤独的追光者2 小时前
MATLAB导出滤波器参数至ADSP中使用
算法·matlab
鲨辣椒100862 小时前
线程函数接口补充
java·开发语言·算法
0 0 02 小时前
CCF-CSP 33-2 相似度计算(jaccard)【C++】考点:STL容器(set/map)
开发语言·c++·算法