首页 > 编程语言 >2023数据结构408程序题C语言

2023数据结构408程序题C语言

时间:2024-08-29 19:58:12浏览次数:17  
标签:int 元素 number next Num 2023 new C语言 408

如A=(0,5,5,3,5,7,5,5),则5为主元素;又如A=(0,5,5,3,5,1,5,7),则A中没有主元素。假设 A 中的n个元素保存在一个一维数组中,请设计一个尽可能高效的算法,找出A 的主元素。若存在主元素,则输出该元素;否则输出-1。

#include <stdio.h>
#include <stdlib.h>
//定义结构体数组S,其中的元素不仅有值,还有该值在S中出现的次数。
#define length 8
typedef struct Num
{
    int data;        //数据元素
    int number;  //对应出现的次数
    struct Num *next;
}Num;

Num *new()
{
    Num *new=(Num *)malloc(sizeof (Num));
    new->data=0;
    new->number=0;
    new->next=NULL;
    return new;
}

int main_element(int in[],int n)
{

    Num *Numhead=NULL;
    for(int i=0;i<n;i++)//往链表中添加数据及其对应出现的次数
    {
        if(Numhead==NULL)   //第一个链表头
        {
            Numhead =new();
            Numhead ->data=in[i];
            Numhead ->number++;

        }
        else
        {
            Num *p=Numhead;    //循环遍历的指针
            Num *p1=Numhead;   //用于添加元素的指针
            do     //遍历链表并对比添加每个数据在数组中出现的次数
            {
                if(p->data==in[i])
                {
                    p->number++;
                    break;
                }
                else
                {

                    if(p->next!=NULL)
                    {
                         p1=p->next;
                    }
                    p=p->next;
                }
            }
            while(p!=NULL) ;

            if(p==NULL)//链表中不存在,则创建一个结构体元素接在链表未
            {
                p1->next=new();
                p1->next->data=in[i];
                p1->next->number++;
            }
        }
    }

    Num *p=Numhead;
    int max=-1;
    int maxnum=0;
    while (p!=NULL)     //遍历链表寻找出现最多的数据
    {
        //printf("数据元素 %d 次数:%d\n",p->data,p->number);
        if(max<p->number)
        {
            max=p->number;
            maxnum=p->data;
        }
        p=p->next;
    }
    if(n%2==1)      //判断数组大小的奇偶
    {
        if(max>n/2+1)  //如果为奇数
        {
            return maxnum;
        }
        else
        {
            return -1;
        }
    }
    else {
        if(max>n/2)    //如果为偶数
        {
            return maxnum;
        }
        else
        {
            return -1;
        }
    }

}
int main()
{

    int in[length]={0,5,5,3,5,7,5,5};                 //测试数据
    int num= main_element(in,length);
    if(num==-1)
    {
        printf("没有主元素\n");
    }
    else {
        printf("主元素为%d\n",  main_element(in,length));
    }
    return 0;
}

标签:int,元素,number,next,Num,2023,new,C语言,408
From: https://blog.csdn.net/bobo123355566/article/details/141676928

相关文章

  • C语言基础——函数详解
    目录 函数的概述1函数的概念2函数的意义 函数的定义和使用1函数的定义2函数的调用2.1在同一文件中函数定义后函数调用2.2在同一文件中函数定义前函数调用2.3调用其它文件中定义的函数2.3.1在函数调用文件中进行声明2.3.2在头文件中进行函数的声明 函......
  • 华为20240821笔试第一题笔记
    https://mp.weixin.qq.com/s?__biz=MzkyNTQ3NDAzNw==&mid=2247489703&idx=1&sn=96d3f883998b4bbb395dfc5f08906399&chksm=c02307cb0d07e5b4e7140350b08b20bd7b5ba950886d62a60f44af3bc6c070c1031827edc979&mpshare=1&scene=1&srcid=0821m7WJaqagZ......
  • C语言 备份
    scanf读取原理行缓冲:标准缓存区读入字符‘20\n’,会打印输出20,紧接着的scanf,会打印输出\n,标准输入缓冲区有\n,scanf(c=%c,&c),直接读取缓冲区的\n字符输出。scanf匹配规则:scanf函数在读取整型数、浮点数、字符串会忽略'\n'字符判断闰年#include<stdio.h>intmain(){ in......
  • T240829 【用Liouville定理证明代数学基本定理】
    [T240829]代数学基本定理:在复平面上次数大于\(1\)的一元多项式至少有一个零点.引理(Liouville)有界整函数\(f(z)\)必为常数.证:设\(|f(z)|\)有上界\(M\).即\(\forallz\in\C,~|f(z)|\leM\).于是由Cauchy不等式,对\(\foralla\in\C\),有\[0\le|f'(a)|\le......
  • Alias Autostudio2023软件下载Alias2022软件下载安装包(全版本)
    AliasAutostudio是一款由Autodesk公司开发的概念设计和3D建模软件。它主要用于汽车、工业产品等概念设计阶段,具有以下核心功能:-快速造型-内置丰富的基本造型工具,可以快速生成设计概念构思。-灵活编辑-使用子分模型方式组织数据,支持多种方式编辑模型。-渲染与......
  • inventor软件下载-Autodesk Inventor各版本下载-inventor2023
    Inventor是Autodesk公司推出的三维机械CAD软件,用于机械产品的数字原型设计和仿真模拟。Inventor的主要功能包括:-三维机械建模-包含丰富的机械设计工具,可以快速设计机械产品。-大组装设计-支持大规模机械系统的组装设计。-机械动画仿真-可以进行运动学和动力......
  • C语言涉及问题(文件IO与数组和指针)
    一、文件IO相关1、标准出错、输入、输出三者的缓冲机制是什么?标准出错(stderr):属于不缓冲机制,数据直接写入设备标准输入(stdin)和标准输出(stdout):属于行缓冲和全缓冲,行缓冲时需要用'\n'分隔,全缓冲是缓冲区满才会写入或者输出。冲刷缓冲函数:fflush();无论是如果想将全缓冲......
  • C语言--运算符3
    自增自减运算符i++,i--运算符在后,在表达式中先用i的值,下条语句i的值自增或者自减#include<stdio.h>intmain(){inti=1;intnum;num=i++;printf("num=%d,i=%d\n",num,i);//num=1,i=2return0;}++i先加,后用#include<stdio.h>intmain(){inti=1;intnum;......
  • 【408DS算法题】028基础-查找二叉树的最大值结点
    Index题目分析实现总结题目给定二叉树的根节点,找到二叉树中结点值最大的结点。分析实现对于查找二叉树中的最大值结点,在二叉树的遍历(DFS、层次遍历)的基础上进行修改可以轻松地达成这一目的。本文中选用的是相对直观的后序遍历,具体实现如下:BTNode*findMax(BTN......