定时比赛(题解)忘了发~

34 篇文章 0 订阅
12 篇文章 0 订阅

目录

找最长良序字符串

电子警察(police)

连续自然数之和

删数

幂字符串

01背包


找最长良序字符串

#include<bits/stdc++.h>
using namespace std;
string s;
int c = 1, maxn, len;
int main()
{
    freopen("string.in", "r", stdin);
    freopen("string.out", "w", stdout);
    cin >> s;
    s = s + char('0'-1);
    for(int i = 0; i < s.size()-1; i++)
    {
        if(s[i] < s[i + 1])
        {
            c++;
        }
        else
        {
            maxn = max(maxn, c);

            c = 1;
        }
    }
    cout << maxn;
}

电子警察(police)

#include <bits/stdc++.h>
using namespace std;
int toTime(string s)
{
  return ((s[0]-'0')*10+s[1]-'0')*3600+((s[2]-'0')*10+s[3]-'0')*60+(s[4]-'0')*10+s[5]-'0';
}
int main()
{
  freopen("police.in","r",stdin);
  freopen("police.out","w",stdout);
  string str;
  int l,s,r,n,time;
  cin>>l>>s>>r>>n;
  while(n--)
  {
    cin>>str;
    time=toTime(str);
    time= time%(l+s+r)==0? (l+s+r) : time%(l+s+r);
    if(time<=l)
    {
      if(str[6]!='L')
      {
        cout<<str.substr(7,8)<<endl;
      }
    }
    else if(time<=l+s)
    {
      if(str[6]!='S')
      {
        cout<<str.substr(7,8)<<endl;
      }
    }
    else if(time<=l+s+r)
    {
      if(str[6]!='R')
      {
        cout<<str.substr(7,8)<<endl;
      }
    }
  }
  return 0;
}

连续自然数之和

#include<bits/stdc++.h>
using namespace std;
long long l, r, m, s;
int main()
{
    cin >> m;
    l = 1, r = 2;
    //l不可能超过m/2,因为如果l,r都>m/2,则总和一定>m
    while(l <= m / 2 && r <= m)
    {
        s = (l + r) * (r - l + 1) / 2; //等差数列的区间和
        if(s == m)
        {
            cout << l << " " << r << endl;
            l++, r++;
        }
        else if(s < m) r++; //区间和太小,扩大
        else l++;//区间和太大,缩小
    }
    return 0;
}

删数

#include<bits/stdc++.h>
using namespace std;
string s;
int n, cnt;
int main()
{
    cin >> s >> n;
    s += ' ';
    while (n--)
    {
        for (int i = 0; i < s.size() - 1; i++)
        {
            if (s[i] > s[i + 1])
            {
                s.erase(i, 1);
                break;
            }
        }
    }
    while (s[0] == '0' && s.size() > 1)
        s.erase(0, 1);
    cout << s;
    return 0;
}

幂字符串

#include<bits/stdc++.h>
using namespace std;
string s,s1,str;
int cnt;
int main(){
    while(cin>>s&&s!="."){
        for(int i=0;i<s.size();i++){
            str+=s[i];
            s1="";
            cnt=0;
            while(s1.size()<s.size()){
                s1+=str;
                cnt++;
            }
            if(s1==s){
                cout<<cnt<<endl;
                break;
            }
        }
        str="";
    }
}

01背包

#include<bits/stdc++.h>
using namespace std;
int w[110], v[110], dp[110][20010]; // dp[i][j]:
int maxw, n;

int main()
{
    cin >> maxw >> n;
    for(int i = 1; i <= n; i++)
    {
        cin >> w[i] >> v[i];
    }
    for(int i = 1; i <= n; i++)
    {
        for(int j = 1; j <= maxw; j++)
        {
            if(j >= w[i])
            {
                dp[i][j] = max(v[i] + dp[i-1][j-w[i]],  dp[i-1][j]);
            }
            else
            {
                dp[i][j] = dp[i-1][j];
            }
        }
    }
    cout << dp[n][maxw];
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
06-01
这道题是一道典型的费用限制最短路题目,可以使用 Dijkstra 算法或者 SPFA 算法来解决。 具体思路如下: 1. 首先,我们需要读入输入数据。输入数据中包含了道路的数量、起点和终点,以及每条道路的起点、终点、长度和限制费用。 2. 接着,我们需要使用邻接表或邻接矩阵来存储图的信息。对于每条道路,我们可以将其起点和终点作为一个有向边的起点和终点,长度作为边权,限制费用作为边权的上界。 3. 然后,我们可以使用 Dijkstra 算法或 SPFA 算法求解从起点到终点的最短路径。在这个过程中,我们需要记录到每个点的最小费用和最小长度,以及更新每条边的最小费用和最小长度。 4. 最后,我们输出从起点到终点的最短路径长度即可。 需要注意的是,在使用 Dijkstra 算法或 SPFA 算法时,需要对每个点的最小费用和最小长度进行松弛操作。具体来说,当我们从一个点 u 经过一条边 (u,v) 到达另一个点 v 时,如果新的费用和长度比原来的小,则需要更新到达 v 的最小费用和最小长度,并将 v 加入到优先队列(Dijkstra 算法)或队列(SPFA 算法)中。 此外,还需要注意处理边权为 0 或负数的情况,以及处理无法到达终点的情况。 代码实现可以参考以下样例代码: ```c++ #include <cstdio> #include <cstring> #include <queue> #include <vector> using namespace std; const int MAXN = 1005, MAXM = 20005, INF = 0x3f3f3f3f; int n, m, s, t, cnt; int head[MAXN], dis[MAXN], vis[MAXN]; struct Edge { int v, w, c, nxt; } e[MAXM]; void addEdge(int u, int v, int w, int c) { e[++cnt].v = v, e[cnt].w = w, e[cnt].c = c, e[cnt].nxt = head[u], head[u] = cnt; } void dijkstra() { priority_queue<pair<int, int>, vector<pair<int, int>>, greater<pair<int, int>>> q; memset(dis, 0x3f, sizeof(dis)); memset(vis, 0, sizeof(vis)); dis[s] = 0; q.push(make_pair(0, s)); while (!q.empty()) { int u = q.top().second; q.pop(); if (vis[u]) continue; vis[u] = 1; for (int i = head[u]; i != -1; i = e[i].nxt) { int v = e[i].v, w = e[i].w, c = e[i].c; if (dis[u] + w < dis[v] && c >= dis[u] + w) { dis[v] = dis[u] + w; q.push(make_pair(dis[v], v)); } } } } int main() { memset(head, -1, sizeof(head)); scanf("%d %d %d %d", &n, &m, &s, &t); for (int i = 1; i <= m; i++) { int u, v, w, c; scanf("%d %d %d %d", &u, &v, &w, &c); addEdge(u, v, w, c); addEdge(v, u, w, c); } dijkstra(); if (dis[t] == INF) printf("-1\n"); else printf("%d\n", dis[t]); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值