技术标签: 算法
串只包含0或者1,给定一个数字,输出以此为长度的01串不含连续1的串的个数。
如输入3,则输出5,因为长度为3的01串不含连续1的串包括000, 001, 010, 100, 101。
思路1:
(暴力,较复杂)思路2:将’1’或’0’放置在长度固定为n的数组中,不能有连续的’1’,看有多少种放法。
思路1:
#include <iostream>
#include <cmath>
#include <cstring>
#include <stdlib.h>
using namespace std;
char a[32] = {
0};
char* toRadix(int i)
{
itoa(i, a, 2);
return a;
}
int main()
{
int len, n;
int count = 0;
cin >> len;
n = pow(2, len);
for(int i = 0; i < n; i++)
{
char* radix = toRadix(i);
for(int j = 0; j < 30; j++)
{
if(radix[j] == '1')
{
if(radix[j+1] == '1')
{
break;
}
}
if(j == strlen(radix))
{
count++;
}
}
}
cout << count << endl;
return 0;
}
思路2:
#include<iostream>
#include<cstdio>
using namespace std;
int Fac(int n){
if(0==n||1==n){
return 1;
}else{
return n*Fac(n-1);
}
}
int main(){
int n,res=0,maxNum;
cin>>n;
//maxNum=n%2==0?n/2:(n+1)/2;
maxNum=(n+1)/2;
for(int i=0;i<=maxNum;i++){
int t=(n-i+1);
res+=Fac(t)/(Fac(i)*Fac(t-i));
}
printf("%d\n",res);
return 0;
}
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
char a[32] = {
0};
char* toRadix(int i)
{
itoa(i, a, 2);
return a;
}
res+=Fac(t)/(Fac(i)*Fac(t-i));
int Fac(int n){
if(0==n||1==n){
return 1;
}else{
return n*Fac(n-1);
}
}
给出字符串A和B,判断A是否是B的进行循环移位得到的子串。
如A = “ABC”,B = “BCDEFA”, 则是。
注意:
循环移位:将最左边的字符移到最右边。
思路1:
#include <iostream>
#include <cmath>
#include <cstring>
#include <stdlib.h>
using namespace std;
int main() {
string A = "cdeeb";
string B = "abcde";
int lena = A.length();
int lenb = B.length();
for(int i = 0; i < lenb; i++)
{
if(B[i] == A[0])
{
int j;
for(j = 1; j < lena; j++)
{
if(i+j > lenb-1)
{
if(B[i+j-lenb] == A[j])
{
continue;
}
else
{
break;
}
}
if(B[i+j] == A[j])
{
continue;
}
else
{
break;
}
}
if(j == lena)
{
cout << "true" << endl;
return 0;
}
}
}
cout << "false" << endl;
return false;
return 0;
}
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.字符串循环比较题,记得可以将字符串拼接起来。 | ||
般 | |||
必 |
for(int i = 0; i < lenb; i++)
{
if(B[i] == A[0])
{
int j;
for(j = 1; j < lena; j++)
{
if(i+j > lenb-1)
{
if(B[i+j-lenb] == A[j])
{
continue;
}
else
{
break;
}
}
if(B[i+j] == A[j])
{
continue;
}
else
{
break;
}
}
if(j == lena)
{
cout << "true" << endl;
return 0;
}
}
}
https://leetcode-cn.com/problems/perfect-squares/
思路1:
#include <stdio.h>
#include <iostream>
#include <stdlib.h>
using namespace std;
int main()
{
int n;
cin >> n;
int *a = (int *)calloc(n + 1, sizeof(int));
a[1] = 1;
for(int i = 2; i <= n; i++)
{
a[i] = a[i-1] + 1;
for(int j = 1; j < i; j++)
{
if(i - j * j >= 0)
{
a[i] = min(a[i], a[i - j * j] + 1);
}
}
}
cout << a[n] << endl;
}
动态规划题
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.理清上一个数与下一个数的的关系,在此题中则是若i=一个数m+另一个数j的平方,则它可能更短;令a[i] = min(a[i], a[i - j * j] + 1)即可。 | ||
般 | |||
必 |
for(int i = 2; i <= n; i++)
{
a[i] = a[i-1] + 1;
for(int j = 1; j < i; j++)
{
if(i - j * j >= 0)
{
a[i] = min(a[i], a[i - j * j] + 1);
}
}
}
思路1:
sort()排序,时间复杂度为nlogn思路2:三分法。
#include <iostream>
#include <cmath>
#include <algorithm>
using namespace std;
int main()
{
vector<int> nums = {
1, 5, 1, 1, 6, 4};
// 值的传递,不是地址的传递
vector<int> a = nums;
sort(a.begin(), a.end());
int len = nums.size();
int sidenum, innum;
if(len % 2 == 0)
{
sidenum = innum = len / 2;
}
else
{
sidenum = len / 2 + 1;
innum = sidenum - 1;
}
int j = len-1;
int m = sidenum - 1;
for(int i = 0; i < len; i++)
{
nums[i] = i & 1 ? a[j--] : a[m--];
}
}
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.记得要倒序插入。2.sort()排序法。 | ||
般 | |||
必 |
https://leetcode-cn.com/problems/longest-word-in-dictionary-through-deleting/
思路1:
思路2:引入当前最大变量,和满足题意的先置条件
#include <iostream>
#include <cmath>
#include <stdlib.h>
#include <cstring>
#include <algorithm>
using namespace std;
bool isZiChuan(string target, string s)
{
cout << target << endl;
int j = 0;
int len1 = target.length();
int len2 = s.length();
for(int i = 0; i < len2; i++)
{
if(j < len1 && target[j] == s[i])
{
j++;
}
}
// 判断是否遍历完
return j == target.length();
}
int main()
{
string s = "abpcplea", d[] = {
"ale","apple","monkey","plea"};
string curstr = "";
for(int i = 0; i < sizeof(d)/sizeof(string); i++)
{
if(d[i].length() < curstr.length() || (d[i].length() == curstr.length() && d[i].compare(curstr) >= 0))
{
continue;
}
if(isZiChuan(d[i], s))
{
curstr = d[i];
}
}
cout << curstr << endl;
return 0;
}
if(d[i].length() < curstr.length() || (d[i].length() == curstr.length() && d[i].compare(curstr) >= 0))
{
continue;
}
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.判断是否比较完字符串。2利用先知条件跳过一些解。 | ||
般 | |||
必 |
// 判断是否遍历完
return j == target.length();
if(d[i].length() < curstr.length() || (d[i].length() == curstr.length() && d[i].compare(curstr) >= 0))
{
continue;
}
小贝有一个矩形板,矩形板由N行M列的单位方块组成,每个单位方块要么是白色的要么是黑色的.小贝想知道矩形板是否是水平对称或者竖直对称的,你能帮助她吗?
所固水平对称,是指如果将矩形板治着其水平中轴线翻转,得到的矩形板和原来一样.具体地说,如果N是奇数,水平中轴线是指第(N+1/2行方块的中线;如果N是偶数,水平中轴线是指在第/2行和第N/2+1行方块之间的直线.竖直对称的定义类似.
思路1:
#include<iostream>
#include <string>
using namespace std;
char a[51][51];
int main()
{
int count, n, m;
cin >> count;
for(int i = 0; i < count; i++)
{
int hor = 0, sym = 0;
cin >> n >> m;
for(int p = 0; p < n; p++)
{
for(int q = 0; q < m; q++)
{
cin >> a[p][q];
}
}
//是否水平对称
int p, q;
for(p = 0; p < n; ++p)
{
for(q = 0; q < m/2; q++)
{
if(a[p][q] != a[p][m-1-q])
{
break;
}
}
}
if(p == n && q == int(m/2))
{
hor = 1;
}
//垂直对称
for(p = 0; p < m/2; p++)
{
for(q = 0; q < n; q++)
{
if(a[p][q] != a[n-1-p][q])
{
break;
}
}
}
if(p == int(m/2) && q == m)
{
sym = 1;
}
if(sym && hor)
{
cout << "both" << endl;
}
else if(hor == 1)
{
cout << "hor" << endl;
}
else if(sym == 1)
{
cout << "sym" << endl;
}
// 不满足了才不进入循环了嘛,所以for循环结束后,p=n。
//cout << p << endl;
}
}
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.very基础题。注意要定义成char a[][]。 | ||
般 | |||
必 |
https://leetcode-cn.com/problems/reconstruct-itinerary/
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
https://leetcode-cn.com/problems/validate-binary-search-tree/
思路1:
使用二叉树的**中序遍历算法**;中序遍历时,是一个升序的过程,若不满足升序,则不是二叉搜索树。模拟二叉树思考的过程的解法
思路2:上下边界+DFS。引入上下边界,并根据情况变化上下边界。
1…根节点的左节点仅上边界变化(若其不满足:大于low,小于val,则return false。)。
2…根节点的右节点仅下边界变化(若其不满足:大于val,小于high,则return true。)。
思路3:
思路2:
#include <iostream>
#include <cmath>
#include <stdlib.h>
using namespace std;
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
long long high = 10000000000;
long long low = -10000000000;
int count = 0;
bool DFS(TreeNode* root, long long low, long long high)
{
count++;
if(root == NULL)
{
return true;
}
if((root->val <= low || root->val >= high))
{
return false;
}
return DFS(root->left, low, root->val) && DFS(root->right, root->val, high);
}
bool isValidBST(TreeNode* root) {
//结构体的指针和结构体
if(root == NULL)
{
return true;
}
return DFS(root, low, high);
}
};
int main()
{
Solution sol;
sol.isValidBST(NULL);
}
易 | 中 | 难 | |
---|---|---|---|
紧 | 1.上下边界+DFS。2.前序、中序、后序遍历二叉树(结构体)。 | ||
般 | |||
必 |
if((root->val <= low || root->val >= high))
{
return false;
}
return DFS(root->left, low, root->val) && DFS(root->right, root->val, high);
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
思路1:
易 | 中 | 难 | |
---|---|---|---|
紧 | |||
般 | |||
必 |
文章浏览阅读451次。dev/mem: 物理内存的全镜像。可以用来访问物理内存。/dev/kmem: kernel看到的虚拟内存的全镜像。可以用来访问kernel的内容。调试嵌入式Linux内核时,可能需要查看某个内核变量的值。/dev/kmem正好提供了访问内核虚拟内存的途径。现在的内核大都默认禁用了/dev/kmem,打开的方法是在 make menuconfig中选中 device drivers --> ..._dev/mem 源码实现
文章浏览阅读7.1k次,点赞2次,收藏19次。vxe-table,一个小众但功能齐全并支持excel操作的vue表格组件_vxe-table
文章浏览阅读62次。参考:http://www.ruanyifeng.com/blog/2016/01/babel.htmlBabelBabel是一个广泛使用的转码器,可以将ES6代码转为ES5代码,从而在现有环境执行// 转码前input.map(item => item + 1);// 转码后input.map(function (item) { return item..._让开发环境支持bable
文章浏览阅读2.8k次,点赞6次,收藏29次。摘要:FPGA视频处理FIFO的典型应用,视频输入FIFO的作用,视频输出FIFO的作用,视频数据跨时钟域FIFO,视频缩放FIFO的作用_fpga 频分复用 视频
文章浏览阅读575次。【代码】R语言:设置工作路径为当前文件存储路径。_r语言设置工作目录到目标文件夹
文章浏览阅读452次。格式:background: linear-gradient(direction, color-stop1, color-stop2, ...);<linear-gradient> = linear-gradient([ [ <angle> | to <side-or-corner>] ,]? &l..._background线性渐变
文章浏览阅读1k次,点赞26次,收藏8次。第十三届蓝桥杯青少年组python编程省赛真题一、题目要求(注:input()输入函数的括号中不允许添加任何信息)1、编程实现给定一个正整数N,输出正整数N中各数位最大的那个数字。例如:N=132,则输出3。2、输入输出输入描述:只有一行,输入一个正整数N输出描述:只有一行,输出正整数N中各数位最大的那个数字输入样例:
文章浏览阅读2.2k次。一个网络协议主要由以下三个要素组成:1.语法数据与控制信息的结构或格式,包括数据的组织方式、编码方式、信号电平的表示方式等。2.语义即需要发出何种控制信息,完成何种动作,以及做出何种应答,以实现数据交换的协调和差错处理。3.时序即事件实现顺序的详细说明,以实现速率匹配和排序。不完整理解:语法表示长什么样,语义表示能干什么,时序表示排序。转载于:https://blog.51cto.com/98..._网络协议三要素csdn
文章浏览阅读153次。主要的思想,将所有的系统都可以看作两部分,真正的数据log系统和各种各样的query engine所有的一致性由log系统来保证,其他各种query engine不需要考虑一致性,安全性,只需要不停的从log系统来同步数据,如果数据丢失或crash可以从log系统replay来恢复可以看出kafka系统在linkedin中的重要地位,不光是d..._the log: what every software engineer should know about real-time data's uni
文章浏览阅读746次。伟大是熬出来的 目录 前言 引言 时间熬成伟大:领导者要像狼一样坚忍 第一章 内圣外王——领导者的心态修炼 1. 天纵英才的自信心 2. 上天揽月的企图心 3. 誓不回头的决心 4. 宠辱不惊的平常心 5. 换位思考的同理心 6. 激情四射的热心 第二章 日清日高——领导者的高效能修炼 7. 积极主动,想到做到 8. 合理掌控自己的时间和生命 9. 制定目标,马..._当狼拖着受伤的右腿逃生时,右腿会成为前进的阻碍,它会毫不犹豫撕咬断自己的腿, 以
文章浏览阅读285次。在当今的大数据时代,人们对高速度和高带宽的需求越来越大,迫切希望有一种新型产品来作为高性能计算和数据中心的主要传输媒质,所以有源光缆(AOC)在这种环境下诞生了。有源光缆究竟是什么呢?应用在哪些领域,有什么优势呢?易天将为您解答!有源光缆(Active Optical Cables,简称AOC)是两端装有光收发器件的光纤线缆,主要构成部件分为光路和电路两部分。作为一种高性能计..._aoc 光缆
文章浏览阅读2.2k次。在“桌面”上按快捷键“Ctrl+R”,调出“运行”窗口。接着,在“打开”后的输入框中输入“Gpedit.msc”。并按“确定”按钮。如下图 找到“用户配置”下的“Windows设置”下的“Internet Explorer 维护”的“连接”,双击选择“自动浏览器配置”。如下图 选择“自动启动配置”,并在下面的“自动代理URL”中填写相应的PAC文件地址。如下..._設置proxy腳本