UVa Problem 110 - Meta-Loopless Sorts

  1. // UVa Problem 110 - Meta-Loopless Sorts   
  2. // Verdict: Accepted   
  3. // Submission Date: 2011-11-25   
  4. // UVa Run Time: 0.196s   
  5. //   
  6. // 版权所有(C)2011,邱秋。metaphysis # yeah dot net   
  7. //   
  8. // [解题方法]   
  9. // 啊哈,又是一道很有意思的模拟题。本题解是依照题目所给的示例模拟生成插入排序的 Pascal 程序。   
  10.   
  11. #include <iostream>   
  12.   
  13. using namespace std;  
  14.   
  15. int n;  
  16. string tab(2, ' ');  
  17.   
  18. string substr(string s, int start, int length)  
  19. {  
  20.     if (start >= s.length())  
  21.         return "";  
  22.     return s.substr(start, length);  
  23. }  
  24.   
  25. void writeln(string space, string sequences)  
  26. {  
  27.     cout << space << "writeln(";  
  28.     for (int i = 0; i < sequences.length(); i++)  
  29.         cout << (i ? "," : "") << sequences[i];  
  30.     cout << ")\n";  
  31. }  
  32.   
  33. void sort(string space, string sequences)  
  34. {  
  35.     char c = (char) ('a' + sequences.length());  
  36.     for (int i = sequences.length(); i >= 0; i--)  
  37.     {  
  38.         if (i)  
  39.         {  
  40.             cout << space << "if " << sequences[(i ? (i - 1) : i)];  
  41.             cout << " < " << c << " then\n";  
  42.         }  
  43.   
  44.         string tmp = substr(sequences, 0, i) + c +  
  45.             substr(sequences, i, sequences.length() - i);  
  46.   
  47.         if (tmp.length() == n)  
  48.             writeln(space + (i ? tab : ""), tmp);  
  49.         else  
  50.             sort(space + tab, tmp);  
  51.   
  52.         if (i)  
  53.         {  
  54.             cout << space << "else\n";  
  55.             space += tab;  
  56.         }  
  57.     }  
  58. }  
  59.   
  60. int main(int argc, char const *argv[])  
  61. {  
  62.     int cases;  
  63.     bool printBlankLine = false;  
  64.       
  65.     cin >> cases;  
  66.     while (cases--)  
  67.     {  
  68.         cin >> n;  
  69.   
  70.         if (printBlankLine)  
  71.             cout << "\n";  
  72.         else  
  73.             printBlankLine = true;  
  74.   
  75.         cout << "program sort(input,output);\n";  
  76.   
  77.         cout << "var\n";  
  78.         for (int i = 0; i < n; i++)  
  79.             cout << (i ? "," : "") << (char) ('a' + i);  
  80.         cout << " : integer;\n";  
  81.   
  82.         cout << "begin\n";  
  83.   
  84.         cout << (tab + "readln(");  
  85.         for (int i = 0; i < n; i++)  
  86.             cout << (i ? "," : "") << (char) ('a' + i);  
  87.         cout << ");\n";  
  88.   
  89.         sort("""");  
  90.   
  91.         cout << "end.\n";  
  92.     }  
  93.   
  94.     return 0;  
  95. }  
// UVa Problem 110 - Meta-Loopless Sorts
// Verdict: Accepted
// Submission Date: 2011-11-25
// UVa Run Time: 0.196s
//
// 版权所有(C)2011,邱秋。metaphysis # yeah dot net
//
// [解题方法]
// 啊哈,又是一道很有意思的模拟题。本题解是依照题目所给的示例模拟生成插入排序的 Pascal 程序。

#include <iostream>

using namespace std;

int n;
string tab(2, ' ');

string substr(string s, int start, int length)
{
	if (start >= s.length())
		return "";
	return s.substr(start, length);
}

void writeln(string space, string sequences)
{
	cout << space << "writeln(";
	for (int i = 0; i < sequences.length(); i++)
		cout << (i ? "," : "") << sequences[i];
	cout << ")\n";
}

void sort(string space, string sequences)
{
	char c = (char) ('a' + sequences.length());
	for (int i = sequences.length(); i >= 0; i--)
	{
		if (i)
		{
			cout << space << "if " << sequences[(i ? (i - 1) : i)];
			cout << " < " << c << " then\n";
		}

		string tmp = substr(sequences, 0, i) + c +
			substr(sequences, i, sequences.length() - i);

		if (tmp.length() == n)
			writeln(space + (i ? tab : ""), tmp);
		else
			sort(space + tab, tmp);

		if (i)
		{
			cout << space << "else\n";
			space += tab;
		}
	}
}

int main(int argc, char const *argv[])
{
	int cases;
	bool printBlankLine = false;
	
	cin >> cases;
	while (cases--)
	{
		cin >> n;

		if (printBlankLine)
			cout << "\n";
		else
			printBlankLine = true;

		cout << "program sort(input,output);\n";

		cout << "var\n";
		for (int i = 0; i < n; i++)
			cout << (i ? "," : "") << (char) ('a' + i);
		cout << " : integer;\n";

		cout << "begin\n";

		cout << (tab + "readln(");
		for (int i = 0; i < n; i++)
			cout << (i ? "," : "") << (char) ('a' + i);
		cout << ");\n";

		sort("", "");

		cout << "end.\n";
	}

	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值