JayMagician 2022-06-14 02:34 采纳率: 28.6%
浏览 73
已结题

c语言数据结构链表遍历

问题遇到的现象和发生背景

小T昨天很不爽
昨天体彩销售点买了2注生日号码玩,当晚开奖后……
小T号码: 8902088
中奖号码:3902888
一个号码不对就差了十几万……
小T想:为什么规则是那样玩的啊……为什么5个号码要连续才能中二等奖啊……
我自己创建个规则,开N个数字,只要数字位置对了不一定要连续就可以有奖。
现在有一个中奖号码,有一个兑奖号码,小T想知道一共有多少个数字位置正确的,N太大了……

要求用链表做
输入:

输入数据第一行包含一个整数T表示有T组测试数据

对于每组测试数据

第一行包含一个整数N,表示有N个数字

第二行包含N个中奖号码

第三行包含N个兑奖号码

输出:

对于每组测试数据输出有多少个号码位置正确了

样例输入:

2
7
3902888
8902088
10
1234567890
0987654321

样例输出:
5
0

  • 写回答

3条回答 默认 最新

  • xdspower 2022-06-14 12:52
    关注
    #include<stdio.h>
    #include<stdlib.h>
     
    typedef struct node
    {
        char data;/*数据域*/ 
        struct node *next;/*指针域*/
    } Node,*Link;
     
    void destroy(Link head)
    {
       Link  p;
       while (head!=NULL)/*当还有头结点存在时*/
       {
          p=head;/*头结点是待删除结点*/
          head=head->next;/*先连*/
          free(p);/*后断*/
       }
    }
     
    int main()
    {
        int t,i,j,n,count;
        scanf("%d",&t);
        int *rt = (int  *)malloc(sizeof(int) * t); /* 申请一个用来记录结果数据的数组。*/
        for(i =0;i<t;i++) /*多组输入*/
        {
            count=0;
            scanf("%d",&n);
            Link head1,head2,c1,c2,l;
            head1=NULL; 
            head2=NULL;
            for(j=0; j<n; j++)/*创建后续节点*/
            {
                l=(Link)malloc(sizeof(Node));
                l->next=NULL;
                scanf("%c",&(l->data));
         
                if(head1==NULL){
                    head1=l;
                    c1=head1;
                }else{
                    c1->next=l;
                    c1=l;
                }
            }
            getchar();
            for(j=0; j<n; j++)/*创建后续节点*/
            {
                l=(Link)malloc(sizeof(Node));
                l->next=NULL;
                scanf("%c",&(l->data));
                
                if(head2==NULL){
                    head2=l;
                    c1=head2;
                }else{
                    c1->next=l;
                    c1=l;
                }
            }
            c1=head1;
            c2=head2;
            while(c1!=NULL)/*因为中奖号码和兑奖号码一样长,当c1不为空时,c2也不为空*/
            {
                if(c1->data==c2->data)/*他们相等时*/
                   count++;
                c1=c1->next;/*往后移*/
                c2=c2->next;
            }
            rt[i]=count;
            destroy(head1);
            destroy(head2);
        }
        for(i=0;i<t;i++){
           printf("%d\n",rt[i]);
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 6月16日
  • 已采纳回答 6月16日
  • 创建了问题 6月14日

悬赏问题

  • ¥30 征集Python提取PDF文字属性的代码
  • ¥15 如何联系真正的开发者而非公司
  • ¥15 有偿求苍穹外卖环境配置
  • ¥15 代码在keil5里变成了这样怎么办啊,文件图像也变了,
  • ¥20 Ue4.26打包win64bit报错,如何解决?(语言-c++)
  • ¥15 clousx6整点报时指令怎么写
  • ¥30 远程帮我安装软件及库文件
  • ¥15 关于#自动化#的问题:如何通过电脑控制多相机同步拍照或摄影(相机或者摄影模组数量大于60),并将所有采集的照片或视频以一定编码规则存放至规定电脑文件夹内
  • ¥20 (求远程解决)深信服vpn-2050这台设备如何配置才能成功联网?
  • ¥15 Arduino的wifi连接,如何关闭低功耗模式?