NYOJ----1124數量

来源:http://www.cnblogs.com/520xiuge/archive/2016/04/02/5347085.html
-Advertisement-
Play Games

數量 時間限制:200 ms | 記憶體限制:65535 KB 難度:0 HJS大牛想去街上吃飯,街道旁邊拴著很多狗,他想我堂堂......(省略n個字)豈會被狗咬,所以他很牛的從狗的面前經過,不管是否被上一條狗咬過,下次還會從狗的面前過(J I A N) 現在問題來了,我們給狗編號從1...n,有多 ...


數量

時間限制:200 ms  |  記憶體限制:65535 KB 難度:0
描述

HJS大牛想去街上吃飯,街道旁邊拴著很多狗,他想我堂堂......(省略n個字)豈會被狗咬,所以他很牛的從狗的面前經過,不管是否被上一條狗咬過,下次還會從狗的面前過(J I A N)

現在問題來了,我們給狗編號從1...n,有多次詢問,每次詢問M,N這一段有多少狗咬過他有多少狗沒有咬過他

輸入
輸入有多組數據,每組數據有N,M代表N個狗,M次詢問(n<=1000000)
接下來一行有n個數正數代表被狗咬,負數代表不咬,0代表不確定看心情,所以我們只計算確定的就可以了
接下來M行每行兩個數a,b代表a到b這一段
輸出
每次查詢輸出一行,每行兩個數中間有一個空格,分別代表咬人的狗的數量,沒咬人的數量
樣例輸入
5 6
-1 -2 3 4 5
1 2
1 3
1 4
2 4
3 5
1 5
樣例輸出
0 2
1 2
2 2
2 1
3 0
3 2
//主要是要剔除0,即不確定的數量
#include <stdio.h>
int ydog[1000001],dog[1000001],flag[1000001],flag1[1000001];//定義全局變數區而不可定義為棧區(棧溢出),s[0] = 0
int main()
{
    int N,M,i,a,b,s;
    while(scanf("%d%d",&N,&M) != EOF)  
    {
        for(i=1;i<=N;i++)
        {
            scanf("%d",&ydog[i]);
            if(ydog[i] > 0)
            {
                dog[i] = dog[i-1] + 1;//dog[0] = 0
                flag[i] = 1;//咬人 
                flag1[i] = flag1[i-1];//要剔除的0的個數和前一個相同 
            }
            else{
                dog[i] = dog[i-1];//dog[0] = 0
                flag[i] = 0;//不確定和確定不咬人的 
                if(ydog[i] == 0)
                    flag1[i] = flag1[i-1] + 1;//要剔除掉0(不確定)
                else{
                    flag1[i] = flag1[i-1];
                }
            }
        }
        for(i=1;i<=M;i++)
        {
            scanf("%d%d",&a,&b);//編號 
            printf("%d %d\n",dog[b]-dog[a]+flag[a],(b-a+1-(flag1[b]-flag1[a]+(!ydog[a])))-(dog[b]-dog[a]+flag[a]));
        }
    }
    return 0;
}

 

//----JZT_wuyang
#include <stdio.h>
int main()
{
    int n, m, x, y, z, i, a[100005] = {0}, b[100005] = {0};
    while (~scanf("%d%d", &n, &m))
    {
        for (i = 1, y = z = 0; i <= n; i++)
        {
            scanf("%d", &x);
            if (x > 0)
                y ++;
            else if (x < 0)
                z ++;
            a[i] = y;
            b[i] = z;
        }
        while (m--)
        {
            scanf("%d%d", &x, &y);
            printf("%d %d\n", a[y]-a[x-1], b[y]-b[x-1]);
        }
    }
    return 0;
}

 

 

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果使用的是redis2.x,在項目中使用客戶端分片(Shard)機制。(具體使用方式:第九章 企業項目開發--分散式緩存Redis(1) 第十章 企業項目開發--分散式緩存Redis(2)) 如果使用的是redis3.x中的集群,在項目中使用jedisCluster。 1、項目結構 2、pom.x ...
  • HashMap簡介: HashMap在日常的開發中應用的非常之廣泛,它是基於Hash表,實現了Map介面,以鍵值對(key-value)形式進行數據存儲,HashMap在數據結構上使用的是數組+鏈表。允許null鍵和null值,不保證鍵值對的順序。 HashMap檢索數據的大致流程: 當我們使用Ha ...
  • 【轉自 "太陽尚遠的博客" : "http://blog.yeqianfeng.me/2016/04/01/python yield expression/" 】 使用過 python 的 aiohttp 第三方庫的同學會知道,利用 aiohttp 來構造一個最簡單的web伺服器是非常輕鬆的事情,只 ...
  • 本人設計了一個高效讀寫鎖,可實現多個線程讀一個線程寫的鎖,應該比Delphi自帶的讀寫鎖高效,本人沒有做對比測試。 本文的鎖不可以在一個線程里重入,否則會鎖死,另外讀寫鎖最多支持65535個線程同時讀。 ...
  • <!--?xml version="1.0" encoding="UTF-8" standalone="no"?--> elixir在1.2後增加了一個新的特性i helper. 在iex shell中使用i可以查看任意數據的數據類型和詳細描述 #查看變數描述 iex(1)> i {:test, " ...
  • spring.jar 是包含有完整發佈模塊的單個jar 包。但是不包括mock.jar, aspects.jar, spring-portlet.jar, and spring-hibernate2.jar。spring-src.zip就是所有的源代碼壓縮包。除了spring.jar 文件,Spri ...
  • 這個對象池相當小巧,支持加鎖以方便支持線程安全,當然了,如果在單線程中使用,可以指定一個偽鎖。 這個對象池並不能解決記憶體碎片問題,只是用空間換時間。這個代碼相當簡短,一看就明白,所以不寫用例了。還有這個鎖的代碼就不貼了,因為鎖的樣式各有不同,還有避免跑題,避免喧賓奪主。 上代碼: 不夠150字不允許 ...
  • JAVA Quick Java 8 or Java 7 Dev Environments With Docker Printing arrays by hacking the JVM Mobile How to Create a News Reader With React Native: Web ... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...