C语言-详细讲解-洛谷P1424 小鱼的航程(改进版)

目录

1.题目要求

2.题目解读

3.代码实现

1.使用switch-case语句

2.使用for循环

3.不用循环(暴力版)


1.题目要求

2.题目解读

此题难点在于对天数的计算,这里我们可以考虑通过循环来算出小鱼游泳的天数

3.代码实现

1.使用switch-case语句

cpp 复制代码
#include<stdio.h>
int main()
{
	int x;
	long long int n,way=0;
	scanf("%d %lld",&x,&n);
	 for(int i=1;i<=n;i++)
	   {
	        switch(x)//对星期依次判断
	        {
	           case 1:case 2:case 3:case 4:case 5:way+=250;
	           case 6: x++;continue;//周六不进行 进行下一循环
	           case 7:x=1;continue;//周日清零为星期一 并进行下一循环
	        }
	      x++;//工作日情况下 进入下一日
	  }
	printf("%lld",way);
	return 0;
}

2.使用for循环

cpp 复制代码
#include<cstdio>
int main()
{
    int n,k,s=0;//周n开始游,过了k天,游了s公里
    scanf("%d %d",&n,&k);
    for(int i=1;i<=k;i++)//要游k天,所以用循环
    {
        if(n!=6 && n!=7) s+=250;//如果不是周末则加250
        if(n==7) n=1;//如果是周7,那么赋值为1
        else n++;//否则n+1
    }
    printf("%d",s);//输出游了多少公里
    return 0;
}

3.不用循环(暴力版)

cpp 复制代码
#include <stdio.h>

int begin,days,front,mid,end;

int main()
{
    scanf("%d %d",&begin,&days);
    front=6-begin;
    if(front<0)
        front=0;
    end=(days-8+begin)%7;
    if(end>5)
        end=5;
    mid=(days-8+begin-(days-8+begin)%7)/7*5;
	if(begin<=5&&begin+days-1<=5)
		printf("%d",days*250);
	else
	{
		if((mid+front+end)>=0)
			printf("%d",(mid+front+end)*250);
		else
			printf("0");
	}
}

***新人博主创作不易,希望大家多多点赞关注呀~

相关推荐
元亓亓亓8 分钟前
LeetCode热题100--230. 二叉搜索树中第 K 小的元素--中等
算法·leetcode·职场和发展
草莓熊Lotso8 分钟前
《算法闯关指南:优选算法-双指针》--01移动零,02复写零
c语言·c++·经验分享·算法·leetcode
焜昱错眩..1 小时前
代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
算法
焦耳加热5 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn5 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6065 小时前
常用排序算法核心知识点梳理
算法·排序
索迪迈科技7 小时前
基于野火F407开发板实现电源管理-停止模式
c语言·stm32·单片机·嵌入式硬件·mcu
蒋星熠7 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小莞尔8 小时前
【51单片机】【protues仿真】基于51单片机宠物投食系统
c语言·stm32·单片机·嵌入式硬件·51单片机
小欣加油8 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展