General Algorithm

2024-09-03 20:48
文章标签 general algorithm

本文主要是介绍General Algorithm,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • Y or N
      • Silly Board Game
  • String Sorting
      • Find the smallest char in a string
  • Integer Sorting
      • Pairs

Y or N

Silly Board Game

2 opponents: A&B. To represent a board by String[] board = new String[]{“…”,”.#.”,”..#”}, then use for loop to get into the board environments(’#‘为障碍物不可走棋):

                        . . .. # .. . #for (int i = 0; i < board.length; i++) {for (int j = 0; j < board[i].length(); j++) {.......}}

已知条件:A 总先走。所以为了判断A 的输赢:用A可选择走的棋格 数量%2, 如果剩下的棋格为Even number, A则输(B赢),否则A赢(B输)(整个游戏像抽乌龟,单纯以Even/Odd 判断最后输赢)。总结为:先走的,且可走棋数为Odd的,会成为最后赢家。

String Sorting

Find the smallest char in a string

Only get the smallest char from the first half of string:

重要条件: Each letter from ‘a’ to ‘z’ will have either zero or two occurrences in s
使用ASCii 去比较字母。

Method 1 (Best)
连续两次为最小的直接return.

public class StringHalving {public String lexsmallest(String s) {char[] chCount = new char[256];char smallest = s.charAt(0);for(int i=0;i<s.length();++i){if(s.charAt(i)<smallest){smallest = s.charAt(i);}chCount[s.charAt(i)]++;if(chCount[s.charAt(i)]==2){return ""+smallest;}}          return null;} }

Method 2 (Easiest)
使用build-in function Array.sort(char [ ])

public class StringHalving {public String lexsmallest(String s){int cut = (int) Math.floor(s.length()/2);char tempArray[] = s.substring(0,cut).toCharArray();Arrays.sort(tempArray);return Character.toString(tempArray[0]);}}

Integer Sorting

Pairs

这里写图片描述

把已知的数字加一遍K得到Set B,再从已知数字Set A里找到和Set B重合的数字,累计重合次数
改进:在Set A里使用Binary Search Tree来找SetB里所有的数字,并累计
在这题的2叉题目里,用Hash Table加unordered Set速度快于Ordered过的Set,没排序过的Set可以增大查找的机率。

#include<iostream>
#include<unordered_set>
using namespace std;
unordered_set<int> s;int main()
{int n, k, val;cin >> n >> k;for (int i = 0; i < n; i++){cin >> val;s.insert(val);}int ans = 0;for (unordered_set<int>::iterator it = s.begin(); it != s.end(); ++it)if (s.find(*it + k) != s.end()) ans++;cout << ans << endl;return 0;
}

这篇关于General Algorithm的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1134011

相关文章

神经网络训练不起来怎么办(零)| General Guidance

摘要:模型性能不理想时,如何判断 Model Bias, Optimization, Overfitting 等问题,并以此着手优化模型。在这个分析过程中,我们可以对Function Set,模型弹性有直观的理解。关键词:模型性能,Model Bias, Optimization, Overfitting。 零,领域背景 如果我们的模型表现较差,那么我们往往需要根据 Training l

【tensorflow 使用错误】tensorflow2.0 过程中出现 Error : Failed to get convolution algorithm

如果在使用 tensorflow 过程中出现 Error : Failed to get convolution algorithm ,这是因为显卡内存被耗尽了。 解决办法: 在代码的开头加入如下两句,动态分配显存 physical_device = tf.config.experimental.list_physical_devices("GPU")tf.config.experiment

纪念一下自己的Coursera Princeton Algorithm的课程第一个assignment

今天终于完成了第一个Union-Find的assignment,之前觉得特别的难,可是最后自己也搞定了。而且是100%满分。 自己后来plot了一下自己的分数,也许这就是学习曲线吧。刚开始不会,到后来中期显著提高,但是要到100%,那就要经历更多的波折,甚至是下降都有可能。最后才能达到100%满分。 我觉得最有用的还是下面这段源代码: /*************************

[Algorithm][综合训练][栈和排序][加减]详细讲解

目录 1.栈和排序1.题目链接2.算法原理详解 && 代码实现 2.加减1.题目链接2.算法原理详解 && 代码实现 1.栈和排序 1.题目链接 栈和排序 2.算法原理详解 && 代码实现 解法:栈 + 贪心 -> 每次尽可能先让当前需要的最大值弹出去vector<int> solve(vector<int>& a) {int n = a.size();vect

[Algorithm][综合训练][四个选项][接雨水]详细讲解

目录 1.四个选项1.题目链接2.算法原理详解 && 代码实现 2.接雨水1.题目链接2.算法原理详解 && 代码实现 1.四个选项 1.题目链接 四个选项 2.算法原理详解 && 代码实现 解法:DFS(暴搜) + 剪枝 + Hash 剪枝: 填某个数的时候,要看看还有没有剩余次数填某个数的时候,符不符合若干题的选项必须相同 #include <iostr

General Algorithms - Graph

BFS Red Knights Shortest Path - World CodeSprint 12 - DFS Even TreeRoads and Libraries MST Kruskal MST Really Special Subtree A BFS Red Knight’s Shortest Path - World CodeSprint

零基础学启发式算法(5)-遗传算法 (Genetic Algorithm)

一、遗传算法 (Genetic Algorithm, GA)  源于达尔文的进化论,将问题的一个解当作种群中的一个个体。 gene:基因 chromosome: 染色体 population:种群 crossover:交叉 mutation:变异 selection:选择 通过多轮的“选择,交叉和变异”,选择适应度最好的个体作为问题的最优解。 选择:优胜劣汰,适者生存。

多边形快速凸包算法(Melkman‘s Algorithm)

前言 平面点集的凸包算法一文介绍了如何计算平面点集或者任意多边形的凸包。对于随机的平面点集,Graham scan和Andraw's 单调链算法已经是最快的算法了。但是对于没有自相交的封闭的简单多边形,存在线性复杂度的算法。下面介绍这一优雅高效的算法。 一般的2D凸包算法,首先将点进行排序(时间复杂度),然后利用栈操作在O(n)的时间复杂度内计算凸包。初始的排序决定了最终的时间复杂度。但是本文

one model / ensemble method /meta-algorithm 迁移学习算不算ensemble method

鉴于object detection COCO数据集的论文经常出现 single-model 也就是说,这是一个对网络的分类,呢它是什么意思,有什么特点。相对应的另一类是什么。就是下面介绍的ensemble learning。 不过比如说网络初值是用别人的网络训练好的数值,一定意义来讲是在优化空间找到一个初值,对于自己网络的结果的影响究竟有多大,也就是说,用随机初始网络得到的结果是否有不同,有多

[Algorithm][综合训练][体育课测验(二)][合唱队形][宵暗的妖怪]详细讲解

目录 1.体育课测验(二)1.题目链接2.算法原理详解 && 代码实现 2.合唱队形1.题目链接2.算法原理详解 && 代码实现 3.宵暗的妖怪1.题目链接2.算法原理详解 && 代码实现 1.体育课测验(二) 1.题目链接 体育课测验(二) 2.算法原理详解 && 代码实现 说明:单纯积累一题[拓扑排序]用于加强印象 能识别模型,并且写出代码 vector<i