5-45 航空公司VIP客户查询 (25分)

不少航空公司都会提供优惠的会员服务,当某顾客飞行里程累积达到一定数量后,可以使用里程积分直接兑换奖励机票或奖励升舱等服务。现给定某航空公司全体会员的飞行记录,要求实现根据身份证号码快速查询会员里程积分的功能。

输入格式:

输入首先给出两个正整数NN(\le 10^5≤10?5??)和KK(\le 500≤500)。其中KK是最低里程,即为照顾乘坐短程航班的会员,航空公司还会将航程低于KK公里的航班也按KK公里累积。随后NN行,每行给出一条飞行记录。飞行记录的输入格式为:18位身份证号码(空格)飞行里程。其中身份证号码由17位数字加最后一位校验码组成,校验码的取值范围为0~9和x共11个符号;飞行里程单位为公里,是(0, 15 000]区间内的整数。然后给出一个正整数MM(\le 10^5≤10?5??),随后给出MM行查询人的身份证号码。

输出格式:

对每个查询人,给出其当前的里程累积值。如果该人不是会员,则输出No Info。每个查询结果占一行。

输入样例:

4 500
330106199010080419 499
110108198403100012 15000
120104195510156021 800
330106199010080419 1
4
120104195510156021
110108198403100012
330106199010080419
33010619901008041x

输出样例:

800
15000
1000
No Info注意hash函数的选取,一开始我选取了后四位果断超时,选取了后五位即可AC,尽量让Hash函数取值接近数据最大值,这样能减少很多冲突。
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
using namespace std;
#define MAXN 10005
typedef long long LL;
/*
hash表
*/

typedef struct node
{
    char id[20];
    LL miles;
    struct node* next;
}*List;
typedef struct tb
{
    LL Tablesize;
    List *list;
}*Hashlist;
LL Hash(char key[],LL size)
{
    LL tmp = 0;
    for(LL i=13;i<18;i++)
    {
        if(key[i]==‘x‘)
            tmp = (tmp*10+10)%size;
        else
            tmp = (tmp*10 + key[i]-‘0‘)%size;
    }
    return tmp;
}
LL NextPrim(LL x)
{
    LL j;
    for(LL i=x;;i++)
    {
        for(j=2;j*j<=i;j++)
            if(i%j==0)
                break;
        if(j*j>i)
            return i;
    }
}
Hashlist Init(LL size)
{
    Hashlist H = (Hashlist)malloc(sizeof(tb));
    H->Tablesize = NextPrim(size);
    H->list = (List*)malloc(sizeof(List)*H->Tablesize);
    for(LL i=0;i<H->Tablesize;i++)
    {
        H->list[i] = (List)malloc(sizeof(node));
        H->list[i]->next = NULL;
    }
    return H;
}
List Find(char key[],Hashlist H)
{
    List t = H->list[Hash(key,H->Tablesize)];
    List p = t->next;
    while(p!=NULL && strcmp(key,p->id))
        p = p->next;
    return p;
}
void Insert(char key[],LL miles,Hashlist H)
{
    List t = H->list[Hash(key,H->Tablesize)];
    List f = Find(key,H);
    if(f==NULL)
    {
        List tmp = (List)malloc(sizeof(node));
        tmp->miles = miles;
        strcpy(tmp->id,key);
        tmp->next = t->next;
        t->next = tmp;
    }
    else
    {
        (f->miles) += miles;
    }
}

int main()
{
    char id[20];
    LL tmp,n,m,k;
    scanf("%lld%lld",&n,&k);
    Hashlist H = Init(n);
    for(LL i=0;i<n;i++)
    {
        scanf("%s%lld",id,&tmp);
        if(tmp<k) tmp = k;
        Insert(id,tmp,H);
    }
    scanf("%lld",&m);
    for(LL j=0;j<m;j++)
    {
        scanf("%s",id);
        List f = Find(id,H);
        if(f==NULL)
            printf("No Info\n");
        else
            printf("%lld\n",f->miles);
    }
}
				
时间: 2024-08-11 01:36:15

5-45 航空公司VIP客户查询 (25分)的相关文章

7-13 航空公司VIP客户查询 (25 分)

题意: ? 思路: 读完题目之后的第一思路就是用map将客户的id(string类型)与里程road(int类型)形成映射,然后直接用id查找添加里程或输出里程.但是400ms的限制妥妥的超时了.然后意识到要用哈希做,但是用哈希就有一点不好解决,每个客户的里程怎么保存,考虑了很长时间无果,搜了一下博客,发现可以用结构体来保存,平常用数组模拟链表的时候都是直接开的一维数组,所以当每个客户的信息多了后就没有结构体来的理解方便了. 第一次尝试:这个题N的上限是1e5,所以将每个客户的id转换成long

ShopNum1微分销商城系统与您看:航空公司与去哪儿继续跨年大战

尽管对于航空公司暂停合作事件的态度有了180度的大转弯,但"去哪儿"网与航空公司之间的"战火"似乎并没有熄灭的迹象.1月7日,又有几家航空公司陆续宣布撤出"去哪儿"网旗舰店. 从2015年的最后一天到1月6日,包括南航.海航.国航.东航.四川航空等国内主要航空公司,陆续宣布暂停与"去哪儿网"的合作,而即使在6日晚间"去哪儿"网表示要自查并进行监管升级后,7日当日仍有包括乌鲁木齐航空.福州航空.北部湾航空在内

“携手见证,共谋未来”——捷配VIP客户沙龙·杭州站

2019年12月28日,捷配VIP客户沙龙·杭州站正式拉开帷幕,参加本次沙龙的嘉宾主要来自江浙沪,12位捷配VIP客户代表参加此次沙龙. 本次沙龙活动分为嘉宾签到.参观捷配.嘉宾自我介绍.捷配CEO分享.茶歇.捷配COO答疑.意见调查反馈.晚宴环节. 嘉宾签到 担任本次沙龙主持的是捷配信用中心负责人斑马,首先表达了对在座嘉宾的感谢,接着开启了嘉宾自我介绍环节,并对为什么选择捷配给出了自己的答案. 和捷配合作了多年,他们用诚信征服了我,承诺下单24小时到,逾期赔偿,之前在其他工厂下单,语气赔偿都是

为方便旅客,某航空公司拟开发一个机票预定系统。

航空订票系统技术在目前是一个技术上成熟的系统,并且在航空公司内部准备采取有力措施保证资金和人员配置等. 因此,分阶段开发“航空订票系统”的构想是可行的.为了使航空公司适应现代化市场竞争的需求,促进机票预订管理信息 化,不断满足旅客预订机票的要求,争取更好的经济效益,可立即着手系统的开发与完善. 1> 目标:在一个月内建立一个高效率,无差错的航空公司机票预定系统 2> 存在的主要问题:人工不易管理,手续繁琐 3> 建立新系统 ① 经济可行性                成本效益分析 成本

2.3为方便旅客,某航空公司拟开发一个机票预定系统。 写出问题定义并分析系统的可行性。

为方便旅客,某航空公司拟开发一个机票预定系统.旅行社把预定机票的旅客信息(姓名.性别.工作单位.身份证号码.旅行时间.旅行目的地等)输入进 入该系统,系统为旅客安排航班,印出取票通知和账单,旅客在飞机起飞的前一天凭取票通知和账单交款取票,系统校对无误即印出机票给旅客. 写出问题定义并分析系统的可行性. 1>     目标:在一个月内建立一个高效率,无差错的航空公司机票预定系统 2>     存在的主要问题:人工不易管理,手续繁琐 3>     建立新系统 ①  经济可行性        

为方便旅客,某航空公司拟开发一个机票预订系统。旅行社把预订机票的旅客信息(姓名、性别、工作单位、身份证号码、旅行时间、旅行目的地等)输入进该系统,系统为旅客安排航班,印出取票通知和账单,旅客在飞机起飞的前一天凭取票通知和账单交款取票,系统校对无误即印出机票给旅客。写出问题定义并分析此系统的可行性。

1> 目标:在一个月内建立一个高效率,无差错的航空公司机票预定系统 2> 存在的主要问题:人工不易管理,手续繁琐 3> 建立新系统 ① 经济可行性                成本效益分析 成本估算:打印机一台(2000元)+开发费(3500元)=5500元 可承担 效益估算:该系统有很好的社会效益,提高了航空公司售票效率,方便了旅客,售票方便化,科学化 ② 技术可行性 经过调查分析,得到目前航空公司机票预定系统流程图如下: ③操作的可行性 比较以上两图看出,与人工系统相比,计算机保留

航空公司机票代理费或取消

继今年1月各大航空公司将机票代理费率下调至1%后,南方航空昨天宣布,从2015年6月1日起,将国内机票代理手续费从1%调整为0.根据惯例,四大航中只要有一家率先调整代理费,其他航空公司就会跟进.业内人士指出,全面取消机票代理费后,中小票代将被洗出局. 南航给各子公司市场销售部和营业部的通知文件显示,为了适应市场变化,自2015年6月1日起,在中国境内(不含香港.澳门.台湾地区),南航客运销售代理人的代理手续费将从原来的1%调整为0%. 就在去年6月,国航宣布将国内机票的销售代理费从沿用了6年的3

公司产品目录查询管理系统源码ASP.NET制作

方便的进行产品目录的查询,可以添加删除修改产品,简单实用. 参考网址:http://cp.sqffz.com 淘宝网地址: http://item.taobao.com/item.htm?spm=686.1000925.1000774.50.P4KGEq&id=40153373613 QQ:109626141 公司产品目录查询管理系统源码ASP.NET制作

4-9 二叉树的遍历 (25分)

4-9 二叉树的遍历   (25分) 输出样例(对于图中给出的树): Inorder: D B E F A G H C I Preorder: A B D F E C G H I Postorder: D E F B H G I C A Levelorder: A B C D F G I E H 代码:(都是遍历的算法) 1 // 4-9 二叉树的遍历 2 // 3 // Created by Haoyu Guo on 04/02/2017. 4 // Copyright ? 2017 Haoy