【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一) - 教程


个人主页艾莉丝努力练剑

❄专栏传送门:《C语言》《数据结构与算法》C语言刷题12天IO强训LeetCode代码强化刷题洛谷刷题C/C++基础知识知识强化补充C/C++干货分享&学习过程记录

学习方向:C/C++方向

⭐️人生格言:为天地立心,为生民立命,为往圣继绝学,为万世开太平

前言:本文主要用C语言和C++跟大家做一下洛谷的一些入门题,主要是分支机构的部分。



目录

正文 

1  Apples Prologue / 苹果和虫子

2  数的性质

3  闰年判断 

4  Apples

5  洛谷团队系统 

6  肥胖问题 

7  三位数排序

结尾


 C++的两个参考文档:

老朋友(非官方文档):cplusplus

官方文档(同步更新):cppreference


正文 

1  Apples Prologue / 苹果和虫子

题目链接:P5709 【深基2.习6】Apples Prologue / 苹果和虫子

题目描述:

代码演示:

#include
using namespace std;
int main()
{
int m,t,s;
cin>>m>>t>>s;
if(t==0)
{
cout<<0<

博主用的是C++的写法,关于C++,大家可以关注一下博主的专栏,会介绍许多C++方向的干货:

C/C++干货分享&学习过程记录

这道题我们主要注意要用到分类讨论的思想——

(1)先判断 t 是否为 0,为 0 我们直接打印,程序就结束了;

(2)如果 t 不为 0,我们再分类讨论——s % t 是否为 0,输出的就是对应的答案。

2  数的性质

题目链接:P5710 【深基3.例2】数的性质

题目描述:

代码演示:

#include
using namespace std;
int main()
{
int x;cin>>x;
if(x%2==0&&x>4&&x4&&x4&&x4&&x4&&x<=12))
cout<<1<<' ';
else
cout<<0<<' ';
return 0;
}

这道题我们逐个讨论,用if/else语句一个一个实现分别满足4个人要求的结果就可以了。

3  闰年判断 

题目链接:P5711 【深基3.例3】闰年判断

题目描述:

代码演示:

#include
using namespace std;
int main()
{
int n;cin>>n;
if((n%4==0) && (n%100!=0)
||(n%400==0))
cout<<1<

这道题是C语言中一道老生常谈的经典题目,只不过我们这次是要用C++来实现。

根据题目所给闰年满足的条件,我们就能写出代码:要么能被4整除且不能100整除(这是一个小的“且”的关系),要么就是能被400整除,这是一个大的“或”的关系。

4  Apples

题目链接:P5712 【深基3.例4】Apples

题目描述:

代码演示:

#include
using namespace std;
int main()
{
int x;cin>>x;
if(x==1)
cout<<"Today, I ate 1 apple."<

这道题也是一道老生常谈的经典题目,我们根据题目给出的条件写就没有问题了。

根据题目所给吃掉苹果的数量,我们分成三种情况,就能写出代码:

吃了1个、没吃和吃了超过1个三种情况,我们直接if/else if/else,关键是最后一个条件要传一个未知数x,我们不确定到底是多少,所以直接用占位符%d代替,传一个x,输出直接用printf,C++就是在C语言中生长出来的语言,可以用printf。

5  洛谷团队系统 

题目链接:P5713 【深基3.例5】洛谷团队系统

题目描述:

代码演示:

写法(1):

#define  _CRT_SECURE_NO_WARNINGS  1
#include
using namespace std;
int main()
{
int n; cin >> n;
int Jqj, Lmt;
Jqj = 5 * n;
Lmt = 11 + 3 * n;
if (Jqj < Lmt)
cout << "Local" << endl;
else
cout << "Luogu" << endl;
return 0;
}

写法(2):

#define  _CRT_SECURE_NO_WARNINGS  1
#include
using namespace std;
int main()
{
int n; cin >> n;
if ((5 * n)  (3 * n + 11))
cout << "Luogu" << endl;
return 0;
}

这道题依然是一道老生常谈的经典题目,我们根据题目给出的条件写就没有问题了。

本题我们只要比较5 * n 和 3 * n + 11 就可以了。

6  肥胖问题 

题目链接:P5714 【深基3.例7】肥胖问题

题目描述:

代码演示:

#include
using namespace std;
int main()
{
double m,h; cin>>m>>h;
double bmi=m/(h*h);
if(bmi=18.5&&bmi<24)
cout<<"Normal"<

这道题也是一道老生常谈的经典题目,我们根据题目给出的条件写就没有问题了。

这道题我们只要知道BMI的几个结点值:18.5、24就可以了。

7  三位数排序

题目链接:P5715 【深基3.例8】三位数排序

题目描述:

代码演示:

#include
using namespace std;
const int N=105;
int a[N];
int main()
{
for(int i=0;i>a[i];
}
sort(a,a+3);
for(int i=0;i<3;i++)
{
cout<

我们如果完全用C++的STL的sort排序就会异常简洁,代码演示如下:

#include
using namespace std;
int main()
{
int arr[3];
cin>>arr[0]>>arr[1]>>arr[2];
//C++的STL的sort排序
sort(arr,arr+3);
cout<

当然,用C语言也是可以写的,代码演示:

#include
int main()
{
int a, b, c;
scanf("%d %d %d", &a, &b, &c);
// 比较交换法排序
if (a > b)
{
int tmp = a;
a = b;
b = tmp;
}
if (a > c)
{
int tmp = a;
a = c;
c = tmp;
}
if (b > c)
{
int tmp = b;
b = c;
c = tmp;
}
printf("%d %d %d", a, b, c);
return 0;
}

这道题是一道老生常谈的经典题目,我们根据题目给出的条件写就没有问题了。

如果选择用C语言写,就直接比较交换进行排序,题目说从小到大,我们就用if语句分别判断a>c、a>b、b>c三种情况,再创建一个空的数组,把比较出来大的那个放到空数组tmp里面,再让大的那个的变量和小的那个变量一交换,再让原来存放小的那个变量(现在“空了”)等于数组tmp,让tmp里面存放的那个大的数覆盖这个变量里面存放的小的那个数,这样进行三次if语句判断,分别完成交换,我们就把小的全部交换到前面了,完成三位数排序了。


结尾

结语:本文的内容到这里就结束了,记得给博主“一键四连”哦!感谢支持!

posted @ 2025-08-21 21:46  wzzkaifa  阅读(8)  评论(0)    收藏  举报