在这里我给大家推荐一款不错刷算法学习网站:点击这处链接牛客网;牛客网作为国内内容超级丰富的 IT 题库,各种东西看的我眼花缭乱,题库+面试+学习+求职+讨论+大厂内推等等服务,堪称
"互联网求职神器"。它好就好在不只是一个刷题的平台,还是一个交流学习的平台,发个问题贴总有热心的大佬帮助。
文章目录

思考:该题使用循环1-2020即可,每次循环需要判断每个位数是否为2,方法:三个if()判断是否有十位、百位、千位、有的情况下判断是否为2,是的话2的数字+1.答案624次
#include<iostream>
#include<string>
using namespace std;
int main()
{
const n=2020;
int ans=0;
for(int i=1;i<=n;i++)
{
int t=i;
while(t){
if(t%10==2) ans++;
t/=10;
}
// cout<<i<<" "<<ans<<endl;
}
cout<<ans<<endl;
return 0;
}

思考:
1.最大公约数定理:两个正整数a和b(a>b),它们的最大公约数等于a除以b的余数c和较小数b之间的最大公约数
2.分子和分母均从1-2020循环,判断符合公约数为1的即为既约分数,数目+1。
#include<iostream>
#include <stdio.h>
using namespace std;
int gcd(int a,int b )
{
if(a%b==0) return b;
else return gcd(b,a%b);
}
int main()
{
int ans=0;
for(int i=1;i<=2020;i++)
{
for (int j=1;j<=2020;j++)
{
if(gcd(i,j)==1)
ans++;
}
}
cout<<ans<<endl;
return 0;
}
运行结果:2481215

分析:
第1行第1列为1,第2行第2列为5,相差4,=41
第2行第2列为5,第三行第3行为13,相差8,42
第三行第3行为13,第四行第四列为25,相差12,4*3
sum=1
for(i=2,i<=20;i++)
sum=sum+(i-1)*4
#include <stdio.h>
int main()
{
int i,sum=1;
for(i=1;i<=20;i++)
{
sum=sum+(i-1)*4;
printf("%d\n",sum);
}
return 0;
}
运行结果,第20行20列为761

分析:将日期从2000-1-1(周六)到2020-10-1(周四)进行循环,分别找出跑1km和2km的日期。可以将日期分解为年、月、日、周,四个变量。月初或者周初以及同时满足的情况都跑2千米,即当d1==1||week_num == 1时,跑2千米,其余情况都跑1千米。
#include<iostream>
#include <stdio.h>
using namespace std;
int r[2][13]={{0,31,29,31,30,31,30,31,31,30,31,30,31},{0,31,28,31,30,31,30,31,31,30,31,30,31}};
int main()
{
int ans=0;
int y1,m1,d1,week_num;
y1=2000,m1=1,d1=1,week_num=6;
while(!(y1==2020 && m1==10 && d1==1))
{
if((d1==1)||(week_num==1))
ans=ans+2;
else ans++;
d1++;
week_num++;
if(week_num==8)week_num=1;
int f=(y1%4==0&&y1%100!=0)||(y1%400==0)?0:1;
if(d1>r[f][m1]){d1=1;m1++;}
if(m1==13) {m1=1;y1++;}
}
cout<<week_num<<endl;
ans=ans+2;
cout<<"跑步里程:"<<ans<<"km"<<endl;
return 0;
}
运行结果:跑了8879千米。

分析:每段二极管分发光(1)不发光状态(0),7次循环嵌套可以表示所有状态。对每种状态判断是否连续是记+1
方法二:七位二制进数可以表达所有状态,即循环1-127可以表达所有状态。用位运算对二制进数取出每位二进制的值,对每种状态判断是否连续是记+1
#include<iostream>
#include<string>
#include<cstring>
#include<set>
#include<queue>
using namespace std;
int a[100][100];
void init(){
a[0][1]=a[1][0]=a[0][5]=a[5][0]=1;
a[1][2]=a[2][1]=a[1][6]=a[6][1]=1;
a[2][6]=a[6][2]=a[2][3]=a[3][2]=1;
a[3][4]=a[4][3]=1;
a[4][6]=a[6][4]=a[4][5]=a[5][4]=1;
a[5][6]=a[6][5]=1;
}
bool ok(int s){
queue<int> q;
bool v[7];
int start;
for(int i=0;i<7;i++) v[i]=false;
for(int j=0;j<7;j++){
if((1<<j)&s){
start =j;
break;
}
}
q.push(start);
v[start]=true;
while(!q.empty()){
int u=q.front();
q.pop();
for(int y=0;y<7;y++)
{
if(((1<<y)&s)&&a[u][y]&&!v[y]){
q.push(y);
v[y]=true;
}
}
}
for(int x=0;x<7;x++){
if(((1<<x)&s)&&!v[x])return false;
}
return true;
}
int main()
{
init();
int ans=0;
for(int s=1;s<(1<<7);s++)
{
if(ok(s)) ans++;
}
cout<<ans<<endl;
return 0;
}

#include <iostream>
using namespace std;
int score[1001];
int main()
{
int n;
int jg=0;
int yx=0;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>score[i];
}
for(i=0;i<n;i++)
{
if(score[i]>=60)
jg++;
if(score[i]>=85)
yx++;
}
int jres=float((double)jg*100/n+0.5);
int yres=float((double)yx*100/n+0.5);
cout<<jres<<"%"<<endl;
cout<<yres<<"%"<<endl;
return 0;
}

分析:需要判断输入的日期后续仍为正确日期数,需要分别判断年份的四位倒序能为正确的月日,注意
闰年判断。日期为正期数时需要判断是否为回文日期,同时判断是否为ABABBABA型回文。考虑获得回文日期时不再判断普通回文并记录该数,获得ABABBABA型回文时不再判断并记录该数,两个获得后跳出循环.分两行输出两个日期。
#include <iostream>
using namespace std;
int months[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
//判断日期是否合法
bool check(int date)
{
int year = date/10000;
int month = date/100%100;
int day = date%100;
if(!month || month>13 || !day) return false;
if(month != 2 && day > months[month]) return false;
if(month == 2){
bool leap = year%4==0 && year%100 || year%400==0;
if(day > 28+leap) return false;
}
return true;
}
//判断日期是否为回文日期
bool Ishuiwen(int date)
{
int temp = 0;
while(date > temp){//求日期后四位的值
temp = temp * 10 + date%10;
date /= 10;
}
if(date == temp) return true;
return false;
}
//判断日期是否为ABABBABA型日期
bool IsABhuiwen(int date){
int d,m;
d = date%100;//日期后两位78位
m = date/100%100;//日期后56位
if(Ishuiwen(date) && d==m) return true;//满足回文且56位=78时判断日期为ABABBABA型日期
return false;
}
int main()
{
int N;
cin>>N;
for(int i=N+1;i<=89991231;i++)
if(check(i)&&Ishuiwen(i))
{
cout<<i<<endl;
break;
}
for(int j=N+1;j<=89991231;j++)
if(check(j)&&IsABhuiwen(j))
{
cout<<j<<endl;
break;
}
return 0;
}

分析:逐一查找字符串的每个子集,将子集中重复的字符去掉再计算子集长度
#include<iostream>
#include<cstring>
#include<set>
#include<algorithm>
using namespace std;
string s;
int res;
int cal(string s){
set<char> st;
for(int i = 0; i < s.size(); i++){
st.insert(s[i]);
}
return st.size();
}
int main(){
cin >> s;
for(int i = 0; i < s.size(); i++){
for(int j = i; j < s.size(); j++){
string sub = s.substr(i, j - i + 1);
res += cal(sub);
}
}
cout << res;
return 0;
}

#include<iostream>
#include<cstring>
#include<set>
using namespace std;
set<pair<double,double> > se;
const int N = 1005;
double A[N];
double B[N];
set<pair<double,double> > s;
set<pair<double,double> >::iterator it;
int main()
{
int n,i,j,x,y;
cin>>n;
for(i=0;i<n;i++)
{
cin>>x>>y;
s.insert(make_pair(x,y));
}
n = s.size();
for(i=0,it=s.begin(),it++;it!=s.end();it++,i++)
{
A[i]=(*it).first;
B[i]=(*it).second;
}
long long ans=2;
for(i=1;i<n;i++)
{
set<pair<double,double> > se;
for(j=i-1;j>=0;j--)
{
double x=(B[j]-B[i])/(A[i]-A[j]);
double y=(A[j]*B[i]-A[i]*B[j])/(A[j]-A[i]);
se.insert(make_pair(x,y));
}
int n2=se.size();
ans+=(n2+1);
}
cout<<ans<<endl;
}

分析:显然要使长度最短,我们就不能浪费每一个字母,所以,一定有字母是递减的顺序的,要使字典序最短,每个字母出现的数量一定是要递减的,这样就好了,限制一下每个字母最多出现的次数然后就是dfs dfsdfs爆搜,//Author : lifehappy的垫脚石
#include <bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
char ans[N], res[N];
int n, len;
bool judge()
{
int i = len;
while(ans[i] == res[i] && i) i--;
return res[i] < ans[i];
}
void dfs(int now, int maxn, int m, int sum) {
if(sum == n)
{
if(m < len || (m == len && judge()))
{
len = m;
for(int i = 1; i <= len; i++) ans[i] = res[i];
}
return;
}
if(now >= 26) return ;
for(int i = 1; i <= maxn; i++)
{
int temp = sum + m * i;
if(temp > n) return ;
res[m + i] = char(now + 'a');
dfs(now + 1, i, m + i, temp);
}
}
int main()
{
len = 0x3f3f3f3f;
scanf("%d", &n);
dfs(0, 8, 0, 0);
for(int i = len; i >= 1; i--)
putchar(ans[i]);
return 0;
}

我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
几个月前,我读了一篇关于rubygem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:
?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来
目录1.漏洞简介2、AJP13协议介绍Tomcat主要有两大功能:3.Tomcat远程文件包含漏洞分析4.漏洞复现 5、漏洞分析6.RCE实现的原理1.漏洞简介2020年2月20日,公开CNVD的漏洞公告中发现ApacheTomcat文件包含漏洞(CVE-2020-1938)。ApacheTomcat是Apache开源组织开发的用于处理HTTP服务的项目。ApacheTomcat服务器中被发现存在文件包含漏洞,攻击者可利用该漏洞读取或包含Tomcat上所有webapp目录下的任意文件。该漏洞是一个单独的文件包含漏洞,依赖于Tomcat的AJP(定向包协议)。AJP自身存在一定缺陷,导致存在可控
关闭。这个问题是off-topic.它目前不接受答案。想改进这个问题吗?Updatethequestion所以它是on-topic用于堆栈溢出。关闭11年前。Improvethisquestion我不经常使用ruby-通常它加起来相当于每两个月或更长时间编写一次脚本。我的大部分编程都是使用C++进行的,这与ruby有很大不同。由于我与ruby之间的差距如此之大,我总是忘记语言的基本方面(比如解析文本文件和其他简单的东西)。我想每天练习一些基本的东西,我想知道是否有一些我可以订阅的网站,并且会向我发送当天的Ruby问题或类似的东西。有人知道这样的站点/Internet服务吗?
如果特定语言环境中缺少翻译,如何配置i18n以使用en语言环境翻译?当前已插入翻译缺失消息。我正在使用RoR3.1。 最佳答案 找到相似的question这里是答案:#application.rb#railswillfallbacktoconfig.i18n.default_localetranslationconfig.i18n.fallbacks=true#railswillfallbacktoen,nomatterwhatissetasconfig.i18n.default_localeconfig.i18n.fallback
在我的双语Rails4应用程序中,我有一个像这样的LocalesController:classLocalesController用户可以通过此表单更改其语言环境:deflocale_switcherform_tagurl_for(:controller=>'locales',:action=>'change_locale'),:method=>'get',:id=>'locale_switcher'doselect_tag'set_locale',options_for_select(LANGUAGES,I18n.locale.to_s)end这有效。但是,目前用户无法通过URL更改
我使用Ruby编程已经有一段时间了,现在只使用Ruby的标准MRI实现,但我一直对我经常听到的其他实现感到好奇。前几天我在读有关Rubinius的文章,这是一个用Ruby编写的Ruby解释器。我试着在不同的地方查找它,但我很难弄清楚这样的东西到底是如何工作的。我在编译器或语言编写方面从来没有太多经验,但我真的很想弄明白。一门语言究竟如何才能被自己解释?编译中是否有一个我不明白这有意义的基本步骤?有人可以像我是个白痴一样向我解释这个吗(因为无论如何这都不会太离谱) 最佳答案 它比你想象的要简单。Rubinius并非100%用Ruby编
Ruby是完全面向对象的语言。在ruby中,一切都是对象,因此属于某个类。例如5属于Objectclass1.9.3p194:001>5.class=>Fixnum1.9.3p194:002>5.class.superclass=>Integer1.9.3p194:003>5.class.superclass.superclass=>Numeric1.9.3p194:005>5.class.superclass.superclass.superclass=>Object1.9.3p194:006>5.class.superclass.superclass.superclass.su