通话记录

已知 10 条通话记录,通话记录有三种类型:0 代表未接来电,1 代表已接来电,2 代表已拨电话。要求分别将三种类型前 10 条通话记录以三列的形式输出。

输入格式
输入 10 条通话记录,每条通话记录都占一行。每一行的第一个数字代表通话记录的类型,第二个数字代表电话号码,电话号码均由 11 个数字组成。他们之间用一个空格隔开。

输出格式
分三列输出未接来电、已接电话和已拨电话。
每列之间用一个空格分割,最后一列后没有空格。每种类型输出前十个电话,先出现的通话记录先输出,不足十个的用 0 占位。

#include<stdio.h>
#include<stdlib.h>

#define ERROR 0
#define OK 1

typedef struct Queue{
    long *data;
    int head, tail, length;
}Queue;

void init(Queue *q, int length){
    q->data = (long *)calloc(sizeof(long), length);
    q->head = 0;
    q->tail = -1;
    q->length = length; 
}

int push(Queue *q, long element){
    if(q->tail + 1 >= q->length){
        return ERROR;
    }
    q->tail++;
    q->data[q->tail] = element;
    return OK;
}
void output(Queue *q1, Queue *q2, Queue *q3){
    for(int i = q1->head, j = q2->head, k = q3->head; i <= 9; i++, j++, k++){
        printf("%ld %ld %ld\n",q1->data[i], q2->data[j], q3->data[k]);
        
    }
    printf("\n"); 
}
int empty(Queue *q){
    return q->head > q->tail;
}

void clear(Queue *q) {
    free(q->data);
    free(q);
}
int main(){
    int m = 0;
    long str[11];
    Queue *q1 = (Queue *)malloc(sizeof(Queue));
    init(q1, 10);
    Queue *q2 = (Queue *)malloc(sizeof(Queue));
    init(q2, 10);
    Queue *q3 = (Queue *)malloc(sizeof(Queue));
    init(q3, 10);
    for(int i = 0; i < 10; i++){
        scanf("%d %ld", &m, &str[i]);
        if(m == 0){
            push(q1, str[i]);
        }
        else if(m == 1){
            push(q2, str[i]);
        }else{
            push(q3, str[i]);
        }
    }
    output(q1, q2, q3);
    clear(q1);
    clear(q2);
    clear(q3);
    return 0;
    
}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • android 蓝牙 pbap 获取通话时间 之前,我们利用 pbap 协议获取到了用户的通讯录。那自然而然产生了...
    弄码哥nomag阅读 13,123评论 12 7
  • 表情是什么,我认为表情就是表现出来的情绪。表情可以传达很多信息。高兴了当然就笑了,难过就哭了。两者是相互影响密不可...
    Persistenc_6aea阅读 127,586评论 2 7
  • 16宿命:用概率思维提高你的胜算 以前的我是风险厌恶者,不喜欢去冒险,但是人生放弃了冒险,也就放弃了无数的可能。 ...
    yichen大刀阅读 11,310评论 0 4

友情链接更多精彩内容