PTA 估值一億的AI核心代碼(全網最短的代碼)不到50行,一看就會

原創 轉載請聲明,謝謝

估值一億的AI核心代碼 (超級簡潔,通俗易懂)(20 分)*

題目鏈接 https://pintia.cn/problem-sets/994805046380707840/problems/1111914599412858885

在這裏插入圖片描述
以上圖片來自新浪微博。

本題要求你實現一個稍微更值錢一點的 AI 英文問答程序,規則是:

  1. 無論用戶說什麼,首先把對方說的話在一行中原樣打印出來;
  2. 消除原文中多餘空格:把相鄰單詞間的多個空格換成 1 個空格,把行首尾的空格全部刪掉,把標點符號前面的空格刪掉;
  3. 把原文中所有大寫英文字母變成小寫,除了 I;
  4. 把原文中所有獨立的 can you、could you 對應地換成 I can、I could—— 這裏“獨立”是指被空格或標點符號分隔開的單詞;
  5. 把原文中所有獨立的 I 和 me 換成 you; 把原文中所有的問號 ? 換成驚歎號 !;
  6. 在一行中輸出替換後的句子作爲 AI的回答。

輸入格式:
輸入首先在第一行給出不超過 10 的正整數 N,隨後 N 行,每行給出一句不超過 1000 個字符的、以回車結尾的用戶的對話,對話爲非空字符串,僅包括字母、數字、空格、可見的半角標點符號。

輸出格式:
按題面要求輸出,每個 AI 的回答前要加上 AI: 和一個空格。
輸入樣例:

6
Hello ?
Good to chat with you
can you speak Chinese?
Really?
Could you show me 5
What Is this prime? I,don 't know

輸出樣例:

Hello ?
AI: hello!
Good to chat with you
AI: good to chat with you
can you speak Chinese?
AI: I can speak chinese!
Really?
AI: really!
Could you show me 5
AI: I could show you 5
What Is this prime? I,don 't know
AI: what Is this prime! you,don’t know

這道題主要考察對字符串應用以及對空格的增刪
思路是 在每個標點和空格之前加一個空格 ,劃分成一塊一塊的,然後 逐個判斷輸出就可以了

以下是代碼:

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
	cin >> n;
	getchar();  // 吸收換行 
	string s;
	while(n--){
		string str[1005];
		int cnt=0;
		getline(cin,s);
		cout << s << endl << "AI:";
		for(int i=0;i<s.size();++i){
			if(isalnum(s[i])){
				if(s[i]!='I')
					s[i]=tolower(s[i]);
			}
			else{
				s.insert(i," ");    //對每個非字母和數字之前加空格
				i++;
			}
			if(s[i]=='?')
				s[i]='!';
		}
		stringstream ss(s);        //主要依靠這個函數來取消單詞之前的空格
		while(ss >> s){
			str[cnt++]=s;
		}
		if(!isalnum(str[0][0]))     		// 如果 第一個單詞的第一個位置就是標點  那麼要輸出一個空格,題中要求 每個 AI 的回答前要加上 AI: 和一個空格。
			cout << " ";
		for(int i=0;i<cnt;++i){
			if(!isalnum(str[i][0])){         // 判斷第一個字符是否是 標點,標點前面不要輸出空格
				cout << str[i];
			}
			else if((str[i]=="can" || str[i]=="could") && str[i+1]=="you"){ // &&優先級大於|| ,所以要加括號 
				cout << " I " << str[i];
				i++;
			}
			else if(str[i]=="I" || str[i]=="me"){
				cout << " you";
			}
			else
				cout << " " << str[i];
		}
		cout << endl;
	}
} 

還有什麼問題,請留言,謝謝;
本文原創,轉載請聲明。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章