15 20 32 40 67 89 300 400
 
代码:
#include <stdio.h>
#include <stdlib.h>
#include <memory.h>

//定义无效值
#define INVALIDATE_DATA -1

//处理数据
static void handlerData();
//插入数据,按从大到小的顺序,且不能重复
static void insertArrBySort(int *arr,int arrLen,int inputData,int *resultCount);
//输出结果
static void printArr(int *arr,int arrLen);

int main()
{
     int readLen = 0;
     scanf("%d",&readLen);
     getchar();
    
     while(readLen > 0)
     {
          handlerData();
          --readLen;
     }
    
     return 0;
}

//处理数据
static void handlerData()
{
     int readLen = 0;
     scanf("%d",&readLen);
     getchar();
    
     int arrLen = readLen;
     int resultCount = arrLen; //记录不相同的数目
     int *arr = (int*)malloc(sizeof(int)*arrLen);
     memset(arr,INVALIDATE_DATA,sizeof(int)*arrLen);
    
     while(readLen>0)
     {
          int inputNumber = 0;
          scanf("%d",&inputNumber);
          insertArrBySort(arr,arrLen,inputNumber,&resultCount);
         
          --readLen;
     }
     //处理换行输入
     getchar();
    
     printf("%d\n",resultCount);
     printArr(arr,arrLen);
    
     free(arr);
}

//插入数据,按从大到小的顺序,且不能重复
static void insertArrBySort(int *arr,int arrLen,int inputData,int *resultCount)
{
     int index = INVALIDATE_DATA;
     int i=0;

     for(;i<arrLen;++i)
     {
          if(arr[i] == inputData) //有重复数据不做处理
               break;
         
          if(arr[i] < inputData) //定位到存放该数据的索引位置
          {
               index = i;
               break;
          }
     }
    
     if(index != INVALIDATE_DATA && index < arrLen) //需要移动数据
     {
          if(arr[index] != -1)
          {
               i=arrLen - 1;
               for(;i>index;--i)
               {
                    arr[i] = arr[i-1];
               }
          }

          arr[index] = inputData;
     }
     else
     {
          --(*resultCount);
     }
}

//输出结果
static void printArr(int *arr,int arrLen)
{
     int i=arrLen-1;
     for(;i>=0;--i)
     {
          if(arr[i] == INVALIDATE_DATA) //有重复数据不做处理
               continue;
         
          printf("%d ",arr[i]);
     }
     printf("\n");
}

 
总结:
1.memset的第一个参数值目标指针,第二个参数是赋值内容,第三个值一定要注意,是sizeof(type)*len
2.memset需要头文件 #include <memory.h>
3.malloc需要头文件 #include <stdlib.h>

40-语言入门-40-C小加之随机数的更多相关文章

  1. C++语言入门知识点(详细版)【持续更新每周三更】,小舒舒戳这里!!!

    时间过得好快啊,LITTLESUN已经在这块新地图摸打滚爬了一个多月了.前一段时间出了点小意外一直没能更新博客,昨天被小舒舒催更了(惭愧惭愧)便准备着手来一篇回忆录回首一下这一个月走过的风风雨雨,也希 ...

  2. Delphi XE2 之 FireMonkey 入门(40) - 控件基础: TMemo

    Delphi XE2 之 FireMonkey 入门(40) - 控件基础: TMemo 值得注意的变化: 1.其父类 TScrollBox 的许多特性也很有用处, 如:   Memo1.UseSma ...

  3. 【南阳OJ分类之语言入门】80题题目+AC代码汇总

    小技巧:本文之前由csdn自动生成了一个目录,不必下拉一个一个去找,可通过目录标题直接定位. 本文转载自本人的csdn博客,复制过来的,排版就不弄了,欢迎转载. 声明: 题目部分皆为南阳OJ题目. 代 ...

  4. 《C语言入门1.2.3—一个老鸟的C语言学习心得》—清华大学出版社炮制的又一本劣书及伪书

    <C语言入门1.2.3—一个老鸟的C语言学习心得>—清华大学出版社炮制的又一本劣书及伪书 [薛非评] 区区15页,有80多个错误. 最严重的有: 通篇完全是C++代码,根本不是C语言代码. ...

  5. c语言入门到精通怎么能少了这7本书籍?

    C语言作为学编程最好的入门语言,对一个初进程序大门的小白来说是很有帮助的,学习编程能培养一个人的逻辑思维,而C语言则是公认的最符合人们对程序的认知的一款计算机语言,很多大学都选择了使用C语言作为大学生 ...

  6. C语言中的调试小技巧

    C语言中的调试小技巧 经常看到有人介绍一些IDE或者像gdb这样的调试器的很高级的调试功能,也听人说过有些牛人做工程的时候就用printf来调试,不用特殊的调试器.特别是在代码经过编译器一些比较复杂的 ...

  7. 入门Leaflet之小Demo

    入门Leaflet之小Demo 写在前面 ---- WebGIS开发基础之Leaflet GIS基本概念:GIS.Map.Layer.Feature.Geometry.Symbol.Data(Poin ...

  8. C/C++编程笔记:C语言入门知识点(三),请收藏C语言最全笔记!

    今天我们继续来学习C语言的入门知识点,第一课:C/C++编程笔记:C语言入门知识点(二),请收藏C语言最全笔记! 21. 输入 & 输出 当我们提到输入时,这意味着要向程序填充一些数据.输入可 ...

  9. 《Ruby语言入门教程v1.0》学习笔记-01

    <Ruby语言入门教程v1.0> 编著:张开川 邮箱:kaichuan_zhang@126.com 想要学习ruby是因为公司的自动化测试使用到了ruby语言,但是公司关于ruby只给了一 ...

  10. C语言入门(1)——C语言概述

    1.程序与编程语言 我们使用计算机离不开程序,程序告诉计算机应该如何运行.程序(Program)是一个精确说明如何进行计算的指令序列.这里的计算可以是数学运算,比如通过一些数学公式求解,也可以是符号运 ...

随机推荐

  1. Android App升级Intent

    点击“更新检查”,自动下载最新版本安装包,然后开始安装,进入安装界面后很快闪退. 在这两天的适配中,发现这样一个问题,即:在升级覆盖安装软件时,程序能进入安装的界面,但会很快闪退.经过多次尝试,终于找 ...

  2. PostgreSQL配置文件--复制

    4 复制 REPLICATION 4.1 Sending Server(s) 4.1.1 max_wal_senders 数字型 默认: max_wal_senders = 10 , 为0表示启用流复 ...

  3. shell脚本之检查局域网中在线的ip地址

    [root@docker-node1 ]# cat ping.sh #!/bin/bash . /etc/init.d/functions for var in {1..254}; do ip=192 ...

  4. Unity Low-level Native Plugin Interface

    https://docs.unity3d.com/Manual/NativePluginInterface.html 拿unity底层graphics device

  5. pycharm2016序列号失效问题解决办法

    1.首先修改配置文件 Linux在/etc/hosts windows的话没记错应该在C:\Windows\System32\drivers\etc\hosts 使用时需要将“0.0.0.0 acco ...

  6. POJ 3020 Antenna Placement 最大匹配

    Antenna Placement Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6445   Accepted: 3182 ...

  7. RDD编程 下(Spark自学四)

    3.5 常见的转化操作和行动操作 3.5.1 基本RDD 1. 针对各个元素的转化操作 两个最常用的转化操作是map()和filter().转化操作map()接受一个函数,把这个函数用于RDD中的每个 ...

  8. 【招聘App】—— React/Nodejs/MongoDB全栈项目:个人中心&退出登录

    前言:最近在学习Redux+react+Router+Nodejs全栈开发高级课程,这里对实践过程作个记录,方便自己和大家翻阅.最终成果github地址:https://github.com/66We ...

  9. 一个简单的JS函数,用于判断文本是否数字

    /****************************************************** 判断是否是数字(整数,小数均可,不包括负数)* 2014年10月10日22:38:19* ...

  10. spring 动态定时任务

    功能介绍:商品自动上架.按修改或添加时设置的自动上架时间而启动定时任务 更改商品状态为上架. spring 中配置文件 <?xml version="1.0" encodin ...