九度OJ 1361(反转) 1362(循环移位) 1363(判断) 1364(01背包) 1365(BFS)

2024-04-02 01:58

本文主要是介绍九度OJ 1361(反转) 1362(循环移位) 1363(判断) 1364(01背包) 1365(BFS),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1361:翻转单词顺序

http://ac.jobdu.com/problem.php?pid=1361

题意

将一行英文句子按单词反转。

思路

二维字符串存储,反转外围即可。

代码

#include <stdio.h>
#include <string.h>#define M 50000int main(void)
{int n, i, j, m, k;char s[M+1];while (gets(s)){n = strlen(s);i = n;while (i>0){m = i;while (i >= 0 && s[--i] == ' ');if (i<0)break;k = i;if (m != n){for (j=i+1; j<=m; j++)printf(" ");}while (i >= 0 && s[--i] != ' ' );//if (m != n)//  printf(" ");for (j=i+1; j<=k; j++)printf("%c", s[j]);}printf("\n");}return 0;
}
/**************************************************************Problem: 1361User: liangrx06Language: CResult: AcceptedTime:210 msMemory:912 kb
****************************************************************/

1362:左旋转字符串

http://ac.jobdu.com/problem.php?pid=1362

题意

实现字符串的循环左移。

思路

用另外一个字符串存储要左移会被覆盖的那部分,然后放到后面即可。

代码

#include <stdio.h>
#include <string.h>#define N 1000int main(void)
{
    int k, i, n;
    char s[N+1], s2[N+1];    while (scanf("%s%d", s, &k) != EOF)
    {
        strcpy(s2, s);        n = strlen(s);
        k = k%n;
        for (i=0; i<n-k; i++)
            s[i] = s2[i+k];
        for (; i<n; i++)
            s[i] = s2[i+k-n];        printf("%s\n", s);
    }    return 0;
}
/**************************************************************
    Problem: 1362
    User: liangrx06
    Language: C
    Result: Accepted
    Time:70 ms
    Memory:912 kb
****************************************************************/

1363:欢乐斗地主

http://ac.jobdu.com/problem.php?pid=1363

题意

找出在上家出的牌是“三带一对”的情况下你手中的牌是否比上家的牌大。

思路

主要是注意特殊情况的考虑,比较简单。

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define N 20int cmp(const void *a, const void *b)
{return *(int *)a - *(int *)b;
}int main(void)
{int n, i, j, x;int a[N], b[N], rank[N];while (scanf("%d", &n) != EOF){memset(rank, 0, sizeof(rank));for(i=0; i<n; i++){scanf("%d", &a[i]);if (a[i] <= 2)a[i] += 13;rank[a[i]]++;}for(i=0; i<5; i++)scanf("%d", &b[i]);x = b[0];if (x <= 2)x += 13;for (i=x+1; i<=15; i++){if (rank[i] >= 3){for (j=3; j<=15; j++){if (j == i)continue;if (rank[j] >= 2)break;}if (j <= 15)break;}}if (i <= 15){if (i > 13)i -= 13;if (j > 13)j -= 13;printf("%d %d %d %d %d\n", i, i, i, j, j);}elseprintf("My God\n");}return 0;
}
/**************************************************************Problem: 1363User: liangrx06Language: CResult: AcceptedTime:70 msMemory:912 kb
****************************************************************/

1364:v字仇杀队

http://ac.jobdu.com/problem.php?pid=1364

题意

在地铁有限的空间中装载挑选出来的炸药使得地铁的破坏力最大。

思路

其实就是最基本的01背包。

代码

#include <stdio.h>
#include <string.h>#define N 100
#define M 1000int main(void)
{
    int s, n, i, j;
    int room[N], power[N];
    int dp[M+1];    while (scanf("%d%d", &s, &n) != EOF)
    {
        for(i=0; i<n; i++)
            scanf("%d%d", &room[i], &power[i]);        memset(dp, 0, sizeof(dp));
        for(i=0; i<n; i++)
        {
            for(j=s; j>=room[i]; j--)
            {
                int tmp = dp[j-room[i]] + power[i];
                dp[j] = (tmp > dp[j]) ? tmp : dp[j];
            }
        }        printf("%d\n", dp[s]);
    }    return 0;
}
/**************************************************************
    Problem: 1364
    User: liangrx06
    Language: C
    Result: Accepted
    Time:170 ms
    Memory:912 kb
****************************************************************/

1365:贝多芬第九交响曲

http://ac.jobdu.com/problem.php?pid=1365

题意

在一张二维棋盘上,按照中国象棋马的走法,从起点到终点的步数。

思路

基本的广度优先搜索,注意起点终点相同这种特殊情况的判断。

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <queue>
using namespace std;const int N = 100;
const int INF = 0x3f3f3f3f;int n;bool legal(int x, int y)
{return x >= 0 && x < n && y >= 0 && y < n;
}int BFS()
{int sx, sy, ex, ey;cin >> sx >> sy >> ex >> ey;sx--, sy--, ex--, ey--;int i;int d[N][N];typedef pair<int, int> P;queue <P> q;for (i = 0; i < n; i ++)fill(d[i], d[i]+n, INF);q.push(P(sx, sy));d[sx][sy] = 0;int pos[8][2] = {{1, 2}, {2, 1}, {1, -2}, {-2, 1},{-1, 2}, {2, -1}, {-1, -2}, {-2, -1}};while( q.size() ) {P p = q.front();q.pop();int x = p.first;int y = p.second;if (x == ex && y == ey)return d[x][y];for (i = 0; i < 8; i ++) {int nx = x + pos[i][0];int ny = y + pos[i][1];if (legal(nx, ny) && d[nx][ny] == INF) {q.push(P(nx, ny));d[nx][ny] = d[x][y]+1;}}}return -1;
}int main(void)
{while (cin >> n) {printf("%d\n", BFS());}return 0;
}
/**************************************************************Problem: 1365User: liangrx06Language: C++Result: AcceptedTime:730 msMemory:1524 kb
****************************************************************/

这篇关于九度OJ 1361(反转) 1362(循环移位) 1363(判断) 1364(01背包) 1365(BFS)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/868686

相关文章

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Python循环缓冲区的应用详解

《Python循环缓冲区的应用详解》循环缓冲区是一个线性缓冲区,逻辑上被视为一个循环的结构,本文主要为大家介绍了Python中循环缓冲区的相关应用,有兴趣的小伙伴可以了解一下... 目录什么是循环缓冲区循环缓冲区的结构python中的循环缓冲区实现运行循环缓冲区循环缓冲区的优势应用案例Python中的实现库

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Java嵌套for循环优化方案分享

《Java嵌套for循环优化方案分享》介绍了Java中嵌套for循环的优化方法,包括减少循环次数、合并循环、使用更高效的数据结构、并行处理、预处理和缓存、算法优化、尽量减少对象创建以及本地变量优化,通... 目录Java 嵌套 for 循环优化方案1. 减少循环次数2. 合并循环3. 使用更高效的数据结构4

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC