POJ C++程序設計 編程題#7:字符串排序

編程題#7:字符串排序

來源: 北京大學在線程序評測系統POJ (Coursera聲明:在POJ上完成的習題將不會計入Coursera的最后成績。)

總時間限制: 1000ms 內存限制: 1024kB

描述

請按照要求對輸入的字符串進行排序。

#include <iostream>
#include <string>
#include <list>
using namespace std;class A{
private:string name;
public:A(string n) :name(n){}friend bool operator < (const class A& a1, const class A &a2);friend bool operator == (const class A &a1, const class A &a2){if (a1.name.size() == a2.name.size())return true;elsereturn false;}friend ostream & operator << (ostream &o, const A &a){o << a.name;return o;}string get_name() const{return name;}int get_size() const{return name.size();}
};
// 在此處補充你的代碼
int main(int argc, char* argv[])
{list<A> lst;int ncase, n, i = 1;string s;cin >> ncase;while (ncase--){cout << "Case: "<<i++ << endl;cin >> n;for (int i = 0; i < n; i++){cin >> s;lst.push_back(A(s));}lst.sort();Show(lst.begin(), lst.end(), Print());cout << endl;lst.sort(MyLarge<A>());Show(lst.begin(), lst.end(), Print());cout << endl;lst.clear();}return 0;
}

?

輸入

第一行是正整數T,表示測試數據的組數

每組測試數據輸入共兩行,

第一行是正整數N,表示字符串個數

第二行是N個字符串, 字符串間用空格分離

?

輸出

對于每組測試數據,先輸出一行:

Case: n

如對第一組數據就輸出Case: 1

第二行按照字符串長度從小到大排序之后輸出N個字符串,字符串之間以空格間隔(不會出現字符串長度相同的情況)

第三行按照字符串首字符ASCII碼序從小到大排序之后輸出N個字符串,字符串之間以空格間隔(不會出現字符串首字母相同的情況)

?

樣例輸入

2
4
a bnss ds tsdfasg
5
aaa bbbb ccccd sa q

?

樣例輸出

Case: 1
a ds bnss tsdfasg
a bnss ds tsdfasg
Case: 2
q sa aaa bbbb ccccd
aaa bbbb ccccd q sa

 1 #include <iostream>
 2 #include <string>
 3 #include <list>
 4 using namespace std;
 5 
 6 class A{
 7 private:
 8     string name;
 9 public:
10     A(string n) :name(n){}
11     friend bool operator < (const class A& a1, const class A &a2);
12     friend bool operator == (const class A &a1, const class A &a2){
13         if (a1.name.size() == a2.name.size())
14             return true;
15         else
16             return false;
17     }
18     friend ostream & operator << (ostream &o, const A &a){
19         o << a.name;
20         return o;
21     }
22     string get_name() const{
23         return name;
24     }
25     int get_size() const{
26         return name.size();
27     }
28 };
29 // 在此處補充你的代碼
30 bool operator< (const A& a1, const A &a2) {
31     return a1.name.size() < a2.name.size();
32 };
33 
34 template <class Iterator, class Function>
35 void Show(Iterator begin, Iterator end, Function print) {
36     for (Iterator iterator1 = begin; iterator1 != end; iterator1++) {
37         print(*iterator1);
38     }
39 };
40 
41 class Print {
42 public:
43     void operator()(const A &a) {
44         cout << a.get_name()<< " ";
45     }
46 };
47 
48 template <class A>
49 struct MyLarge {
50     inline bool operator()(const A &a1, const A &a2) {
51         return a1.get_name() < a2.get_name();
52     }
53 };
54 
55 int main(int argc, char* argv[])
56 {
57     list<A> lst;
58     int ncase, n, i = 1;
59     string s;
60     cin >> ncase;
61     while (ncase--){
62         cout << "Case: "<<i++ << endl;
63         cin >> n;
64         for (int i = 0; i < n; i++){
65             cin >> s;
66             lst.push_back(A(s));
67         }
68         lst.sort();
69         Show(lst.begin(), lst.end(), Print());
70 
71         cout << endl;
72         lst.sort(MyLarge<A>());
73         Show(lst.begin(), lst.end(), Print());
74         cout << endl;
75         lst.clear();
76     }
77     return 0;
78 }

?

轉載于:https://www.cnblogs.com/dagon/p/4833352.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/256677.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/256677.shtml
英文地址,請注明出處:http://en.pswp.cn/news/256677.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Delphi格式化函數Format、FormatDateTime和FormatFloat詳解

轉自&#xff1a;http://outofmemory.cn/code-snippet/7631/Delphi-format-hua-function-Format-FormatDateTime-FormatFloat-explainindetail 1.Format 根據指定所需要的格式&#xff0c;格式化字符串。 原型&#xff1a; function Format(const Format: string const Args: a…

OSPF地址匯總配置

配置過程在R1上&#xff1a;1. 給 Loopback 0 接口分配IP。2. 給ethernet 0/0 接口分配 IP3. 開啟OSPF路由協議&#xff0c;進程號為110&#xff0c;并宣告直連網段。在R2上&#xff1a;1. 給ethernet 0/0 接口分配 IP2. 開啟OSPF路由協議&#xff0c;進程號為110&#xff0c;并…

論文寫作與學術規范課堂筆記01——4.30

論文質量的判斷標準 &#xff08;原創&#xff09;創新性&#xff1a;觀點、方法、材料 寫作質量&#xff1a;邏輯性、語言清晰、數學數據、格式、數據可視化 論文寫作的提升路徑 模仿 經驗

requirejs學習之-- 初始化(一)

為了規范在項目中使用的javascript代碼&#xff0c;我們使用了requirejs框架。 初始階段&#xff0c;我們在按鈕的點擊事件中調用創建的模塊&#xff0c;代碼如下&#xff1a; function button_click() {_this this;var args _this["Command_Params"] || (_this.co…

ROS系統中的多個版本Boost問題

1、刪除多余的boost版本&#xff0c;只需要刪除該版本的libboost*庫以及Boost的頭文件&#xff0c;不需要使用sudo apt-get rm --pugre libboost-dev sudo apt-get armove libboost-dev;這種卸載會把很多Boost依賴的庫刪掉&#xff1b;想要單純的只刪除當前版本的Boost庫&#…

iOS的通知

首先,什么是通知呢,通知跟代理的功能是一樣的,都是傳值,調方法,但是我個人覺得通知比代理還是要簡便的,而且功能更強大,如果你代理弄懂了,那么通知也就非常容易理解了,我認為通知比代理書寫更容易,而且功能更強大.代理是一對一傳值,但是通知可以一對多或多對多,好了不多說了給大…

ValueStack基礎:OGNL

ValueStack基礎&#xff1a;OGNL 要了解ValueStack&#xff0c;必須先理解OGNL(Object Graphic Navigatino Language)&#xff01; OGNL是Struts2中使用的一種表達式語言&#xff0c;它可以用于JSP的標簽庫中&#xff0c;以便能夠方便的訪問各種對象的屬性&#xff1b;它用于界…

4.H - 組合

題目連接&#xff1a;http://acm.hust.edu.cn/vjudge/contest/125308#problem/H 題目大意&#xff1a;下面是一個二人小游戲&#xff1a;桌子上有M堆撲克牌&#xff1b;每堆牌的數量分別為Ni(i1…M)&#xff1b;兩人輪流進行&#xff1b;每走一步可以任意選擇一堆并取走其中的任…

結構體指針需要申請指針內存,結構體對象不需要申請對象內存

struct frame_info { char* data;//圖像數據 int bufsize;//圖像大小 }&#xff1b; 1、struct frame_info* finfoDT new struct frame_info; finfoDT->data new 1280*720 2、struct frame_info finfoDT new struct frame_info; finfoDT.data new 1280*720

圖論——連通圖

Tyvj 2059 元芳看電影 描述 神探狄仁杰電影版首映這天&#xff0c;狄仁杰、李元芳和狄如燕去看電影。由于人實在是太多了&#xff0c;入場的隊伍變得十分不整齊&#xff0c;一個人的前面可能會出現并排的好多人。“元芳&#xff0c;這隊伍你怎么看&#xff1f;”“大人&#xf…

linux-ftools查看Linux 的cached里面有哪些內容

最近&#xff0c;公司有幾臺java服務器經常出現can not allocate memory 的情況。導致SSH登錄失敗。 因此&#xff0c;有必要做點什么。 我們可以使用linux-ftools查看Linux 的cached里面有哪些內容&#xff08;工具: https://code.google.com/p/linux-ftools/&#xff09;&…

matlab常用函數——軟件常用函數

一、軟件操作函數 1)命令窗口函數: clc:清空命令窗口,使用向上箭頭翻看命令。 open:打開文件,文本文件(*.doc),可執行文件(*.exe),圖形文件(*.fig),超文本文件(*.html,*.htm),MATLAB數據庫文件(*.mat),simulink模型文件*.mdl),MATLAB p文件(*.p),…

stanford corenlp的TokensRegex

最近做一些音樂類、讀物類的自然語言理解&#xff0c;就調研使用了下Stanford corenlp&#xff0c;記錄下來。 功能 Stanford Corenlp是一套自然語言分析工具集包括&#xff1a; POS(part of speech tagger)-標注詞性NER(named entity recognizer)-實體名識別Parser樹-分析句子…

將Linux系統下交叉編譯的依賴庫推到ARM平臺下無法建立以來關系解決

問題&#xff1a;平常把opencv庫使用源碼交叉編譯好之后&#xff0c;從windows推到飛機里發現&#xff0c;該庫的依賴關系都沒有了&#xff0c;導致程序運行的時候報該庫大小有問題 解決辦法&#xff1a; 1、將linux下的庫推到ARM平臺中的一個文件夾中&#xff0c;然后將ARM平臺…

Java:switch語句例子

1、輸入一個名次&#xff0c;第1&#xff5e;4名&#xff0c;分別稱為冠軍、亞軍、季軍、殿軍&#xff0c;5名及5名以上&#xff0c;稱為其他名次。 import java.util.Scanner; public class switch1 {public static void main(String[] args){Scanner snew Scanner(System.in)…

SQL計算100以內的質數(可以把100換成任意的整數)

declare i int --定義局部變量ideclare j int --定義局部變量jset i1 --給變量i賦值while i<100 --最外層while循環控制計算20以內的質數&#xff0c;每循環一次提供一個數&#xff0c;判斷它是不是質數begin --最外層while循環開始set j1 --給變量j賦…

matlab常用函數——數據類型函數

三、基本數據類型函數 1)數值函數 double:轉換為雙精度浮點數 single:轉換為單精度浮點數 typecast:在不改變數據大小情況下轉換數據類型 Y=typecast(X,type) type可選范圍:uint8、int8、uint16、int16、uint32、int32、uint64、int64、single、double arrayfun:把函數…

Courses hdu 1083(匹配)

http://acm.hdu.edu.cn/showproblem.php?pid1083 題意&#xff1a;一共有N個學生跟P門課程,一個學生可以任意選一門或多門課,問是否達成: 1.每個學生選的都是不同的課(即不能有兩個學生選同一門課) 2.每門課都有一個代表(即P門課都被成功選過) 今天學姐講匹配時講的題目&#…

進程編譯連接動態庫,需要將動態庫改為lib***.so

1、本身該庫可能編譯成npuDetect.so,但是需要改其名字為libnpuDetect.so,CMakelists才能找到該庫 2、進程中連接動態庫&#xff0c;如果該庫還依賴別的動態庫&#xff0c;則需要繼續把其他的庫也要連接進來