1.日期问题:

输入:

例题:

代码:

#include <stdio.h>
#include <bits/stdc++.h>
struct node{
int year, mouth, day;
}p;
int f[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; int main(){
while( scanf("%d%d%d", &p.year, &p.mouth, &p.day)!=EOF ){
//1.首先判断是不是闰年
if( (p.year%400==0)||(p.year%4==0 && p.year%100!=0) ){
f[2] = 29;//是闰年,二月为29天
}else{
f[2] = 28;//不是闰年
}
//2.判断输入的年月日是否合法
int flag = 0;
//2.1.判断月份
if( p.mouth<1 || p.mouth>12 ){
flag = 1;
}
//2.2.判断日
for( int i=1; i<=12; i++ ){
if( p.day<1 || p.day>f[i] ){
flag = 1;
}
}
if( flag ){
printf("Input Error\n");
}
//3.计算当前日子是第多少天
int sum = 0;
int nowDay = p.day;
for( int i=1; i<p.mouth; i++ ){
sum += f[i];
}
sum += nowDay;
printf("%d\n", sum);
}
return 0;
}

注意点:

怎么判断闰年:

(p.year%400==0)或者(p.year%4==0 && p.year%100!=0) 

2.字符串问题:

例题:

代码:

#include <stdio.h>
#include <string.h>
#include <bits/stdc++.h> int main(){
char s[105];
gets(s);//输入一行文本
int len = strlen(s);
for(int i=0; i<len; i++){
//大写字母or小写字母
if(s[i]>='A' && s[i]<='Z'){
s[i] += 3;
}else if(s[i]>='a' && s[i]<='z'){
s[i] += 3;
}else{
//其他的不处理
continue;
}
}
puts(s);//输出一行文本
return 0;
}

3.排序问题:

sort函数:

例题:

解析:

代码:

#include <bits/stdc++.h>
using namespace std; /*
//问题一:稳定排序
struct Student{
string name;
int score, id;
}stu[1005]; //自定义:从小到大函数
bool FromShortToBig(Student a, Student b){
if( a.score==b.score ){
return a.id < b.id;//一样大,根据id判断
}
return a.score < b.score;//哪个小哪个在前面
}
//自定义:从大到小函数
bool FromBigToShort(Student a, Student b){
if( a.score==b.score ){
return a.id < b.id;//一样大,根据id判断
}
return a.score > b.score;//哪个大哪个在前面
} int main(){
int n, model;
cin >> n;
cin >> model;
//输入数据
for(int i=0; i<n; i++){
cin >> stu[i].name >> stu[i].score;
stu[i].id = i;//给id赋值
}
//判断哪种模式
if( model==0 ){
sort(stu, stu+n, FromBigToShort);
}else{
sort(stu, stu+n, FromShortToBig);
}
//打印
for(int i=0; i<n; i++){
cout << stu[i].name << " " << stu[i].score << endl;
}
return 0;
}
*/ //问题二:先奇后偶、再按从小到大顺序排序
bool cmp(int a, int b){
if( a%2==b%2 ){//同为奇数or偶数:按从小到大顺序排序
return a < b;
}else{
return a%2 > b%2;//不同:按先奇后偶顺序排序
}
} int main(){
int n;
cin >> n;
int a[n];
for(int i=0; i<n; i++){
cin >> a[i];
}
sort(a, a+n, cmp);
for(int i=0; i<n; i++){
cout << a[i] << " ";
}
cout << endl;
return 0;
}

《N诺机试指南》(八)日期、字符串、排序问题的更多相关文章

  1. 《N诺机试指南》(五)进制转化

    进制转化类题目类型: 代码详解及注释解答:  //进制转化问题 #include <bits/stdc++.h> using namespace std; int main(){ // 1 ...

  2. 《N诺机试指南》(二)C++自带实用函数

    1.排序sort函数: 2.查找:  实例:  3. 队列:

  3. 《N诺机试指南》(三)STL使用

    1.vector 2.queue 3.stack 4.map 5.set 6.多组输入输出问题 详解见代码以及注释: //学习STL的使用 #include <bits/stdc++.h> ...

  4. 《N诺机试指南》(七)排版类问题

    1.菱形问题: 解析: 主要通过打印空格和星形来打印整个图形,将整体分为=上三角形+下三角形 首先观察上三角形可以发现:第一行2个空格1个星.第二行1个空格3个星.第三行0个空格5个星     空格数 ...

  5. 《N诺机试指南》(一)数组妙用

    题目A: 大家思路有可能是这样: 将输入数据全部存储到一个数组里,然后可以冒泡排序一波,从小到大排序 那么怎么找到重复次数呢:我是这样想的,新定义数组b,原数组a,首先b[0] = a[0],定义指针 ...

  6. 机试指南第二章-经典入门-Hash的应用自解

    Hash的应用: Hash即散列,不像数据结构与算法中讲的各种Hash方法和冲突处理等过多的阐述,以下主要介绍Hash在机试试题解答中的作用. 例2.5 统计同成绩学生人数 Hash解法AC代码:(一 ...

  7. 王道机试指南题解(C/C++版)

    第 2 章 经典入门 一 排序 例 2.1 排序 代码 2.1 冒泡排序(时间复杂度 \(O(n^2)\)) #include <iostream> using std::cin; usi ...

  8. 华为机试001:字符串最后一个单词的长度(华为OJ001)

    华为机试 字符串最后一个单词的长度 计算字符串最后一个单词的长度,单词以空格隔开. 提交网址: http://www.nowcoder.com/practice/8c949ea5f36f422594b ...

  9. 2014华为机试西安地区A组试题

    2014华为机试西安地区A组试题 题目一.分苹果 M个同样苹果放到N个同样篮子里有多少种放法,同意有篮子不放. 1<=M<=10.1<=N<=10 比如5个苹果三个篮子,3,1 ...

随机推荐

  1. java中多线程入门有趣介绍

    我们在网上可以看到所有有关于java的线程的基本概念的很多解释,不乏有很多详细经典的解释和代码解说.但是我们的很多初学者看完不能有一个直观的印象,特别是一些没有编程基础的学习者,很多时候要花很多时间去 ...

  2. day22- hashlib模块-摘要算法(哈希算法)

    # python的hashlib提供了常见的摘要算法,如md5(md5算法),sha1等等.摘要:digest # 摘要算法又称哈希算法.散列算法. # 它通过一个函数,把任意长度的数据(明文)转换为 ...

  3. linux 上安装 java

    一.源码安装 1.本地下载 java, 并上传到 linux 上 2.解压文件  tar -zxvf jdk-7u72-linux-i586.gz 3.配置环境变量  vi /etc/profile ...

  4. 关于 SQLServer Express 2012 的连接字符串

    调试的时候,使用的是 LocalDB,SqlConnection 的连接字符串很简单 Data Source=(localdb)\ProjectsV12;Initial Catalog=master; ...

  5. EX_KMP算法总结

    EX_KMP算法总结 By viv 2014-8-9 0:30 吐槽1:字符串神马的我最讨厌了,但不学不行啊.TAT 吐槽2:写这东西差点错过CF(codeforces). 今天学了ex_kmp,故总 ...

  6. Linux quota磁盘配额

    quota:磁盘配额 限制某一群组所能使用的最大磁盘配额 限制某一用户的最大磁盘配额 使用限制: 仅能针对整个filesystem 核心必须支持quota quota的记录文件 只对一般身份使用者有效 ...

  7. python语法基础-常用模块-长期维护

    ###############      常用模块   ################ # 常用模块: # 1,collections模块 # 2,时间模块,time模块,datatime模块 # ...

  8. ArcGIS Server10.2忘记密码怎么办?重置ArcGIS Server Manager密码

    忘记了ArcGIS Server Manager的密码不要慌张,下面简单的几步就可以重置密码. 第一步:找到ArcGIS Server的安装目录,然后找到..\ArcGIS\Server\tools\ ...

  9. python中编码判断

    https://www.cnblogs.com/lc-D-a/p/6074878.html python3 用isinstance()检查unicode编码报错

  10. XML的打包与解析

    XML的打包与解析 一.XML语言的特点       1.XML独立于任何编程语言,允许人们按接收者容易解析的方式,对复杂数据进行编码.先来看一个简单的XML格式的文件: [XML] 纯文本查看 复制 ...