IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 查询无效交易-c语言 -> 正文阅读

[C++知识库]查询无效交易-c语言

查询无效交易

如果出现下述两种情况,交易 可能无效:

交易金额超过 $1000
或者,它和 另一个城市 中 同名 的另一笔交易相隔不超过 60 分钟(包含 60 分钟整)

给定字符串数组交易清单 transaction 。每个交易字符串 transactions[i] 由一些用逗号分隔的值组成,这些值分别表示交易的名称,时间(以分钟计),金额以及城市。

返回 transactions,返回可能无效的交易列表。你可以按 任何顺序 返回答案。
示例 1:

输入:transactions = [“alice,20,800,mtv”,“alice,50,100,beijing”]
输出:[“alice,20,800,mtv”,“alice,50,100,beijing”]
解释:第一笔交易是无效的,因为第二笔交易和它间隔不超过 60 分钟、名称相同且发生在不同的城市。同样,第二笔交易也是无效的。

示例 2:

输入:transactions = [“alice,20,800,mtv”,“alice,50,1200,mtv”]
输出:[“alice,50,1200,mtv”]

示例 3:

输入:transactions = [“alice,20,800,mtv”,“bob,50,1200,mtv”]
输出:[“bob,50,1200,mtv”]
解题代码如下:

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */

 int f1(char *ch){
     int i=0;
     int s=0;
      while(ch[i++]!=','){
          
    }
      while(ch[i++]!=','){
 
    }
    while(ch[i]!=','){
      //  printf("%c ",ch[i]);
        s=s*10+ch[i]-'0';
        i++;
    }
    printf("%d ",s);
    if(s>1000){
        return 0;
    }
    else return 1;

 }
 int f2(char *ch1,char *ch2){
     char s1_name[20],s1_city[20],s2_name[20],s2_city[20];
     int s1m=0,s2m=0;
     int i=0,j=0;
     int p1,p2;
       while(ch1[i]!=','){
           s1_name[i]=ch1[i];
           i++;
    }
       while(ch2[j]!=','){
           s2_name[j]=ch2[j];
           j++;
    }
    s1_name[i]='\0';
    s2_name[j]='\0';
    i++;
    j++;
//    printf("%s %s",s1_name,s2_name);
    if(strcmp(s1_name,s2_name)==0){
    while(ch1[i]!=','){
         s1m=s1m*10+ch1[i]-'0';
         i++;
          
    }
      while(ch2[j]!=','){
           s2m=s2m*10+ch2[j]-'0';
         j++;
 
    }
    i++;
    j++;
       while(ch1[i++]!=','){
          
    }
      while(ch2[j++]!=','){
 
    }
    p1=0;
    p2=0;

     while(ch1[i]!='\0'){
           s1_city[p1]=ch1[i];
           i++;
           p1++;
    }
       while(ch2[j]!='\0'){
           s2_city[p2]=ch2[j];
           j++;
           p2++;
    }
    s1_city[p1]='\0';
    s2_city[p2]='\0';
  //  printf(" %s %s",s1_city,s2_city);

    if(strcmp(s1_city,s2_city)!=0){
      //  printf("%d %d ",s1m,s2m);
        if(abs(s2m-s1m)<=60){
            return 0;
        }
        else return 1;
    
    }
    else return 1;
    }
    else return 1;


 }
char ** invalidTransactions(char ** transactions, int transactionsSize, int* returnSize){
    int a[transactionsSize],i,j;
    int p=0;
    for(i=0;i<transactionsSize;i++){
        if(f1(transactions[i])){
            a[i]=1;
        }
        else a[i]=0;
    }
    for(i=0;i<transactionsSize;i++){
        
            j=i+1;
            if(j<transactionsSize){
                for(j;j<transactionsSize;j++){
                    
                        if(f2(transactions[i],transactions[j])==0){
                        a[i]=0;
                        a[j]=0;
                    
                        
                    }


                }
            }
           
        
     
    }
for(i=0;i<transactionsSize;i++){
    if(a[i]==0){
        transactions[p++]=transactions[i];
    }
}


*returnSize=p;
return transactions;

}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-18 17:22:53  更:2022-04-18 17:23:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 0:09:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码