【洛谷题单---函数与结构体题解】

2023-11-02 11:30
文章标签 函数 结构 题解 洛谷题

本文主要是介绍【洛谷题单---函数与结构体题解】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.【P5735 【深基7.例1】距离函数】

 

【题解】

#include <iostream>
#include <iomanip>
#include <cmath>
using namespace std;
double x1, x2, y, y2,x3,y3;
double m(double x1, double y1, double x2, double y2,double x3,double y3)
{double n = sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2))+sqrt((x1 - x3) * (x1 - x3) + (y1 - y3) * (y1 - y3))+sqrt((x3 - x2) * (x3 - x2) + (y3 - y2) * (y3 - y2));return n;
}
int main()
{double m(double x1, double y1, double x2, double y2,double x3,double y3);double q;cin >> x1 >> y >> x2 >> y2>>x3>>y3;q = m(x1, y, x2, y2,x3,y3);cout << fixed<<setprecision(2)<<q;//保留小数点后两位小数return 0;
}

2.【P5736 【深基7.例2】质数筛】

#include <iostream>
using namespace std;
int pd(int m)
{if(m==1)return 0;//特判1的情况for(int i=2;i<m;i++){if(m%i==0)return 0;}return 1;
}
int main()
{int n,m,i=0;cin>>m;int a[m];for(i=0;i<m;i++)cin>>a[i];for(i=0;i<m;i++){    if(pd(a[i]))cout<<a[i];}return 0;
}


3【P5738 【深基7.例4】歌唱比赛】

#include <iostream>
#include <algorithm>
#include <iomanip>
using namespace std;
int m,a[20];
double hs(int a[],int m)
{int s=0;double s2=0;for(int i=1;i<m-1;i++)//跳过了最低分a[0]和最高分a[m-1];{s+=a[i];}s2=s*1.0/(m-2);return s2;}
int main()
{double hs(int a[],int m);int i,n,m;cin>>n>>m;int a[m];double pj[n];for(int j=0;j<n;j++){for(i=0;i<m;i++){cin>>a[i];//i在输入每组唱歌成绩时从0--m的变化;}sort(a,a+m);pj[j]=hs(a,m);//传的是排好顺序的a的首地址;pj[j]存的是每组平均成绩}sort(pj,pj+n);cout<<fixed<<setprecision(2)<<pj[n-1];
}

【运行结果】

7 6
4 7 2 6 10 7
0 5 0 10 3 10
2 6 8 4 3 6
6 3 6 7 5 8
5 9 3 3 8 1
5 9 9 3 2 0
5 8 0 4 1 10
6.00
Process returned 0 (0x0)   execution time : 64.820 s
Press any key to continue.


4.【P1075 [NOIP2012 普及组] 质因数分解】

#include <iostream>
using namespace std;
int sz(int a[2],int n)
{for (int i = 2; i < n; i++){if(n%i==0){a[0] = i;a[1]=n/i;//减少时间复杂度,否则会超时break;}}return a[1];//a[1]即较大的那个质数
}
int main()
{int n, a[2];cin >> n;int max = sz(a, n);cout << max;
}

5.【P5742 【深基7.例11】评等级】

 

#include<bits/stdc++.h>
using namespace std;
struct student
{int xh,xy,sz;};
int main()
{int N;cin>>N;struct student a[N];//知道N,方便设数组长度for(int i=0;i<N;i++){cin>>a[i].xh>>a[i].xy>>a[i].sz;if(a[i].xy+a[i].sz>140&&(0.7*a[i].xy+a[i].sz*0.3)>=80)cout<<"Excellent"<<"\n";else cout<<"Not excellent\n";}
}


6.【旗鼓相当的对手-加强版】


#include <iostream>
#include <algorithm>
using namespace std;
struct stu
{string name;int cg,mg,eg,s;
}z[1000],a[1005];
bool cmp(stu a,stu b){return a.name<b.name;}//注意传的参数,是新定义的 结构体类型名+结构体对象;
int main()
{int N,i,j;cin>>N;for(i=0;i<N;i++){cin>>z[i].name>>z[i].cg>>z[i].mg>>z[i].eg;z[i].s=z[i].cg+z[i].mg+z[i].eg;}sort(z,z+N,cmp);//先排序再处理;for(i=0;i<N-1;i++)for(j=i+1;j<N;j++)//依次查找符合条件的情况{int scj=abs(z[i].s-z[j].s);//abs()返回()内的绝对值;int ccj=abs(z[i].cg-z[j].cg);int mcj=abs(z[i].mg-z[j].mg);int ecj=abs(z[i].eg-z[j].eg);if(scj<=10&&ccj<=5&&mcj<=5&&ecj<=5)cout<<z[i].name<<" "<<z[j].name<<endl;}return 0;
}

7【P1304哥德巴赫猜想】

#include <iostream>
using namespace std;
bool pd(int n)
{for(int i=2;i<n;i++)if(n%i==0)return false; return true;
}
int main()
{int N,i,j=2;cin>>N;for(i=4;i<=N;i+=2){for(j=2;j<=i/2;j++){if(pd(j)&&pd(i-j))               //用i-j减少时间复杂度{cout<<i<<'='<<j<<'+'<<i-j<<endl;break;}}}return 0;
}

8.P2415【集合求和】

#include<iostream>
#include<cmath>
using namespace std;
long long s=0,a,i=0;
int main()
{while(cin>>a)  //结束循环的方式为先按 Ctrl+z 键,再回车;{i++;s+=a;}cout<<(long long)(s*pow(2,i-1));return 0;
}

说明:(1)long long在计算过程被隐式转换成了double,需要用强制类型转换转换回long long输出。

(2)while(cin>>a)  //结束循环的方式为先按 Ctrl+z 键,再回车;

  (3)规律:设集合中的元素总共有n个,该集合的所有子集中,每个元素出现的次数为2的(n-1)次方;


9.【P5744 【深基7.习9】培训】

 

#include<iostream>
using namespace std;
struct student
{string name;int age,score;
}a[10000];
int main()
{int n,i;cin>>n;int a[n];for(i=0;i<n;i++){cin>>a[i].name;cin>>a[i].age>>a[i].score;a[i].age++;if(a[i].score/5*6<600)a[i].score=a[i].score/5*6;else a[i].score=600;}for(i=0;i<n;i++){cout<<a[i].name<<' '<<a[i].age<<" "<<a[i].score;cout<<endl;}return 0;
}

 10.【P1217 [USACO1.5]回文质数 Prime Palindromes】

 

#include <iostream>
#include <cmath>
using namespace std;
int ss(int m)                            // 判断素数(质数)
{if(m==1||m%2==0) return 0;for(int i=2;i<=sqrt(m);i++){if(m%i==0)return 0;}return 1;
}
int pd(int m)            //判断回文数
{int n=m,s=0;while(n!=0){s=s*10+n%10;n/=10;}if(m==s)return 1;return 0;
}
int main()
{int i,n,j;cin>>i>>n;for(j=i;j<=n;j++){if(j>1e7)break;        //实验得的  !不加上本句会REif(j%2==0) continue;   //回文质数不可能为偶数if((pd(j))&&(ss(j)))cout<<j<<endl;}return 0;
}

11.【P5743 【深基7.习8】猴子吃桃】

 (用函数做真的香,少死了多少脑细胞)

#include<iostream>
#include<cmath>
using namespace std;
int f(int l)
{return (l+1)*2;          //上一天没吃之前的数目
}
int main()
{int n,i,s=1;                  // s为最后一天剩余的桃子数cin>>n;for(i=0;i<n-1;i++){s=f(s);}cout<<s;return 0;
}

12.【P5461 赦免战俘】

(推荐学习路径>>杨辉三角--南蛮图腾--赦免战俘)

 

#include <iostream>using namespace std;
int a[1050][1050];      //找最大的内存容量,并且定义在主函数外面
void cal(int x,int y,int n)
{if(n==0) a[x][y]=1;else {cal(x+(1<<(n-1)),y,n-1);//右上cal(x,y+(1<<(n-1)),n-1);//左下}cal(x+(1<<(n-1)),y+(1<<(n-1)),n-1);//右下}
}
int main()
{int n,i,j;cin>>n;cal(0,0,n);for(i=0;i<1<<n;i++)for(j=0;j<1<<n;j++){cout<<a[i][j];if(j==(1<<n)-1)           //1<<n相当于1*2^ncout<<endl;else cout<<' ';}return 0;
}

13.P5737 【深基7.例3】闰年展示

闰年的计算方法

判断是否为闰年的两个条件
1、能被400整除
2、能被4整除但不能被100整除

#include <iostream>
using namespace std;
int pd(int x)
{if(((x%4==00)&&(x%100!=0))||(x%400==0))return 1;return 0;
}
int main()
{int n,m,i,k=0,a[1500];cin>>n>>m;for(i=n;i<=m;i++){if(pd(i)){a[k]=i;k++;}}cout<<k<<endl;for(i=0;i<k;i++)cout<<a[i]<<" ";
}

14.P5740 【深基7.例9】最厉害的学生

#include <iostream>
using namespace std;
struct stu
{string name;int cg,mg,eg;
}z[1000];
int main()
{int N,max=0,t=0;cin>>N;for(int i=0;i<N;i++)  //打擂台的方法找max{cin>>z[i].name>>z[i].cg>>z[i].mg>>z[i].eg;if(z[i].cg+z[i].mg+z[i].eg>max){max=z[i].cg+z[i].mg+z[i].eg;t=i;}}cout<<z[t].name<<' '<<z[t].cg<<" "<<z[t].mg<<' '<<z[t].eg;return 0;
}

这篇关于【洛谷题单---函数与结构体题解】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/330297

相关文章

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者

结构体和联合体的区别及说明

《结构体和联合体的区别及说明》文章主要介绍了C语言中的结构体和联合体,结构体是一种自定义的复合数据类型,可以包含多个成员,每个成员可以是不同的数据类型,联合体是一种特殊的数据结构,可以在内存中共享同一... 目录结构体和联合体的区别1. 结构体(Struct)2. 联合体(Union)3. 联合体与结构体的

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)